c++中按位取反_取反和按位取反

c++中按位取反_取反和按位取反#include<stdio.h>#include<iostream>usingnamespacestd;voidmain(){//做这类题目抓住两点:第一、无论是以进制表示还是整数形式赋值给变量,都要根据变量相应//的数据类型,表示为…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 

  1. #include <stdio.h>  
  2. #include <iostream>  
  3.   
  4. using namespace std;  
  5.   
  6. void main()  
  7. {  
  8.       
  9.     //做这类题目抓住两点:第一、无论是以进制表示还是整数形式赋值给变量,都要根据变量相应  
  10.     //的数据类型,表示为补码的形式存储进计算机内存中;第二、无论是在做数据类型强制转换(  
  11.     //内存存储形式没有改变,这一点可以通过查看Memory得到)还是做位运算的时候,实际上都是对  
  12.     //内存中存储的数进行的操作(也可以查看Memory得到),至于呈现的时候就是根据设定的数据类  
  13.     //型把内存中存储的二进制数字进行相应规则的呈现即可  
  14.   
  15.     //cout << sizeof(long long) << endl;  
  16.   
  17.     //注意,计算机存储的都是数的补码,无论是正数还是负数,另外要注意数据类型的长度  
  18.     short int a = 0x8000;//有符号数则表示-32768(计算机就存这个数,它是补码,要算实际代表的数要运算)  
  19.     short int b = 0x7000;//有符号数表示28672  
  20.     unsigned short int c = 0x8000;//无符号数则表示32768,是正数  
  21.   
  22.     short int d = c;  
  23.     unsigned short int e = a;  
  24.   
  25.     cout << a << endl;//应输出-32768,因为是有符号数  
  26.     cout << b << endl;//应输出28762,应为是正数  
  27.     cout << c << endl;//应输出32768,因为是无符号数  
  28.     cout << d << endl;//应输出-32768,因为强制转换成了有符号数  
  29.     cout << e << endl;//应输出32768,因为强制转换成了无符号数  
  30.     //感觉强制转换的时候在内存存储形式并没有任何改变,只是呈现的形式改变而已,按照需要的数据类型格式进行呈现  
  31.     //任何的位操作都是对内存中存储的数进行的操作。  
  32.   
  33.     short int pre = -3;                 //在内存中的表示为1111 1111 1111 1101是它的补码形式,即0xfffd  
  34.     unsigned short int trans = pre;     //0xfffd无符号数应表示的是65533,注意内存内形式不变  
  35.     short int m = ~pre;                 //直接操作的是内存中存储的形式,按位取反后是0000 0000 0000 0010,即0x0002  
  36.     unsigned short int n = ~pre;        //实际上之后的形式还是0x0002  
  37.   
  38.     cout << pre << endl;  
  39.     cout << trans << endl;  
  40.     cout << m << endl;  
  41.     cout << n << endl;  
  42.   
  43.     cout << “/*********************************************************************************/” << endl;  
  44.     unsigned char ch = ‘F’;  
  45.     //其实下面一行代码做了三步操作  
  46.     //第一、首先把ch按位取反,之后在内存中的形式变为1011 1001  
  47.     //第二、把内存中的这个值先进行扩位,扩充成short类型的,扩位的时候是看做有符号数进行的,  
  48.     //扩位之后为1111 1111 1011 1001,即:0xffb9  
  49.     //第三、把0xffb9按照无符号数规则进行呈现  
  50.     unsigned short int p = ~ch;  
  51.     unsigned short int q = (unsigned)~ch;  
  52.   
  53.     cout << ch << endl;  
  54.     cout << p << endl;  
  55.     cout << q << endl;  
  56.   
  57.     cout << “/**************************************************************************/” << endl;  
  58.     unsigned short int p1;  
  59.     short int p2;  
  60.       
  61.     //有符号字符扩充为无符号和有符号short int  
  62.     char ch1 = ‘F’;  
  63.     p1 = ~ch1;  
  64.     p2 = ~ch1;  
  65.     cout << p1 << endl;  
  66.     cout << p2 << endl;  
  67.   
  68.     //无符号字符扩充为无符号和有符号short int  
  69.     unsigned char ch2 = ‘F’;  
  70.     p1 = ~ch2;  
  71.     p2 = ~ch2;  
  72.     cout << p1 << endl;  
  73.     cout << p2 << endl;  
  74.   
  75.   
  76.     /******测试有符号数和无符号数的强制转换和扩位******/  
  77.     cout << “/**************************************************************************/” << endl;  
  78.     int nn = 0;  
  79.     unsigned int nn1 = 0;  
  80.   
  81.     //无符号数(正)扩充为有符号数和无符号数  
  82.     unsigned short int mm1 = 0x7000;  //28672  
  83.     nn = ~mm1;  
  84.     nn1 = ~mm1;  
  85.   
  86.     cout << nn << endl;   
  87.     cout << nn1 << endl;   
  88.   
  89.     short int aaa = 0x8000;  
  90.     long long bbb = ~aaa;  
  91.   
  92.     //无符号数(负)扩充为有符号数和无符号数  
  93.     unsigned short int mm3 = 0x8000;   //32768  
  94.     nn = mm3;  
  95.     nn1 = mm3;  
  96.   
  97.     cout << nn << endl;  
  98.     cout << nn1 << endl;  
  99.   
  100.     //有符号数(正)扩充为有符号数和无符号数  
  101.     short int mm2 = 0x7000;             //+28672  
  102.     nn = mm2;  
  103.     nn1 = mm2;  
  104.   
  105.     cout << nn << endl;  
  106.     cout << nn1  << endl;  
  107.   
  108.     //有符号数(负)扩充为有符号数和无符号数  
  109.     short int mm4 = 0x8000;             //-32768  
  110.     nn = mm4;  
  111.     nn1 = mm4;  
  112.   
  113.     cout << nn << endl;  
  114.     cout << nn1  << endl;  
  115.   
  116. }  

转载于:https://www.cnblogs.com/xrcun/archive/2012/12/01/2797061.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170478.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 深圳易速马网络科技有限公司_动易网络

    深圳易速马网络科技有限公司_动易网络纵观现如今国内CMS程序,大有百花争艳的感觉,随着企业建站需求的复杂度和功能的不断扩展,传统的三五个人写一段代码即告网站建已经行不通,于是以内容管理为应用核心的CMS产品大行其道。  这些CMS系统大体上基于两套框架编写:PHP+MySQL和.NET+MSSQL。在PHP中比较有名的就有DeDeCMS、PHP168、帝国CMS、Supesite等,在.NET方面就有zoomla!CMS、

    2022年9月30日
    3
  • 通俗讲解 同步、异步、阻塞、非阻塞 编程

    通俗讲解 同步、异步、阻塞、非阻塞 编程#真正意义上的异步IO是说内核直接将数据拷贝至用户态的内存单元,再通知程序直接去读取数据。#select/poll/epoll都是同步IO的多路复用模式1.同步和异步#同步和异步关注的是消息通信机制#所谓同步,就是在发出一个*调用*时,没得到结果之前,该*调用*就不返回。但是一旦调用返回就得到返回值了,*调用者*主动等待这个*调用*的结果#所谓异步,就是在发出一个*调用*时,这个*调用*就直接返回了,不管返回有没有结果。当一个异步过程调用发出后,*被调用者*.

    2022年6月1日
    35
  • 台式电脑用网线可以上网,为什么把网线插到笔记本电脑上就连不上网的问题的解决

    台式电脑用网线可以上网,为什么把网线插到笔记本电脑上就连不上网的问题的解决那是笔记本网卡设置有问题。查看连接属性IP地址及DNS服务器是否是自动获得。然后修改成和台式机一样的为自动获得,即可让你的笔记本进入使用状态了!管理员在2009年8月13日编辑了该文章文章。–> –> window._bd_sh

    2022年6月26日
    52
  • 从零实现SpringBoot简易读写分离,也不难嘛!

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:温安适 my.oschina.net/floor/blog/1632565 最近在学习Spring boot,…

    2021年6月28日
    115
  • idea、webStorm怎么使用快捷键复制上一行

    idea、webStorm怎么使用快捷键复制上一行今天用idea写代码时,想要复制一行代码,才发现以前用Eclipse的复制快捷键在Idea中不起作用。————————————————————————————————————————————设置如下:File—>Settings(Ctrl+Alt+s)—>Keymap—>搜索输入(duplicate)—>双击Duplicate Entire Li…

    2022年6月13日
    128
  • requests库的使用(一篇就够了)

    requests库的使用(一篇就够了)urllib 库使用繁琐 比如处理网页验证和 Cookies 时 需要写 Opener 和 Handler 来处理 为了更加方便的实现这些操作 就有了更为强大的 requests 库 基本用法请先参考 requests 库安装一节 确保安装了 requests 库 下面案例使用 requests 库中的 get 方法发送了一个 get 请求 导入 requests 库 importreques 发送一个 get 请求并得到响应 r requests get https www baidu com 查看响应对象的类

    2025年10月21日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号