习题2.4,P11.
// ------
16位unsigned short : 最大是65535 ( 即2^16-1)
unsigned short z;
int x = 100 000 用十六进制表示是 : 0X186A0, 它的低十六位是 86A0 ,对应十进制的34464
z赋值100 000 就会越界,编译器 截取 100 000 的二进制的低16位86A0赋予x,把高位0X10000 扔掉
两种解释:
(1)相当于是 用100 000 对65536取模,即余下部分 : 100 000 - 65536 = 34464
(2) 好比是只有16个空格, 把100 000 的二进制往空格填,从右边的低位开始,依次向左填入,填满了16格,多余的就扔掉.
因为扔掉的是高位(按十进制看,数比低位的大),扔掉的是 0X10000 = 65536,也就是把超过65535的部分扔掉.
(因为0XFFFF = 65535, 所以: 0XFFFF + 1 = 0X10000 ---- > 0X10000 = 65535+1 = 65536 )
#include <iostream>
using namespace std;
void main()
{
int x = 100000;
cout.setf(ios::hex,ios::basefield);//设置十六进制显示数值
cout.setf(ios::showbase|ios::uppercase);//设置0x头和大写
cout<<"十六进制x = "<<x<<endl;
unsigned short z; // 该类型最大是65535
z = x; // 100000 > 65535 越界
cout<<"十六进制z = : "<<z<<endl;
cout.setf(ios::dec,ios::basefield); //改回来,用十进制显示
cout<<"十进制z = "<<z<<endl;
}

本文探讨了当给16位无符号short类型变量赋值超过其最大值65535时,如何理解赋值过程。通过十六进制表示,解释了编译器会截取数值的低16位,而丢弃高位,从而导致实际赋值为34464,并提供了两种不同的解释来理解这个过程。
1390

被折叠的 条评论
为什么被折叠?



