位操作符

一、传统的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;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值