c++中按位取反运算,类型转换,扩位

来源:互联网 发布:我跟肌肉男的夜晚知乎 编辑:程序博客网 时间:2024/06/16 06:24

#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;

}

 

转自:http://blog.csdn.net/gukesdo/article/details/6998260

0 0
原创粉丝点击