加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C做什么>>做

发布时间:2020-12-16 10:54:34 所属栏目:百科 来源:网络整理
导读:什么在这种情况下呢? int n = 500;unsigned int max = n4;cout max; 打印出31. 500到达31后它做了什么? 解决方法 有点移位! 原始二进制500: ????222220100 转移4 ????000022222是31! Original: 2222201001st Shift:0222220102nd Shift:0022222013rd Shi
什么>>在这种情况下呢?

int n = 500;
unsigned int max = n>>4;
cout << max;

打印出31.

500到达31后它做了什么?

解决方法

有点移位!

原始二进制500:
????222220100

转移4
????000022222是31!

Original: 222220100
1st Shift:022222010
2nd Shift:002222201
3rd Shift:000222220
4th Shift:000022222 which equals 31.

这相当于将整数除以16.

500/16 = 31
500/2 ^ 4 = 31

一些事实从这里拉出来:http://www.cs.umd.edu/class/spring2003/cmsc311/Notes/BitOp/bitshift.html(因为从我头上咆哮导致漫无目的,这是非生产性的……这些人说它比我更干净)

使用<<<<<导致0从最低有效端(右侧)移位,并导致位从最高端(左侧)脱落. 使用>>向右移位导致0从最高端(左侧)移位,如果数字是无符号的,则导致位从最低端(右侧)掉落.

Bitshifting不会改变被移位变量的值.而是使用位移结果创建临时值.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读