一、传统的C方式位操作:
1.基本操作:
使用一个unsigned int变量来作为位容器。
2.操作符:
| 按位或操作符:result=exp1|exp2;当exp1和exp2中对应位中至少有一个为1时,result中对应位为1,否则为0。
& 按位与操作符::result=exp1&exp2;当exp1和exp2中对应位全为1时,result中对应位为1,否则为0。
^ 按位异或或操作符:result=exp1^exp2;当exp1和exp2中对应位不相同时,result中对应位为1,否则为0。
~ 反转操作符:将位容器中的所有位都反转,1变为0,0变为1。
<< 按位左移操作符:exp<<n,将容器中所有的位向左移n位,空出的位用0填充。
>> 按位右移操作符:exp>>n,将容器中所有的位向右移n位,空出的位用0填充。
|=,&=,^= 分别对应|&^三种操作符的复合操作符。
3.常用操作
这里我们假设有一个result的unsigned int变量用来储存32个学生的成绩(通过和不通过分别用0和1),这样result就有33位(result从右至左,从0开始计算位数,在这个例子中0位被浪费)。
(a) 将第27位设置为及格(设作1)其他位不变:
result|=(1<<27) //任意的位值与1作按位或操作其值为1,而与0作按位与操作其值不变
(b) 将第27位设置成不及格(设为0)。
result&=~(1<<27) //任意的位值与0作按位与操作其值为0,而与1作按位与操作其值不变
(c) 反转第27位的值。
result^=(1<<27) //任意的位值与1作按位异或操作其值为1,而与0作按位异或操作其值不变
二、
把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列。
实现了unsigned long型的转换。
char* int_to_bin(unsigned long data)
{
int bit_num = sizeof(unsigned long)*8;
char* p_bin = new char[bit_num+1];
p_bin[bit_num] = '\0';
for (int i = 0; i < bit_num; i++)
{
p_bin[i] = data<<i>>(bit_num-1); //先左移i位,然后右移bit_num-1位。
if (p_bin[i] == 0)
p_bin[i] = '0';
else if (p_bin[i] == 1)
p_bin[i] = '1';
else
p_bin[i] = 'a';
}
return p_bin;
}
char* int_to_hex(unsigned long data)
{
int bit_num = sizeof(unsigned long)*8;
char* p_hex = new char[bit_num/4+3];
p_hex[0]='0';
p_hex[1]='x';
p_hex[bit_num/4+2] = '\0';
char* p_tmp = p_hex+2;
for (int i = 0; i < bit_num/4; i++)
{
p_tmp[i] = data<<(4*i)>>(bit_num-4);
if (p_tmp[i] >= 0 && p_tmp[i] <= 9)
{
p_tmp[i] += '0';
}
else if (p_tmp[i] >= 10 && p_tmp[i] <= 15)
{
p_tmp[i] = p_tmp[i]-10+'A';
}
// else
// p_tmp[i] = '0';
}
return p_hex;
}