字节、字长、移位,补码,有符号数与无符号数

字节是最小的内存寻址单元,一个字节是由8位二进制数组成的,而二进制数是内存的最小单元。

字长是内存单元的地址的位数,每个字长指向一个字节,也就是C++指针中存放的字节个数。比如32位字长的机器,虚拟地址范围就是0~2^32-1,(虚拟地址对应的是虚拟内存,虚拟内存就是一个抽象的概念,其对应的物理内存空间可能在主存,闪存,磁盘上,但是从虚拟内存的角度,都被整合成一块连续的内存,在底层操作时会通过映射的方法映射到具体的物理内存当中。每个进程都有4G的虚拟内存,但是对应到物理内存并不是真的有4G大小的)

移位注意区分算术移位和逻辑移位,通过下图可以辨别出两种移位的区别:

 C++中负数是由补码表示的,补码的生成规则是:正数的补码就是其本身;负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1,即在反码的基础上+1。

至于为什么补码是这样的计算方式,可以参考这篇文章:https://blog.csdn.net/jiange_zh/article/details/47381115

在C++中有符号数和无符号数之间的强制转换就是不改变每一位二级制的值,只是计算方式不一样,有符号数是按补码计算,无符号数是按原码来计算的。按这种计算方式,非负数的转换值不变,但是负数转换值大概率不是自己想要的了。

int main(void)
{
	int x = -149;
	unsigned int y = (unsigned int)x;//强制转换成无符号数
	cout << y << endl;//结果是4294967147
	system("pause");
	return 0;
}//在有符号数的情况下,-149的二进制表示是1111 1111 1111 1111 1111 1111 0110 1011
//无符号数4294967147的二进制表示也是上面这个

注意:C++中三种情况下都可能发生这种转换

/*显示转换*/
int a=10;
unsigned int b;
b=(unsigned int)a;
/*隐式转换1*/
int a=10;
unsigned int b;
b=a;
/*隐式转换2*/
int a=10;
unsigned int b;
b+a;//如果运算中有无符号数和有符号数,那么会自动转换为无符号数进行运算

 注意在比较运算时,如下的例子需要注意(其中打*的是特别需要注意的,另外-2147483647-1的无符号数是2147483648)

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值