| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4533 人关注过本帖
标题:C语言的左移和右移的问题?
只看楼主 加入收藏
akjarjash
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2018-1-16
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:6 
C语言的左移和右移的问题?
C语言中:
  1)左移:丢弃最高位的符号位,低位补0。
  2)右移:如果为正数,那么高位补0进行右移,如果为负数,那么高位补1,进行右移。

有疑问的地方:
  1)对于左移:既然丢弃最高的符号位,那么为什么 -7 << 2 的结果会是 -28。
  2)对于右移:那原来的符号位还跟着右移吗再补位吗?还是先右移原来的非最高位的位,在针对符号位进行操作?

还请大佬们详细解答一下?
PS:采用的编译环境是Dev-C++,Win10
搜索更多相关主题的帖子: C语言 左移 右移 高位 符号位 
2018-01-29 12:25
虫眼
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:314
专家分:1121
注 册:2017-11-29
收藏
得分:2 
谁告诉你丢弃符号位?
2018-01-29 12:59
kin3z
Rank: 5Rank: 5
等 级:职业侠客
威 望:4
帖 子:157
专家分:390
注 册:2011-4-24
收藏
得分:10 
运算方法:
1.整型负数以补码的形式作存放,假定用7位来储存数据,计算如下:
先原码再移位:-7 == (补码)0111001 == (原码)1000111 ,左移2位,得 1011100 == -(4+8+16) == -28
相当于-7*2*2 == -14*2 == -28
2.至于右移,相同假设,如下:
-7 == (补码)0111001 == (原码)1000111 == (右移2位)1000001 == -1
相当于-7/2/2 == -3/2 == -1

实际应用在计算机硬件里有不同的实现方式,这个就脱离C的内容了,自行参考CPU运算单元的相关资料。
2018-01-29 13:08
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9030
专家分:54050
注 册:2011-1-18
收藏
得分:8 
以前翻译的,你看看

移位操作Bitwise shift operators
2. 每个操作数都应当为整型
3. 每个操作数都执行整型提升,结果类型为“左操作数类型提升后的类型”。如果右操作数是“负值”或“值大于等于左操作数的宽度”,其行为未定义。
4. E1<<E2的结果是E1左移E2位;空出的位以0填充。
当 E1 为符号类型时,结果等于“(E1*"2的E2次方")%"结果类型的最大值+1"”;
当 E1 为符号类型时,如果 值非负 且 结果类型能表达(E1*"2的E2次方"),那么(E1*"2的E2次方")就是结果值;否则行为未定义。
5. E1>>E2的结果是E1右移E2位。
当 E1 为符号类型时,或E1虽然是具符号类型但值非负时,结果值是 E1/(2的E2次方) 的整数部分;
当 E1 为符号类型,值为负时,结果值取决于 实现定义。
2018-01-29 13:34
akjarjash
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2018-1-16
收藏
得分:0 
回复 2楼 虫眼
哈哈,看的CSDN上写的一篇博客
2018-01-29 14:10
akjarjash
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2018-1-16
收藏
得分:0 
回复 3楼 kin3z
多谢,很详细 ^_^
2018-01-29 14:10
akjarjash
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2018-1-16
收藏
得分:0 
回复 4楼 rjsp
谢谢,更具体了:D
2018-01-29 14:12
快速回复:C语言的左移和右移的问题?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017766 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved