#include <stdio.h>
#include <iostream>
using namespace std;
void main()
{
//做这类题目抓住两点:第一、无论是以进制表示还是整数形式赋值给变量,都要根据变量相应
//的数据类型,表示为补码的形式存储进计算机内存中;第二、无论是在做数据类型强制转换(
//内存存储形式没有改变,这一点可以通过查看Memory得到)还是做位运算的时候,实际上都是对
//内存中存储的数进行的操作(也可以查看Memory得到),至于呈现的时候就是根据设定的数据类
//型把内存中存储的二进制数字进行相应规则的呈现即可
//cout << sizeof(long long) << endl;
//注意,计算机存储的都是数的补码,无论是正数还是负数,另外要注意数据类型的长度
short int a = 0x8000;//有符号数则表示-32768(计算机就存这个数,它是补码,要算实际代表的数要运算)
short int b = 0x7000;//有符号数表示28672
unsigned short int c = 0x8000;//无符号数则表示32768,是正数
short int d = c;
unsigned short int e = a;
cout << a << endl;//应输出-32768,因为是有符号数
cout << b << endl;//应输出28762,应为是正数
cout << c << endl;//应输出32768,因为是无符号数
cout << d << endl;//应输出-32768,因为强制转换成了有符号数
cout << e << endl;//应输出32768,因为强制转换成了无符号数
//感觉强制转换的时候在内存存储形式并没有任何改变,只是呈现的形式改变而已,按照需要的数据类型格式进行呈现
//任何的位操作都是对内存中存储的数进行的操作。
short int pre = -3; //在内存中的表示为1111 1111 1111 1101是它的补码形式,即0xfffd
unsigned short int trans = pre; //0xfffd无符号数应表示的是65533,注意内存内形式不变
short int m = ~pre; //直接操作的是内存中存储的形式,按位取反后是0000 0000 0000 0010,即0x0002
unsigned short int n = ~pre; //实际上之后的形式还是0x0002
cout << pre << endl;
cout << trans << endl;
cout << m << endl;
cout << n << endl;
cout << "/*********************************************************************************/" << endl;
unsigned char ch = 'F';
//其实下面一行代码做了三步操作
//第一、首先把ch按位取反,之后在内存中的形式变为1011 1001
//第二、把内存中的这个值先进行扩位,扩充成short类型的,扩位的时候是看做有符号数进行的,
//扩位之后为1111 1111 1011 1001,即:0xffb9
//第三、把0xffb9按照无符号数规则进行呈现
unsigned short int p = ~ch;
unsigned short int q = (unsigned)~ch;
cout << ch << endl;
cout << p << endl;
cout << q << endl;
cout << "/**************************************************************************/" << endl;
unsigned short int p1;
short int p2;
//有符号字符扩充为无符号和有符号short int
char ch1 = 'F';
p1 = ~ch1;
p2 = ~ch1;
cout << p1 << endl;
cout << p2 << endl;
输出结果:
扩充时均是按有符号补1,输出时则按相应的无符号或有符号输出,注意:是补码形式,若是负数如p2,则符号位不变,补码-1再取反得原码,计算其值。
F
65465
65465
/**************************************************************************/
65465
-71 //则符号位不变,补码-1再取反得原码,计算其值
Press any key to continue
//无符号字符扩充为无符号和有符号short int
unsigned char ch2 = 'F';
p1 = ~ch2;
p2 = ~ch2;
cout << p1 << endl;
cout << p2 << endl;
/******测试有符号数和无符号数的强制转换和扩位******/
cout << "/**************************************************************************/" << endl;
int nn = 0;
unsigned int nn1 = 0;
//无符号数(正)扩充为有符号数和无符号数
unsigned short int mm1 = 0x7000; //28672
nn = ~mm1;
nn1 = ~mm1;
cout << nn << endl;
cout << nn1 << endl;
short int aaa = 0x8000;
long long bbb = ~aaa;
//无符号数(负)扩充为有符号数和无符号数
unsigned short int mm3 = 0x8000; //32768
nn = mm3;
nn1 = mm3;
cout << nn << endl;
cout << nn1 << endl;
//有符号数(正)扩充为有符号数和无符号数
short int mm2 = 0x7000; //+28672
nn = mm2;
nn1 = mm2;
cout << nn << endl;
cout << nn1 << endl;
//有符号数(负)扩充为有符号数和无符号数
short int mm4 = 0x8000; //-32768
nn = mm4;
nn1 = mm4;
cout << nn << endl;
cout << nn1 << endl;
}