C语言位运算和sizeof运算符详解_C 语言

位运算和sizeof运算符

      C语言中提供了一些运算符可以直接操作整数的位,称为位运算,因此位运算中的操作数都必须是整型的。位运算的效率是比较高的,而且位运算运用好的话会达到意想不到的效果。位运算主要有6种:与(&),或(|),取反(~),异或(^),左移(<<),右移(>>)。

1.位运算中的类型转换

      位运算都必须进行Integer Promotion。在进行运算之前,都必须将char型、short型的数据转换为int或者unsigned int型再参与运算。

如下面这段程序:

#include<stdio.h>

int main(void)
{
  unsigned char c=0xfc;
  unsigned int i=~c;
  printf("0x%x\n",i);
  return 0;
}

在对c取反之前,先将c提升为int型,则为0x000000fc,取反之后结果就是0xffffff03,所以程序输出结果是0xffffff03,而不是0x00000003.

2.异或运算的一些特性。

  a^0=a,a^a=0这两个特性是异或运算最常用的特性。

 利用这个特性可以不借助临时变量就可以交换两个整数

#include<stdio.h>

int main(void)
{
  int a=3;
  int b=2;
  a=a^b;
  b=a^b;
  a=a^b;
  printf("%d %d\n",a,b);
  return 0;
}

  不借助临时变量交换两个数据还可以用另外一种方法。

  a=a+b;

  b=a-b;

  a=a-b;

 这两种方法各有优点和缺点,位运算只能用于交换整数,而第二种可能会发生溢出。

3.sizeof运算符

   sizeof是一个特殊的运算符,它有两种形式:sizeof 表达式和sizeof (类型名).对于sizeof运算符要注意几点:

   1)如果是表达式的话,括号可以省略,但是对于类型,括号不能省;

   2)sizeof求算的是所占的空间,如果作用于表达式,这个表达式是不进行求值的,只根据类型转换求得表达式的类型,而表达式的类型在编译时就可以确定。

#include<stdio.h>

int main(void)
{
  int i=1;
  int j;
  j=sizeof i++;
  printf("%d %d\n",i,j);
  return 0;
}

程序执行结果为:

1 4

Press any key to continue

可以看出i的值并没有改变,可知表达式i++并没有进行求值。

再看下面这个程序:

#include <stdio.h>

int main(int argc, char *argv[])
{
  char ch ='a';
  int i =10;
  printf("%d\n",sizeof i+ch);
  return 0;
}

执行结果为:

101

在有二元运算符的表达式中,必须加括号,否则sizeof只会对第一个操作数进行空间计算。由于ch的整形值为97,加上4,便是101了。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索c语言中的位运算符、c语言位运算详解、c语言运算符详解、sizeof运算符、sizeof运算符如何使用,以便于您获取更多的相关知识。

时间: 2025-01-04 23:56:00

C语言位运算和sizeof运算符详解_C 语言的相关文章

C语言 经典题目螺旋矩阵 实例详解_C 语言

C语言 经典题目螺旋矩阵 //N阶螺旋矩阵 #include <stdio.h> #include <stdlib.h> int main() { int N,i,j,n,num=1; int a[10][10]={0}; printf("输入你要输出的几阶中断:"); scanf("%d",&N); for(n=0;n<=N/2;n++) { for(j=n;j<=N-n-1;j++) a[n][j]=num++; fo

C语言实现排序算法之归并排序详解_C 语言

排序算法中的归并排序(Merge Sort)是利用"归并"技术来进行排序.归并是指将若干个已排序的子文件合并成一个有序的文件. 一.实现原理: 1.算法基本思路 设两个有序的子文件(相当于输入堆)放在同一向量中相邻的位置上:R[low..m],R[m+1..high],先将它们合并到一个局部的暂存向量R1(相当于输出堆)中,待合并完成后将R1复制回R[low..high]中. (1)合并过程 合并过程中,设置i,j和p三个指针,其初值分别指向这三个记录区的起始位置.合并时依次比较R[i

C++中的按位与&amp;、按位与或|、按位异或^运算符详解_C 语言

按位与运算符:& 语法 expression & expression 备注 表达式可以是其他"与"表达式,或(遵循下面所述的类型限制)相等表达式.关系表达式.加法表达式.乘法表达式.指向成员的指针表达式.强制转换表达式.一元表达式.后缀表达式或主表达式. 按位"与"运算符 (&) 会将第一操作数的每一位与第二操作数的相应位进行比较.如果两个位均为 1,则对应的结果位将设置为 1.否则,将对应的结果位设置为 0. 按位"与"

C语言 指针与二维数组详解_C 语言

二维数组在概念上是二维的,有行和列,但在内存中所有的数组元素都是连续排列的,它们之间没有"缝隙".以下面的二维数组 a 为例: int a[3][4] = { {0, 1, 2, 3}, {4, 5, 6, 7}, {8, 9, 10, 11} }; 从概念上理解,a 的分布像一个矩阵: 0   1   2   3 4   5   6   7 8   9  10  11 但在内存中,a 的分布是一维线性的,整个数组占用一块连续的内存: C语言中的二维数组是按行排列的,也就是先存放 a[

c语言中 基于随机函数的使用详解_C 语言

在C语言中,rand()函数可以用来产生随机数,但是这不是真真意义上的随机数,是一个伪随机数,是根据一个数,我们可以称它为种子,为基准以某个递推公式推算出来的一系数,当这系列数很大的时候,就符合正态公布,从而相当于产生了随机数,但这不是真正的随机数,当计算机正常开机后,这个种子的值是定了的,除非你破坏了系统,为了改变这个种子的值,C提供了srand()函数,它的原形是void srand( int a). 可能大家都知道C语言中的随机函数random,可是random函数并不是ANSI C标准,

C语言、C++内存对齐问题详解_C 语言

这也可以? 复制代码 代码如下: #include <iostream> using namespace std;   struct Test_A {      char a;      char b;      int c; };   struct Test_B {      char a;      int c;      char b; };   struct Test_C {      int c;      char a;      char b; };   int main() {

C语言文件操作 fopen, fclose, mkdir详解_C 语言

1.建文件夹 int _mkdir(const char *path,mode_t mode); 函数名: _mkdir 功 能: 建立一个目录 用 法: int _mkdir( const char *dirname ); 头文件库:direct.h 返回值:创建一个目录,若成功则返回0,否则返回-1 ===================================================== 2.打开文件fopen() 函数功能: 打开一个文件 函数原型:FILE * fope

深入c语言continue和break的区别详解_C 语言

自认为C语言还算入门的人,看来还是高估自己了.没想到在这个地方还有这么有趣的东西.有些话看来要仔细深究才能真正入门啊.... ================================================================================ 复制代码 代码如下: #include <stdio.h> int main(void) {    int flag=0;    for(int j=0; j <2; j++) {       if(j=

基于C语言EOF与getchar()的使用详解_C 语言

大师级经典的著作,要字斟句酌的去读,去理解.以前在看K&R的The C Programming Language(SecondEdition)第1.5节的字符输入/输出,被getchar()和EOF所迷惑了.可能主要还是由于没有搞清楚getchar()的工作原理和EOF的用法.因此,感觉很有必要总结一下,不然,很多琐碎的知识点长时间过后就会淡忘的,只有写下来才是最好的方法. 其实,getchar()最典型的程序也就几行代码而已.本人所用的环境是DebianGNU/Linux,在其他系统下也一样.