C语言的位移运算

C语言提供了基于bit 的位移运算,写了个小程序测试一下位移运算的准确性

#include "stdafx.h"


int _tmain(int argc, _TCHAR* argv[])
{
int aa = 1234;
printf("sizeof(int):%d\n", sizeof(aa));//sizeof(int):4
printf("hex:%0x\n", aa);//4d2
printf("aa address:%p\n", &aa);//
printf("aa<<1 hex:%0x\n", aa << 1);//aa<<1 hex:94a
printf("aa<<1 dec:%d\n", aa << 1);//aa<<1 dec:2468


unsigned char data[4] = { 0 };
memcpy(data, &aa, 4);//拷贝&aa的十六进制位存储在data数组中
int bb = (data[3]<<24 & 0xff000000)| (data[2]<<16 & 0x00ff0000)| (data[1]<<8 & 0x0000ff00) | (data[0] & 0x000000ff);//移位 与 或操作
printf("data:%0x\n",bb);//data:4d2
return 0;
}


C语言中,寄存器位移运算是通过位操作符来实现的。位操作符在操作寄存器时具有特殊作用。寄存器是按位进行规划和使用的,读写时是以32位整体进行操作的。在操作寄存器时,可以改变某一特定位,而不影响其他位。例如,可以通过位与操作符"&"来改变寄存器中的某些位。 举个例子,假设有两个无符号整数变量a和b,分别为0xa12aaaa7和0xFFFF00FF。要将a和b的对应位进行位与运算,可以使用位与操作符"&",并将结果赋值给另一个变量c。具体代码如下: unsigned int a = 0xa12aaaa7; unsigned int b = 0xFFFF00FF; unsigned int c; c = a & b; 上述代码将a和b进行位与运算,并将结果保存在变量c中。可以使用打印语句输出c的值。 printf("a & b = %#X.\n", c); printf("a & b = 0x%x.\n", c) 这样就可以打印出c的值。在这个例子中,位与运算会将a和b的对应位进行逐位比较,只有在对应位都为1时,结果位才为1,否则为0。 除了寄存器位移运算,还可以使用位移操作符来构建特殊的二进制数。通过位移操作符可以获取特定位为1或0的二进制数。例如,可以使用位移操作符来获取bit3-bit7为1,同时bit23-bit25为1,其余位都为0的数,代码如下: unsigned int num = (0x1F << 3) | (0x7 << 23); 这样就可以得到一个特殊的二进制数。通过位移操作符和按位或操作符,可以灵活地构建需要的二进制数。 总结起来,寄存器位移运算是通过位操作符来实现的。位操作符可以用来改变寄存器中的某一特定位,同时可以用来构建特殊的二进制数。在C语言中,位操作符有不同的作用,可以对位进行逐个取反,也可以进行逻辑运算。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C语言对寄存器的位操作](https://blog.csdn.net/qixjocd12345/article/details/108304967)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [逻辑运算之寄存器移位运算](https://blog.csdn.net/weixin_38066782/article/details/129373220)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值