大家好,又见面了,我是你们的朋友全栈君。
1;位运算; 程序中的所有数在计算机内存中都是以二进制的形式储存的。位运算说穿了,就是直接对整数在内存中的二进制位进行操作。(均以二进制的补码形式) 整数;及只能是带符号或者无符号的char,short,int,long类型;
2;c语言中的6种位运算符; & 按位与——如果两个相应的二进制位都为1,则该位的结果值为1,否则为0; | 按位或——两个相应的二进制位中只要有一个为1,该位的结果值为1; ^ 按位异或—— 若参加运算的两个二进制位值相同则为0,否则为1; ~ 取反 ——~是一元运算符,用来对一个二进制数按位取反,即将0变1,将1变0; << 左移 用来将一个数的各二进制位全部左移N位,右补0; ;>> 右移 将一个数的各二进制位右移N位,移到右端的低位被舍弃,对于无符号数,高位补0;
3;运算符的应用; 3.1;按位与&; 3.1.1;清零;列如101010;清零就是与1000000进行&;即可; 3.1.2;保留指定位;及与一个指定位为1其余都为0的&即可; 3.2;按位或|; 3.3;按位异或^; 3.3.1;交换两个值,不用临时变量;
代码语言:javascript复制 a=a∧b;
b=b∧a;
a=a∧b;
a=011(2)
(∧)b=100(2)
a=111(2)(a∧b的结果,a已变成7)
(∧)b=100(2)
b=011(2)(b∧a的结果,b已变成3)
(∧)a=111(2)
a=100(2)(a∧b的结果,a已变成4)
//及实现了交换;
3.4;按位取反~;他是一元运算符,用于求整数的二进制反码,即分别将操作数各二进制位上的1变为0,0变为1。
3.5;左移与右移; 左移<<是乘;但此结论只适用于该数左移时被溢出舍弃的高位中不包含1的情况。 右移>>是除; 8<<2 ——8乘以2的二次方;则等于32; 8>>2——8除以2的二次方;则等于2;
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。