C语言既具有高级语言的特点,又具有低级语言的功能。

所谓位运算是指进行二进制位的运算。

C语言提供的位运算:

运算符   含义  
&   按位与  
|   按位或  
∧   按位异或  
∽   取反  
<<   左移  
>>   右移

说明:

1。位运算符中除∽以外,均为二目(元)运算符,即要求两侧各有一个运算了量。

2、运算量只能是整形或字符型的数据,不能为实型数据。

“按位与”运算符(&)

规定如下:

0&0=0   0&1=0   1&0=0   1&1=1

例:3&5=?
                         先把3和5以补码表示,再进行按位与运算。

3的补码:   00000011  
5的补码:   00000101

&:   00000001

3&5=1

--------------------------------------------------------------------------------

“按位或”运算符(|)

规定如下:

0|0=0   0|1=1   1|0=1   1|1=1

例:060|017=?
                         将八进制数60与八进制数17进行按位或运算。

060   00110000  
017   00001111

|:   00111111

060|017=077

--------------------------------------------------------------------------------

“异或”运算符(∧),也称XOR运算符

规定如下:

0∧0=0   0∧1=1   1∧0=1   1∧1=0

例:57∧42=?
                         将十进制数57与十进制数42进行按位异或运算。

57   00111001  
42   00101010

∧:   00010011

57∧42=19

--------------------------------------------------------------------------------

“取反”运算符(∽)

规定如下:

∽0=1   ∽1=0

例:∽025=?
                         对八进制数25(即二进制0000000000010101)按位求反。

0000000000010101  
↓  
1111111111101010

∽025=177752

--------------------------------------------------------------------------------

左移运算符(<<)

 

将一个数的二进位全部左移若干位,若高位左移后溢出,则舍弃,不起作用。

例:a=a<<2
                         将a的二进制数左移2位,右补0。
                         若a=15,即二进制数00001111,则

a   00001111  
↓   ↓  
a<<1   00011110  
↓   ↓  
a<<2   00111100

最后a=60

--------------------------------------------------------------------------------

右移运算符(>>)

 

将一个数的二进位全部右移若干位,低位移出部分舍弃。

例:a=a>>2
                         将a的二进制数右移2位,左补0。
                         若a=15,即二进制数00001111,则

a   00001111  
↓   ↓  
a>>1   00000111  
↓   ↓  
a>>2   00000011

最后a=3

--------------------------------------------------------------------------------

位运算符与赋值运算符结合可以组成扩展的赋值运算符

如:&=,|=,>>=,<<=,∧=

例:a&=b相当于a=a&b

a<<=2相当于a=a<<2

不同长度的数据进行位运算

如果两个数据长度不同(例如long型和int型)进行位运算时(如a&b,而a为long型,b为int型),系统会将二者按右端对齐。如果b为正数,则左侧16位补满0。若b为负,左端应补满1。如果b为无符号整数型,则左端添满0。

位运算举例
         例:取一个整数a从右端开始的4∽7位

考虑如下:1、先是a右移4位,即a>>4

2、设置一个低4位全为0的数,即∽(∽0<<4)

3、将上面两式进行与运算,即a>>4&∽(∽0<<4)

程序如下:

main()

{unsigned   a,b,c,d;

scanf("%o",&a);

b=a>>4;

c=∽(∽0<<4);

d=b&c;

printf("%o\n%o\n",a,b);

}

结果:331↙

331(a的值,八进制)

15   (d的值,八进制)

例:循环移位。要求将a进行右循环移位。即a右循环移n位,将a中原来左面(16-n)位右移n位。现假设两个字节存放一个整数。如右图。

考虑如下:1、先将a右端n位放到b中的高n位中,即:b=a<<(16-n)

2、将a右移n位,其左面高位n位补0,即c=a>>n

3、将c与b进行按位或运算,即c=c|b

程序如下:

main()

{unsigned   a,b,c;int   n:

scanf("a=%o,n=%d",&a,&n);

b=a<<(16-n);

c=a>>n;

c=c|b;

printf("%o\n%o",a,c);

}

结果:a=157653,n=3↙

331(a的值,八进制)

15   (d的值,八进制)

位段
所谓位段是以位为单位定义长度的结构体类型中的成员。

例:struct   packed-data

{unsigned   a:2;

unsigned   b:6;

unsigned   c:4;

unsigned   d:4;

int             i;

}data;

c语言位运算符的更多相关文章

  1. C语言位运算符:与、或、异或、取反,左移和右移

    C语言位运算符:与.或.异或.取反.左移和右移 个位操作运算符.这些运算符只能用于整型操作数,即只能用于带符号或无符号的char,short,int与long类型. ,则该位的结果值为1,否则为0 | ...

  2. C语言位运算符:与、或、异或、取反、左移和右移

    语言位运算符:与.或.异或.取反.左移和右移 位运算是指按二进制进行的运算.在系统软件中,常常需要处理二进制位的问题.C语言提供了6个位操作运算符.这些运算符只能用于整型操作数,即只能用于带符号或无符 ...

  3. 【转】C语言位运算符:与、或、异或、取反、左移与右移详细介绍

    转载自:http://www.jb51.net/article/40559.htm,感谢原作者. 以下是对C语言中的位运算符:与.或.异或.取反.左移与右移进行了详细的分析介绍,需要的朋友可以过来参考 ...

  4. C语言位运算符:与、或、异或、取反、左移与右移详细介绍

    位运算是指按二进制进行的运算.在系统软件中,常常需要处理二进制位的问题.C语言提供了6个位操作运算符.这些运算符只能用于整型操作数,即只能用于带符号或无符号的char,short,int与long类型 ...

  5. C语言位运算符详解

    原文链接:https://www.cnblogs.com/911/archive/2008/05/20/1203477.html 位运算是指按二进制进行的运算.在系统软件中,常常需要处理二进制位的问题 ...

  6. 基础知识复习(一)——C语言位运算符详解

    常用的位运算符:与(&),取反(~),或(|),异或(^),左移(«),右移(») 1. 与(&)操作符,按位与,全为1 时,结果取1 11001 &10011 结果:1000 ...

  7. C语言--位运算符

    一.位运算符 1.按位与:& 1> 功能 * 只有对应的两个二进制位为1时,结果位才为1,否则为0 * 举例:10用二进制表示为1010,  7用二进制表示为0111.对两个数值进行&a ...

  8. C语言位运算符及作用:与、或、异或、取反、左移和右移

    一.& 按位与 如果两个相应的二进制位都为1,则该位的结果值为1,否则为0应用:(1)清零 若想对一个存储单元清零,即使其全部二进制位为0,只要找一个二进制数,其中各个位符合一下条件:原来的数 ...

  9. c 语言的位运算符复习

    转载和修正,原文连接:http://www.cnblogs.com/911/archive/2008/05/20/1203477.html 位运算是指按二进制进行的运算.在系统软件中,常常需要处理二进 ...

随机推荐

  1. jquery实现公告上下滚动显示

    js: // JavaScript Documentfunction b(){ t = parseInt(x.css('top')); y.css('top','19px'); x.animate({ ...

  2. linux下查询域名或IP注册信息的操作记录(whois)

    在运维工作中,有时需要查询某些域名的注册信息(域名的NS,注册用户,注册邮箱等),可以使用whois这个命令.whois命令令用来查找并显示指定帐号(或域名)的用户相关信息,因为它是到Network ...

  3. IOS ScrollowView 滑动到边缘后不允许再拖动

    当scrollowview滑动图片时,滑动到最后一张图本应该不让其滑动,但是如果不可以去设置属性,依然可以滑动,露出白色的底色,挺影响美观的, 可以设置其属性: sv.bounces=NO; 这样就不 ...

  4. HDU5100Chessboard(数论)

    HDU5100Chessboard(数论) 题目链接 题目大意:用k∗1的瓷砖区铺n∗n的矩形,问能铺上的最大的面积. 解题思路:这题没有直接得出结论:l = n%k, ans = max[(n^2 ...

  5. Extended ComboBox添加图标

    Extended ComboBox添加图标 关键点 实现过程 // MFC02Dlg.h : header fileCImageList m_imageList;  // MFC02Dlg.cpp : ...

  6. HDU - 5187 - zhx&#39;s contest (高速幂+高速乘)

    zhx's contest Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) To ...

  7. Splay Tree的删除操作

    Splay Tree的插入操作,搜索操作,和删除操作都实现了,那么就能够使用来解题了. 指针的删除操作的处理还是那么难的,非常多坎须要避开. 同一个坎还是坑了我好多次,就是指针传递的问题,什么时候须要 ...

  8. java24 手写服务器最终版本

    手写服务器最终版本; <?xml version="1.0" encoding="UTF-8"?> <web-app> <serv ...

  9. careercup-递归和动态规划 9.8

    9.8 给定数量不限的硬币,币值为25分.10分.5分和1分,编写代码就是n分有几种表示法. 解法: 使用回溯法进行解决,实际上就是一个类似枚举的过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满 ...

  10. 进程控制之vfork函数

    vfork函数的调用序列和返回值与fork相同,但两者的语义不同. vfork用于创建一个新进程,而新进程的目的是exec一个新程序.vfork和fork一样都创建一个子进程,但是它并不将父进程的地址 ...