位运算

1).定义.

指的是1个二进制数据的每一位来参与运算.

位运算的前提: 是这个数必须是1个二进制.

注意:

a). 参与位运算的二进制数据必须是补码形式.

b). 位运算的结果也是二进制的补码形式.

2).按位与: &

参与按位与的两个二进制数.如果都为1 那么结果就为1 只要有1位为0 那么结果就为0.

3 & 2;

第1步骤:先得到两个数的二进制补码形式.

3的补码: 00000000 00000000 00000000 00000011

2的补码: 00000000 00000000 00000000 00000010

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

00000000 00000000 00000000 00000010   2

-3 & 4;

-3的原码:10000000 00000000 00000000 00000011

-3的反码:11111111 11111111 11111111 11111100

-3的补码:11111111 11111111 11111111 11111101

4的补码: 00000000 00000000 00000000 00000100

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

00000000 00000000 00000000 00000100

-3 & -4;

-4的原码: 10000000 00000000 00000000 00000100

-4的反码: 11111111 11111111 11111111 11111011

-3的补码:11111111 11111111 11111111 11111101

-4的补码:11111111 11111111 11111111 11111100

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

11111111 11111111 11111111 11111100

结果是补码: 现将其还原为反码

反码:      11111111 11111111 11111111 11111011

原码:      10000000 00000000 00000000 00000100

注意:

任何数按位与1的结果是:是这个数的最低位.

10 & 1

xxxxxxxx xxxxxxxx xxxxxxxx xxxxxxx0

00000000 00000000 00000000 00000001

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

00000000 00000000 00000000 00000000

偶数的最低位一定是0. 奇数的最低为一定是1

所以,如果要判断这个数是奇数还是偶数 只要用这个数按位与1就可以了.

如果结果为1 那么就是奇数 如果结果为0 那么结果就是偶数.

int num = 10;

if((num & 1) == 0)

{

偶数.

}

else

{

奇数.

}

3). 按位或. |

参与按位或的二进制数据 只要有1位是1 那么结果就为1  只有当两位都是0的时候结果才为0

3 | 2;

3的补码: 00000000 00000000 00000000 00000011

2的补码: 00000000 00000000 00000000 00000010

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

00000000 00000000 00000000 00000011

-3 | 4

-3的补码:11111111 11111111 11111111 11111101

4的补码: 00000000 00000000 00000000 00000100

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

11111111 11111111 11111111 11111101

结果是1个负数.

反码: 11111111 11111111 11111111 11111100

原码: 10000000 00000000 00000000 00000011

-3 | -4

-3的补码:11111111 11111111 11111111 11111101

-4的补码:11111111 11111111 11111111 11111100

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

11111111 11111111 11111111 11111101

4). 按位取反: ~

单目运算符. 将这个二进制数的每一位取反.

~3;

3的补码: 00000000 00000000 00000000 00000011

11111111 11111111 11111111 11111100 补码

11111111 11111111 11111111 11111011 反码

10000000 00000000 00000000 00000100 原码

5). 按位异或: ^

参与按位异或的二进制数据的位 如果相同则为0 不同为1.

3 ^ 2;

00000000 00000000 00000000 00000011   3的补码

00000000 00000000 00000000 00000010   2的补码

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

00000000 00000000 00000000 00000001   1

交换两个变量的值可以用异或运算.

int a = 3;

int b = 2;

a = a ^ b;  a = 1

b = a ^ b;  b = 3

a = a ^ b;  b = 2

1 ^ 2

00000000 00000000 00000000 00000001

00000000 00000000 00000000 00000010

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

00000000 00000000 00000000 00000011                      3

00000000 00000000 00000000 00000001

00000000 00000000 00000000 00000011

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

00000000 00000000 00000000 00000010                      2

6). 按位左移运算. <<

参与按位左移运算的二进制数据. 向左移动指定的位数. 低位不够补0 高位溢出就丢弃.

3 << 2;

00000000 00000000 00000000 00000011

000000 00000000 00000000 0000001100

12

注意:

a). 左移运算有可能会改变其正负性.

b). 将1个数左移n位,相当于将这个数 乘以 2的n次方.

3 << 2    3乘以2的2次方.

16 << 3;   16 * 8  128

5 * 16 = ????

5 << 4

7). 按位右移. >>

参与按位右移的二进制数据.向右移动指定的位数. 低位溢出丢弃,高位补符号位.

3 >> 2;

00000000 00000000 00000000 00000011

0000000000 00000000 00000000 000000

16 >> 2;

00000000 00000000 00000000 00010000

00000000 00000000 00000000 000100

-16 >> 3

10000000 00000000 00000000 00010000

11111111 11111111 11111111 11101111

11111111 11111111 11111111 11110000

11111111111 11111111 11111111 11110

11111111111 11111111 11111111 11101 反码

10000000000 00000000 00000000 00010

注意.

a). 右移运算不会改变正负性.

b). 1个数按位右移n位.相当于这个数除以2的n次方.

100 >> 2  相当于 100 / 4

C语言之位运算的更多相关文章

  1. 【C语言】位运算

    编写一个函数getbits,从一个16位的单元中取出某几位(即该几位保留原值,其余位0).函数调用形式为getbits(value,n1,2).----简单题目遇到想不到的问题 c语言位运算经典问题: ...

  2. C语言:位运算

    所谓位运算,就是对一个比特(Bit)位进行操作.在<数据在内存中的存储>一节中讲到,比特(Bit)是一个电子元器件,8个比特构成一个字节(Byte),它已经是粒度最小的可操作单元了.C语言 ...

  3. C语言的位运算

    位运算加速技巧1. 如果乘上一个2的倍数数值,可以改用左移运算(Left Shift) 加速 300% x = x * 2;x = x * 64;//改为:x = x << 1; // 2 ...

  4. C语言的位运算的优势

    位运算加速技巧1. 如果乘上一个2的倍数数值,可以改用左移运算(Left Shift) 加速 300% x = x * 2;x = x * 64;//改为:x = x << 1; // 2 ...

  5. 关于c语言的位运算&,|,^(看懂汉字的都能看懂)

    其中|,&可以当作逻辑运算符,当|,&当成逻辑运算符时,与||,&&的用法基本相似,&&,||运算时会当前面的表达式能够决定整个表达式,则不进行对后面的 ...

  6. C语言的位运算的优势 !

    位运算加速技巧1. 如果乘上一个2的倍数数值,可以改用左移运算(Left Shift) 加速 300% x = x * 2; x = x * 64; //改为: x = x << 1; / ...

  7. 零基础逆向工程15_C语言09_位运算

    1.汇编中的移位指令 算数移位指令 指令格式:SAL/SAR Reg/Mem, CL/Imm SAL(Shift Arithmetic Left):算数左移 SAR(Shift Arithmetic ...

  8. C语言中位运算异或“∧”的作用

    1.概念异或运算符"∧"也称XOR运算符.它的规则是若参加运算的两个二进位同号,则结果为0(假):异号则为1(真).即 0∧0=0,0∧1=1, 1^0=1,1∧1=0.运算    ...

  9. C语言:位运算加密

    数据加密解密是一个常用的功能,如果你不希望让别人看到文件中的内容,可以通过密钥(也称"密码")将文件的内容加密.比如文本文件(.txt),加密前的内容是能够读懂的,加密后的内容是& ...

随机推荐

  1. 快速构建Windows 8风格应用16-SettingContract原理及构建

    原文:快速构建Windows 8风格应用16-SettingContract原理及构建 本篇博文主要介绍Setting Contract概述.Setting Contract实现基本原理.如何构建Se ...

  2. SQLServer中处理每天四亿三千万记录

    我是如何在SQLServer中处理每天四亿三千万记录的   首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文中有不对的地 ...

  3. OpenSUSE 13.2安装Texlive2014+Texmaker+Lyx

    (1)首先下载安装Texlive2014 地址:http://mirrors.ustc.edu.cn/CTAN/systems/texlive/Images/ 或直接下载: wget http://m ...

  4. leetcode第14题--Longest Common Prefix

    Problems:Write a function to find the longest common prefix string amongst an array of strings. 就是返回 ...

  5. Mac OSX操作系统安装和配置Zend Server 6教程(4)

    在前三节中,完成了安装和配置,最后是登录后台,并设置权限.Zend server后台登录默认端口是10081.浏览器中的的地址应输入http://localhost:10081/ZendServer. ...

  6. Python装饰器学习

    Python装饰器学习(九步入门)   这是在Python学习小组上介绍的内容,现学现卖.多练习是好的学习方式. 第一步:最简单的函数,准备附加额外功能 ? 1 2 3 4 5 6 7 8 # -*- ...

  7. CentOS 5.8安装SugarCRM 6.5版本

    环境:CentOS 5.8,安装了Asterisk 1.8 升级php到5.2SugarCRM 6.5:  Minimum PHP version required is 5.2.0. You are ...

  8. ps入门教程:裁剪工具、修复画笔工具、图章工具的使用

    本节课程主要内容:学习裁剪工具.污点修复画笔工具.修复画笔工具.修补工具.套索工具.红眼工具.仿制图章工具和图案图 章工具的应用.----------------------------------- ...

  9. DDD(领域驱动设计)应对具体业务场景,如何聚焦 Domain Model(领域模型)?

    DDD(领域驱动设计)应对具体业务场景,如何聚焦 Domain Model(领域模型)? 阅读目录: 问题根源是什么? <领域驱动设计-软件核心复杂性应对之道>分层概念 Repositor ...

  10. 验证编辑方法(Edit method)和编辑视图(Edit view)

    ASP.NET MVC 5 - 验证编辑方法(Edit method)和编辑视图(Edit view) 在本节中,您将验证电影控制器生成的编辑方法(Edit action methods)和视图.但是 ...