C语言位运算符(附例题讲解)
C语言课件第12章 位运算
1.
位运算规则: 位运算规则: A 0 0 1 1 B 0 1 0 1 A&B 0 0 0 1 A|B 0 1 1 1 A^B 0 1 1 0 ~a 1 1 0 0
例12.1 若 a=(15)10=(00001111)2, a=(15) b=(80)10=(01010000)10 则: a&b = 0000 0000, a|b = 0101 1111, a^b =01011111 , ~a = 1111 0000
/*设 a 为待处理的数据,转换成二进制为00001000, /*设 为待处理的数据,转换成二进制为00001000, b用来保存将a的高4位清0后的结果*/ 用来保存将a的高4位清0后的结果* main() { unsigned char a,b,c; a=8; b=a&0x0f; c=b|0xa0; /*c用于保存最终结果*/ b=a&0x0f; c=b|0xa0; /*c用于保存最终结果 用于保存最终结果* printf("%x" printf("%x",c); }
4)左移,右移运算实现将一个数的各个二进制位向左,向 4)左移,右移运算实现将一个数的各个二进制位向左,向 右移若干位. 左移:将一个数的各个二进制位左移若干位,高位左移 左移:将一个数的各个二进制位左移若干位, 后舍弃,低位补0 后舍弃,低位补0 . 若定义: 若定义: int a=8; 即a= 0000 1000 0010 0000 0000 右移:将一个数的各个二进制位右移若个位,低位右移 右移:将一个数的各个二进制位右移若个位, 后舍弃, 还是补1 后舍弃,高位补 0还是补1,要区别有符号数还是无符号 无符号数高位补0 有符号数高位补原符号位. 数:无符号数高位补0,有符号数高位补原符号位. 若定义 unsigned int a=8; 即 00001000, a=8; 00001000, 则语句 a=a>>2 ;将 a 的各二进制位右移 2 位,空出的 高位补 0.结果为: 0000 0010 , 则语句a=a<<2; 则语句a=a<<2;
c语言运算符号详解(二)
c语言运算符号详解(二)C语言运算符号详解简介C语言是一种通用的编程语言,广泛应用于系统开发,嵌入式系统和高性能计算等领域。
运算符是C语言中用来进行各种运算操作的符号,本文将详细介绍C语言中常用的运算符。
算术运算符•+:求两个数的和。
•-:求两个数的差。
•*:求两个数的乘积。
•/:求两个数的商。
•%:求两个数的余数。
关系运算符•==:判断两个数是否相等。
•!=:判断两个数是否不等。
•>:判断左边的数是否大于右边的数。
•<:判断左边的数是否小于右边的数。
•>=:判断左边的数是否大于等于右边的数。
•<=:判断左边的数是否小于等于右边的数。
逻辑运算符•&&:逻辑与,判断两个条件是否同时成立。
•||:逻辑或,判断两个条件是否至少有一个成立。
•!:逻辑非,取反操作。
位运算符•&:按位与,对于两个操作数的每一个对应位,当且仅当两个位都为1时为1。
•|:按位或,对于两个操作数的每一个对应位,当且仅当两个位都为0时为0。
•^:按位异或,对于两个操作数的每一个对应位,当且仅当两个位不相同时为1。
•<<:左移运算符,在二进制表示的数值的右边补0。
•>>:右移运算符,在二进制表示的数值的左边补0。
赋值运算符•=:将右边的值赋给左边的变量。
•+=:将右边的值加上左边的变量,并将结果赋给左边的变量。
•-=:将右边的值减去左边的变量,并将结果赋给左边的变量。
•*=:将右边的值乘以左边的变量,并将结果赋给左边的变量。
•/=:将左边的变量除以右边的值,并将结果赋给左边的变量。
其他运算符•sizeof:获取变量或数据类型所占的字节数。
•&:取地址运算符,获取变量的内存地址。
•*:指针运算符,用于声明指针和通过指针访问变量。
以上是C语言中常见的运算符,掌握这些运算符的使用方法对于编写高效、准确的程序非常重要。
希望本文能够对读者理解和学习C 语言运算符有所帮助。
c语言位运算符的用法指导
c语言位运算符的用法指导c语言位运算符的用法指导C语言中位运算的运算分量只能是整型或字符型数据,位运算把运算对象看作是由二进位组成的位串信息,按位完成指定的运算,得到位串信息的结果。
下面店铺给大家整理了c语言位运算符的用法,供大家参阅。
位运算符C语言提供了六种位运算符:& 按位与| 按位或^ 按位异或~ 取反<< 左移>> 右移1. 按位与运算按位与运算符"&"是双目运算符。
其功能是参与运算的两数各对应的二进位相与。
只有对应的两个二进位均为1时,结果位才为1 ,否则为0。
参与运算的数以补码方式出现。
例如:9&5可写算式如下:00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。
例如把a 的`高八位清0 ,保留低八位,可作a&255 运算( 255 的二进制数为0000000011111111)。
main(){int a=9,b=5,c;c=a&b;printf("a=%d/nb=%d/nc=%d/n",a,b,c);}2. 按位或运算按位或运算符“|”是双目运算符。
其功能是参与运算的两数各对应的二进位相或。
只要对应的二个二进位有一个为1时,结果位就为1。
参与运算的两个数均以补码出现。
例如:9|5可写算式如下: 00001001|0000010100001101 (十进制为13)可见9|5=13main(){int a=9,b=5,c;c=a|b;printf("a=%d/nb=%d/nc=%d/n",a,b,c);}3. 按位异或运算按位异或运算符“^”是双目运算符。
其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。
C语言运算符ppt课件
§3.8 算术运算符和算术表达式
(2) 算术表达式和运算符的优先级与结合性基 本的算术运算符:
用算术运算符和括号将运算对象(也称操作数) 连接起来的、符合C语法规则的式子,称为C算 术表达式。运算对象包括常量、变量、函数等。
例如: a*b/c-1.5+′a′
是一个合法的表达式
§3.2 常量与变量
• C语言规定了运算符的优先级和结合性。
在表达式求值时,先按运算符的优先级别高低 次序执行,例如先乘除后加减。
• C规定了各种运算符的结合方向(结合性)
算术运算符的结合方向为“自左至右”,即先 左后右 。
printf(“%d,%d,%d”,(a,b,c),b“,c() a,b,
c)”是一个 逗号表达式, 它的值等于c 的值。
逻辑运算符:
逻辑运算符是根据表达式的值来返回真值或是 假值。其实在C语言中没有所谓的真值和假值, 只是认为非0为真值,0为假值。
&& 逻辑与、 || 逻辑或、
! 逻辑非
关系运算符:
例如:
①j=++i; i的值先变成4, 再赋给j,j的值均为4
②j=i++; 先将 i的值3赋给j,j的值为3,然后i变为4
§3.8 算术运算符和算术表达式
注意:
(1)自增运算符(++),自减运算符(--), 只能用于变量,而不能用于常量或表达式,
(2)++和--的结合方向是“自右至左”。
自增(减)运算符常用于循环语句中使循环变量 自动加1。也用于指针变量,使指针指向下一个地址
§3.8 算术运算符和算术表达式
(8)指针运算符 (*和&) (9)求字节数运算符(sizeof) (10)强制类型转换运算符( (类型) ) (11)分量运算符(.->) (12)下标运算符([ ]) (13)其他 (如函数调用运算符())
C语言位运算详解及示例代码
C语⾔位运算详解及⽰例代码所谓位运算,就是对⼀个⽐特(Bit)位进⾏操作。
在《⼆进制思想以及数据的存储》⼀节中讲到,⽐特(Bit)是⼀个电⼦元器件,8个⽐特构成⼀个字节(Byte),它已经是粒度最⼩的可操作单元了。
C语⾔提供了六种位运算符:运算符&|^~<<>>说明按位与按位或按位异或取反左移右移按位与运算(&)⼀个⽐特(Bit)位只有 0 和 1 两个取值,只有参与&运算的两个位都为 1 时,结果才为 1,否则为 0。
例如1&1为 1,0&0为0,1&0也为 0,这和逻辑运算符&&⾮常类似。
C语⾔中不能直接使⽤⼆进制,&两边的操作数可以是⼗进制、⼋进制、⼗六进制,它们在内存中最终都是以⼆进制形式存储,&就是对这些内存中的⼆进制位进⾏运算。
其他的位运算符也是相同的道理。
例如,9 & 5可以转换成如下的运算:0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在内存中的存储)& 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在内存中的存储)-----------------------------------------------------------------------------------0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0001 (1 在内存中的存储)也就是说,按位与运算会对参与运算的两个数的所有⼆进制位进⾏&运算,9 & 5的结果为 1。
⼜如,-9 & 5可以转换成如下的运算:1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在内存中的存储)& 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在内存中的存储)-----------------------------------------------------------------------------------0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在内存中的存储)-9 & 5的结果是 5。
关于C语言位运算及语句详解
式 – 普通字符或转义序列:原样输出
• 格式字符
格式字符:
d,i x,X o u c s e,E f g %%
l
例 m.n
例 int a=1234; float f=123.456; char ch=„a‟; printf(“%8d,%2d\n”,a,a); printf(“%f,%8f,%8.1f,%.2f,%.2e\n”,f,f,f,f,f); printf(“%3c\n”,ch);
运行 •234,1234 1 结果: 123.456000,123.456000, •23.5,123.46,1.23e+02 1 a • 例 static char a[]=“Hello,world!” printf(“%s\n%15s\n%10.5s\n%2.5s\n%.3s\n”,a,a,a,a,a); 运行结果:Hello,world! H • ello,world! H • ello Hello Hel
char a=65;printf(“%c”,a);
百分号本身 printf(“%%”);
A
ABC 5.677890e+02 567.789000 567.789 %
– 说明 » 格式字符要用小写 » 格式字符与输出项个数应相同,按先后顺序一一对应(如果不 同则) » 输出转换:格式字符与输出项类型不一致,自动按指定格式输出
十进制整数
int a=567;printf ( “%d”,a);
567 ff 101 567
十六进制无符号整数 int a=255;printf(“%x”,a); 八进制无符号整数 int a=65;printf(“%o”,a);
c语言程序设计第三版谭浩强第十二章位运算
29
程序如下: 运行情况如下: #include <stdio.h> a=157653,n=3 void main() 15765 3 { unsigned a,b,c; 75765 int n; scanf(“a=%o,n=%d”,&a,&n); b=a<<(16-n); c=a>>n; c=c|b; 运行开始时输入八进制数157653 157653, 运行开始时输入八进制数157653, printf(“%o\n%o”,a,c); 即二进制数1101111110101011 即二进制数1101111110101011 } 循环右移3位后得二进制数0111101111110101 循环右移3位后得二进制数0111101111110101 即八进制数75765 即八进制数75765
14
即等效于以下两步:
① 执行前两个赋值语句:“a=a∧b;”和“b =b∧a;”相当于b=b∧(a∧b)。 ② 再执行第三个赋值语句: a=a∧b。由于a的 值等于(a∧b),b的值等于(b∧a∧b), 因此,相当于a=a∧b∧b∧a∧b,即a的值等 于a∧a∧b∧b∧b,等于b。 a得到b原来的值。
9
应用:按位或运算常用来对一个数据的某 些位定值为1。例如:如果想使一个数a 的低4位改为1,只需将a与017进行 按位或运算即可。 例: a是一个整数(16位), 有表达式:a | 0377 则低8位全置为1,高8位保留原样。
10
12.1.3“异或”运算符( 12.1.3“异或”运算符(∧)
异或运算符∧也称XOR运算符。它的规则是: 若参加运算的两个二进制位同号则结果为0(假) 异号则结果为1(真)
5
按位与的用途: 按位与的用途: (1) 清零
C语言位运算和sizeof运算符详解
C语言位运算和sizeof运算符详解C语言位运算和sizeof运算符详解C语言中提供了一些运算符可以直接操作整数的位,称为位运算,因此位运算中的操作数都必须是整型的。
位运算的效率是比较高的,而且位运算运用好的话会达到意想不到的效果。
下面,就和店铺一起来看一看C语言位运算和sizeof运算符详解,希望对大家有帮助!位运算和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%xn",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 %dn",a,b);return 0;}不借助临时变量交换两个数据还可以用另外一种方法。
C语言位运算
取指定位 x = x & 0xf0 ; (高4位)
x 1011 1010 & 1111 0000 结果 1011 0000 保留指定位 x 01010100 & 00111011 结果 00010000
2.“按位或” 运算符 ( | )
(2) 用途: 与其它位运算配合使用。 a=a&~1——将最后一位置0
例如:main()
{ unsigned char a,b; a=0x9d; b=0xa5; printf(“~a: %x\n”, ~a); printf(“a&b: %x\n”,a&b); printf(“a | b: %x\n”,a | b); printf(“a^b: %x\n”,a^b);
}
输出结果: ~a: 62 a&b: 85 a | b: bd a^b: 38
5.“左移运算” 运算符 (<< ) (1)规则:
二进制数的各位依次左移,高位移走作废,低位补0
D7 D6 D5 D4 D3 D2 D1 D0
0
(2) 用途:对于一个无符号整数,若左移若干位后不溢 出(<=65535), 则每左移一位相当于原值乘2
x.c);
(1) 规则:两个运算量的相应位之间进行运算,两个
对应位中只要有一个为“1”时,结果就为“1”,
否则结果为“0”
0010 1010
| 1010 0011
(2) 用途:
结果 1010 1011
将数据中某些位置为1
x=x | 0x0f; (低4位置1)
x 1010 0101 | 0000 1111
c语言程序设计位运算(1)
c语言程序设计位运算(1)一、选择题1、读程序片段:int x=20;printf(“%d\n”, ~x);上面程序片段的输出结果是( ).A)02 B)–20 C)-21 D)-112、表达式~0x13的值是( ).A)0xFFEC B)0xFF71 C)0xFF68 D)0xFF173、在位运算中,操作数每右移一位,其结果相当于( ).A)操作数乘以2 B)操作数除以2 C)操作数除以4 D)操作数乘以44、在位运算中,操作数每左移一位,其结果相当于( ).A)操作数乘以2 B)操作数除以2 C)操作数除以4 D)操作数乘以45、设有以下语句:char x=3,y=6,z;z=x^y<<2;则z的二进制值是( ).A)00010100 B)00011011 C)00011100 D)000110006、请读程序:struct bit{unsigned a_bit:2;unsigned b_bit:2;unsigned c_bit:1;unsigned d_bit:1;unsigned e_bit:2;unsigned word:8;};main(){struct bit *p;unsigned int modeword;printf(“Enter the mode word (HEX):”);scanf(“%x”,&modeword);p=(struct bit *)&modewordprintf(“\n”);printf(“a_bit: %d\n”,p ->a_bit);printf(“b_b it: %d\n”,p ->b_bit);printf(“c_bit: %d\n”,p ->c_bit);printf(“d_bit: %d\n”,p ->d_bit);printf(“e_bit: %d\n”,p ->e_bit);}若运行时从键盘输入: 96<回车> 则以上程序的运行结果是( ).A)a_bit: 1 B) a_bit: 2 C)a_bit: 2 D) a_bit: 1b_bit: 2 b_bit: 1 b_bit: 1 b_bit: 2c_bit: 0 c_bit: 0 c_bit: 1 c_bit: 2d_bit: 1 d_bit: 1 d_bit: 0 d_bit: 0e_bit: 2 e_bit: 2 e_bit: 2 e_bit: 17、设有以下说明:struct packed{ unsigned one:1;unsigned two:2;unsigned three:3;unsigned four:4;} data;则以下位段数据的引用中不能得到正确数值的是( ).A) data.one =4 B) data.two=3 C) data.three =2 D) data.four=18、设位段的空间分配由右到左,则以下程序的运行结果是( ).struct packed_bit{unsigned a:2;unsigned b:3;unsigned c:4;int i;} data;main(){data.a=8; data.b=2;printf(“%d\n”,data.a+data.b);}A) 语法错 B) 2 C) 5 D) 10二、填空题1、在C语言中,&运算符作为单目运算符时表示的是【】;作为双目运算符时表示的是【】运算.2、与表达式a&=b 等价的另一书写形式是【】.3、与表达式x^=y-2等价的另一书写形式是【】.4、请读程序片段:int a=1,b=2;if(a&b)printf(“***\n”);else printf(“$$$\n”);以上程序片段的输出结果是【】.5、设有char a,b;若要通过a&b运算屏蔽掉a中的其它位,只保留第2和第8位(右起为第1位),则b的二进制数是【】.6、测试char型变量a第六位是否为1的表达式是【】(设最右位是第一位)7、设二进制数x的值是11001101,若想通过x&y运算使x中的低4位不变,高4位轻零,则y的二进制数是【】.8、请读程序片段:int a=-1;a=a |0377;printf(“%d,%o\n”,a,a);以上程序片段的输出结果是【】.9、设x是一个整数(16bit),若要通过x|y使x低8位置1,高8位不变,则y的八进制数是【】.10、x=10100011,若要通过x^y使x的高4位取反,低4位不变,则y的二进制数是【】。
C语言丨运算符号的三种用法(有示例代码)
C语⾔⼁运算符号的三种⽤法(有⽰例代码)&: 在C语⾔中有两种意思,⼀种是取地址符,是单⽬运算符;另⼀种是位运算符,表⽰“按位与”,是双⽬运算符。
1.⽤于指针赋值#include<stdio.h>int main(){int a = 2;int*b;//定义⼀个整形指针b = &a;//给指针赋值,使指针指向a的地址printf("%d", b);//输出的是a的地址printf("\n");//换⾏符printf("%d", *b);//*的作⽤是解引⽤,取出指针指向地址的内容,达到简return 0;}2.⽤于⼆⽬运算中的按位(位运算)与运算单⽬是只需要⼀个操作数的意思⽐如 a++ a-- *a &a双⽬是需要两个操作数的意思⽐如 a+b a-b a*b a/b a%b三⽬是需要三个操作数的意思⽐如 a=c>b?c:b;例如:9&5可写算式如下: 00001001 (9的⼆进制补码)&00000101 (5的⼆进制补码) 00000001 (1的⼆进制补码)可见9&5=1。
按位与运算通常⽤来对某些位清0或保留某些位。
例如把a 的⾼⼋位清 0 ,保留低⼋位,可作 a&255 运算 ( 255 的⼆进制数为0000000011111111)。
main(){int a=9,b=5,c;c=a&b;printf("a=%d/nb=%d/nc=%d/n",a,b,c);}3.当出现“&&”时⽤于逻辑与说得简单点就是:逻辑与说的通俗⼀点就是:并且~~&&相当于集合⾥⾯的交集——例如:⼥⼈&&男⼈ —— 地球上没⼈是真值PS: || 是 “逻辑或”、“或者”——例如:⼥⼈||男⼈ —— 地球上⼈⼈都满⾜总结1、取地du址操作符。
c语言位运算详解
图11.2 15右移3位得到1
右移1位相当于该数除以2,右移n位相当于该数除以2 n , 因此,将15右移3位,相当于15/2 3 = 1(C语言规定整数相 除商为整数)。
右移时应注意符号问题。对于无符号数,右移时左端补0。 对于有符号数,若符号位为0(该数为正),则右移时左端 补0,同无符号数的处理。若符号位为1(该数为负),则右 移时左端是补0还是补1,取决于所用的计算机系统。有的系 统左端补0,称逻辑右移;左端补1,称算术右移。显然,两 种方式所得的结果是不一样的。Turbo C采用的是算术右移。
scanf (”%u” , & a ) ;
b=a >> 4 ; b=b & 0x000F; printf (” \na=%u b=%u ”, a , b ) ; } 运行情况如下: 115
a=115,b=7
例 2 循环移位。要求将一个无符号数进行左循环移位。如 图11. 4所示。将a左移1位,并将移出位补到右端,输入′e ′结束。
(4)重复以上步骤,直到有键按下。程序如下:
# include <stdio. h> main( ) { unsigned a ; int flag ; scanf (”%u” , & a ) ; while (getchar( ) !=’ e ’ )
{
flag=a & 0x8000 ; a=a<<1 ;
关于位段数据,注意以下几点: (1)一个位段必须存储在同一存储单元(即字)之中,不能跨两 个单元。如果其单元空间不够,则剩余空间不用,从下一个 单元起存放该位段。 (2)可以通过定义长度为0的位段的方式使下一位段从下一存 储单元开始。 (3)可以定义无名位段。 (4)位段的长度不能大于存储单元的长度。
c语言中位操作运算符 -回复
c语言中位操作运算符-回复C语言中的位操作运算符是一组特殊运算符,它们主要用于对二进制位进行操作。
这些运算符允许开发者直接处理和操作变量的二进制表示,从而能够更高效地进行编程和数据处理。
在本文中,我将详细介绍C语言中的位操作运算符,并逐步回答相关问题。
1. 位操作运算符的基本情况在C语言中,位操作运算符共有六个:按位与(&)、按位或()、按位异或(^)、按位取反(~)、左移(<<)和右移(>>)。
下面我们逐个来看。
2. 按位与(&)运算符按位与运算符使用一个“&”符号表示。
它针对两个操作数的每个对应位执行“与”操作。
如果两个操作数的对应位都为1,则结果为1;否则结果为0。
例如,对于两个二进制数字1101和1010,按位与运算的结果将是1000。
3. 按位或()运算符按位或运算符使用一个“”符号表示。
它也针对两个操作数的每个对应位进行运算,但是只要两个数字对应位中的一位为1,结果就为1。
例如,对于两个二进制数字1101和1010,按位或运算的结果将是1111。
4. 按位异或(^)运算符按位异或运算符使用一个“^”符号表示。
它针对两个操作数的每个对应位进行运算,但是只有在两个数字对应位中的值不同时,结果才为1。
例如,对于两个二进制数字1101和1010,按位异或运算的结果将是0111。
5. 按位取反(~)运算符按位取反运算符使用一个“~”符号表示。
它对操作数的二进制位进行取反,并返回结果。
即,对于任何二进制数字,按位取反的结果将是将每个位的值取反。
例如,按位取反运算符应用于二进制数字1101的结果将是0010。
6. 左移(<<)和右移(>>)运算符位移运算符分别使用“<<”和“>>”符号表示。
左移运算符将操作数的二进制位向左移动指定的位数,并在右侧补零。
右移运算符将操作数的二进制位向右移动指定的位数,如果是非负数则在左侧补零,如果是负数则在左侧补一。
C语言位操作运算详解
位运算程序中的所有数在计算机内存中都是以二进制的形式储存的。
位本文会以C语言的交互环境来做代码演示常见的二进制位的变换操作and运算 &•判断奇偶数对于除0以外的任意数x,使用x&1==1作为逻辑判断即可if (x&1==1){}•判断某个二进制位是否为1比如第7位, 0x40转到二进制是0100 0000,代表第7位是1.if (n&0x40){//TODO:添加你要处理的代码}•字节读取(x >> 0) & 0x000000ff /* 获取第0个字节*/(x >> 8) & 0x000000ff /* 获取第1个字节*/(x >> 16) & 0x000000ff /* 获取第2个字节*/(x >> 24) & 0x000000ff /* 获取第3个字节*/•判断一个数是不是 22 的指数bool isPowerOfTwo(int n) {if (n <= 0) return false;return (n & (n - 1)) == 0;}•取余//得到余数int Yu(int num,int n){int i = 1 << n;return num&(i-1);}•指定二进制位数截取比如说16位二进制数A:1001 1001 1001 1000,如果来你想获A 的哪一位的值,就把数字B:0000 0000 0000 0000的那一位设置为1.比如说我想获得A的第三位就把B的第三位数字设置为1,则B为0000 0000 0000 0100,设置完之后再把A、B求与,其结果若为0,说明A的第三位为0,其结果为1,说明A的第三位为1.同理:若要获得A的第五位,就把B设置为0000 0000 0001 0000,之后再求与。
通常在我们的程序中,数字B被称为掩码,其含义是专门用来测试某一位是否为0的数值。
c语言位运算符号
C语言中的位运算符用于对二进制位进行操作。
以下是C语言中常用的位运算符:
1. 位与(&):如果两个操作数的对应位都为1,则结果位为1,否则为0。
例如:a & b
2. 位或(|):如果两个操作数的对应位中至少有一个为1,则结果位为1,否则为0。
例如:a | b
3. 位异或(^):如果两个操作数的对应位不相同,则结果位为1,否则为0。
例如:a ^ b
4. 位取反(~):对操作数的每个位进行取反,即0变为1,1变为0。
例如:~a
5. 左移(<<):将操作数的二进制位向左移动指定的位数,高位补0。
例如:a << n
6. 右移(>>):将操作数的二进制位向右移动指定的位数,低位补0(对于无符号数)或符号位(对于有符号数)。
例如:a >> n
位运算通常用于处理底层的二进制数据,如位编码、标志位的设置与清除等。
需要注意的是,在使用位运算时要注意数据类型的范围和符号的处理,以免出现意外的结果。
c语言中位运算符及其含义
c语言中位运算符及其含义
C语言中的位运算符主要包括以下几种:
1. 按位与(&)运算符:将两个数的二进制各位进行与运算,只有当相应位都为1时结果为1,否则结果为0。
2. 按位或(|)运算符:将两个数的二进制各位进行或运算,只有当相应位都为0时结果为0,否则结果为1。
3. 按位异或(^)运算符:将两个数的二进制各位进行异或运算,只有当相应位不同才为1,相同为0。
4. 按位取反(~)运算符:将一个数的二进制各位全部取反。
5. 左移(<<)运算符:将一个数的二进制值向左移动n位,右边补0,相当于将该数乘以2的n次方。
6. 右移(>>)运算符:将一个数的二进制值向右移动n位,左边补符号位,相当于将该数除以2的n次方并取整。
这些位运算符可以用于程序中的二进制操作,如位掩码、位开关等。
C语言位运算符
位运算在很多系统程序中常要求在位(bit)一级进行运算或处理。
C语言提供了位运算的功能,这使得C语言也能像汇编语言一样用来编写系统程序。
一、位运算符C语言提供了六种位运算符:& 按位与| 按位或^ 按位异或~ 取反<< 左移>> 右移1. 按位与运算按位与运算符"&"是双目运算符。
其功能是参与运算的两数各对应的二进位相与。
只有对应的两个二进位均为1时,结果位才为1 ,否则为0。
参与运算的数以补码方式出现。
例如:9&5可写算式如下:00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。
例如把a 的高八位清0 ,保留低八位,可作a&255 运算( 255 的二进制数为0000000011111111)。
main(){int a=9,b=5,c;c=a&b;printf("a=%d\nb=%d\nc=%d\n",a,b,c);}2. 按位或运算按位或运算符“|”是双目运算符。
其功能是参与运算的两数各对应的二进位相或。
只要对应的二个二进位有一个为1时,结果位就为1。
参与运算的两个数均以补码出现。
例如:9|5可写算式如下:00001001|0000010100001101 (十进制为13)可见9|5=13main(){int a=9,b=5,c;c=a|b;printf("a=%d\nb=%d\nc=%d\n",a,b,c);}3. 按位异或运算按位异或运算符“^”是双目运算符。
其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。
参与运算数仍以补码出现,例如9^5可写成算式如下:00001001^00000101 00001100 (十进制为12)main(){int a=9;a=a^15;printf("a=%d\n",a);}4. 求反运算求反运算符~为单目运算符,具有右结合性。
c语言位运算
C语言位运算详解位运算是指按二进制进行的运算。
在系统软件中,常常需要处理二进制位的问题。
C语言提供了6个位操作运算符。
这些运算符只能用于整型操作数,即只能用于带符号或无符号的char,short,int与long类型。
C语言提供的位运算符列表:运算符含义描述& 按位与如果两个相应的二进制位都为1,则该位的结果值为1,否则为0 | 按位或两个相应的二进制位中只要有一个为1,该位的结果值为1 ^ 按位异或若参加运算的两个二进制位值相同则为0,否则为1 ~ 取反~是一元运算符,用来对一个二进制数按位取反,即将0变1,将1变0 << 左移用来将一个数的各二进制位全部左移N位,右补0 >> 右移将一个数的各二进制位右移N位,移到右端的低位被舍弃,对于无符号数,高位补0 1、“按位与”运算符(&)按位与是指:参加运算的两个数据,按二进制位进行“与”运算。
如果两个相应的二进制位都为1,则该位的结果值为1;否则为0。
这里的1可以理解为逻辑中的true,0可以理解为逻辑中的false。
按位与其实与逻辑上“与”的运算规则一致。
逻辑上的“与”,要求运算数全真,结果才为真。
若,A=true,B=true,则A∩B=true 例如:3&5 3的二进制编码是11(2)。
(为了区分十进制和其他进制,本文规定,凡是非十进制的数据均在数据后面加上括号,括号中注明其进制,二进制则标记为2)内存储存数据的基本单位是字节(Byte),一个字节由8个位(bit)所组成。
位是用以描述电脑数据量的最小单位。
二进制系统中,每个0或1就是一个位。
将11(2)补足成一个字节,则是00000011(2)。
5的二进制编码是101(2),将其补足成一个字节,则是00000101(2)按位与运算:00000011(2) &00000101(2) 00000001(2) 由此可知3&5=1 c语言代码:#include <stdio.h> main() { int a=3; int b = 5; printf("%d",a&b); } 按位与的用途:(1)清零若想对一个存储单元清零,即使其全部二进制位为0,只要找一个二进制数,其中各个位符合一下条件:原来的数中为1的位,新数中相应位为0。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C语言提供了六种位运算符:
& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移
>> 右移
12.1.1按位与运算
按位与运算符"&"是双目运算符。
其功能是参与运算的两数各对应的二进位相与。
只有对应的两个二进位均为1时,结果位才为1,否则为0。
参与运算的数以补码方式出现。
例如:9&5可写算式如下:
00001001 (9的二进制补码)
&00000101 (5的二进制补码)
00000001 (1的二进制补码)
可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。
例如把a 的高八位清0 ,保留低八位,可作a&255运算( 255 的二进制数为0000000011111111)。
【例12.1】
main(){
int a=9,b=5,c;
c=a&b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
12.1.2按位或运算
按位或运算符“|”是双目运算符。
其功能是参与运算的两数各对应的二进位相或。
只要对应的二个二进位有一个为1时,结果位就为1。
参与运算的两个数均以补码出现。
例如:9|5可写算式如下:
00001001
|00000101
00001101 (十进制为13)可见9|5=13
【例12.2】
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
12.1.3按位异或运算
按位异或运算符“^”是双目运算符。
其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。
参与运算数仍以补码出现,例如9^5可写成算式如下:00001001
^00000101
00001100 (十进制为12)
【例12.3】
main(){
int a=9;
a=a^5;
printf("a=%d\n",a);
}
12.1.4求反运算
求反运算符~为单目运算符,具有右结合性。
其功能是对参与运算的数的各二进位按位求反。
例如~9的运算为:
~(0000000000001001)结果为:1111111111110110
12.1.5左移运算
左移运算符“<<”是双目运算符。
其功能把“<< ”左边的运算数的各二进位全部左移若干位,由“<<”右边的数指定移动的位数,高位丢弃,低位补0。
例如:
a<<4
指把a的各二进位向左移动4位。
如a=00000011(十进制3),左移4位后为00110000(十进制48)。
12.1.6右移运算
右移运算符“>>”是双目运算符。
其功能是把“>> ”左边的运算数的各二进位全部右移若干位,“>>”右边的数指定移动的位数。
例如:
设a=15,
a>>2
表示把000001111右移为00000011(十进制3)。
应该说明的是,对于有符号数,在右移时,符号位将随同移动。
当为正数时,最高位补0,而为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定。
Turbo C和很多系统规定为补1。
【例12.4】
main(){
unsigned a,b;
printf("input a number: ");
scanf("%d",&a);
b=a>>5;
b=b&15;
printf("a=%d\tb=%d\n",a,b);
}
请再看一例!
【例12.5】
main(){
char a='a',b='b';
int p,c,d;
p=a;
p=(p<<8)|b;
d=p&0xff;
c=(p&0xff00)>>8;
printf("a=%d\nb=%d\nc=%d\nd=%d\n",a,b,c,d); }。