现在的位置: 首页 > 综合 > 正文

c++中按位取反运算

2013年12月13日 ⁄ 综合 ⁄ 共 2271字 ⁄ 字号 评论关闭
#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;

	//无符号字符扩充为无符号和有符号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;

}

抱歉!评论已关闭.