C语言位操作(转)】的更多相关文章

c语言位操作中需要注意有: 位操作只针对整型和字符型数据 在右移操作中:对无符号数和有符号中的正数补 0:符号数中的负数,取决于所使用的系统:补 0 的称为“逻辑右移”,补 1 的称为“算术右移”. 循环移位的概念: 循环移位就是把从左边移出去的,补到右边去,或者从右边移出去的补到左边去,例如1000 0001循环右移以为得到:1100 0000,循环左移一位得到0000 0011 掩码的概念: 掩码就是掩盖住你不想让它出现的部分,例如在网络中的子网掩码,就是将网络中的子网内部IP划分屏蔽掉,例…
位操作允许程序员对单独的位进行操作,例如,早某些机器上,短整型占16位,位操作将每一位单独操作. 位操作允许程序员设置.清除.测试与其他的操作,这些操作如下表: 操作 含义 & 按位与 | 按位或 ^ 按位异或 ~ 取反 << 左移 >> 右移 这些操作用于整型或者字符型 1.按位与(&) Bit1 Bit2 Bit1 & Bit2 0 0 0 0 1 0 1 0 0 1 1 1 通常我们可把按位"与"操作 & 作为关闭某位(即将…
计算机中的所有数据均是以二进制形式存储和处理的.所谓位操作就是直接把计算机中的二进制数进行操作,无须进行数据形式的转换,故处理速度较快. 1.原码.反码和补码 位(bit) 是计算机中处理数据的最小单位,其取值只能是 0 或 1. 字节(Byte) 是计算机处理数据的基本单位,通常系统中一个字节为 8 位.即:1 Byte=8 bit. 为便于演示,本节表示的原码.反码及补码均默认为 8 位. 准确地说,数据在计算机中是以其补码形式存储和运算的.在介绍补码之前,先了解原码和反码的概念. 正数的原…
下面分享关于位操作的一些笔记: 一.位操作简单介绍 首先,以下是按位运算符: 在嵌入式编程中,常常需要对一些寄存器进行配置,有的情况下需要改变一个字节中的某一位或者几位,但是又不想改变其它位原有的值,这时就可以使用按位运算符进行操作.下面进行举例说明,假如有一个8位的TEST寄存器: 当我们要设置第0位bit0的值为1时,可能会这样进行设置: TEST = 0x01; 但是,这样设置是不够准确的,因为这时候已经同时操作到了高7位:bit1~bit7,如果这高7位没有用到的话,这么设置没有什么影响…
1.头文件 #ifndef _INC_BITOPERATION #define _INC_BITOPERATION #endif /* 封装了所有的位操作运算 */ #include<stdio.h> #include<stdlib.h> /************************四字节操作,如int ,long等类型**********************/ /*置位int数num的第N个位*/ void setInt(int *num, int N); /*清零in…
http://www.cnblogs.com/cpoint/category/524132.html  …
#include <stdio.h> void print(int); int main(void) { int flag = 0xffe4; print(flag); printf("\n"); flag &= 0xff; //掩码 print(flag); printf("\n"); flag |= 0x07; //打开位,将对应位置1,而其余位不变 print(flag); printf("\n"); flag &…
假设读者熟悉普通代数与布尔代数,下面是部分常见的涉及到加法.减法与逻辑运算符的组合: a.        -x=~x+1 b.           =~(x-1) c.        ~x=-x-1 d.        -~x=x+1 e.        ~-x=x-1 f.         x+y=x-~y-1 g.             =(x^y)+2(x&y) h.             =(x|y)+(x&y) i.              =2(x|y)-(x^y) j.…
信息是以比特流的方式传输的,类似01000001.在传输过程中,有可能会发生错误,比如,我们存储了01000001,但是取出来却是01000000,即低位由0变成了1.为了检测到这种错误,我们可以通过“奇偶校验”来实现.假如,我们存储的数据是一个字节,8个比特位,那我们就可以计算每个字节比特位是1的个数,如果是偶数个1,那么,我们就把第九个位设为1,如果是奇数个1,那么就把第九个位设为0,这样连续9个字节比特位为1的位数肯定是奇数.这中方法叫做“奇校验”,“偶校验”和此类似.当然,在实际应用中,…
1.使用加法与减法交换两数值: #define SWAP(a, b) ((&(a) == &(b)) || \ (((a) -= (b)), ((b) += (a)), ((a) = (b) - (a)))) 这种交换数值a与b的方法没有使用临时变量,初始化检测a,b,如果在同一内存区,则被忽略,当然这通常不会发生,(编译器会忽略,然而无论如何都是一种优化),假如可以确 定溢出异常,于是传递无符号数异常就不会抛出. 下面的逻辑“或”运算的方法在某些机器上可能要快一些,不要使用浮点型数字.…