搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ C语言的左移和右移的问题?
标题:
C语言的左移和右移的问题?
只看楼主
akjarjash
等 级:
新手上路
帖 子: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
虫眼
等 级:
贵宾
威 望:
10
帖 子:314
专家分:1121
注 册:2017-11-29
第
2
楼
得分:2
谁告诉你丢弃符号位?
2018-01-29 12:59
kin3z
等 级:
职业侠客
威 望:
4
帖 子:157
专家分:390
注 册:2011-4-24
第
3
楼
得分: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
等 级:
版主
威 望:
507
帖 子:8890
专家分:53117
注 册:2011-1-18
第
4
楼
得分: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
等 级:
新手上路
帖 子:4
专家分:0
注 册:2018-1-16
第
5
楼
得分:0
回复 2楼 虫眼
哈哈,看的CSDN上写的一篇博客
2018-01-29 14:10
akjarjash
等 级:
新手上路
帖 子:4
专家分:0
注 册:2018-1-16
第
6
楼
得分:0
回复 3楼 kin3z
多谢,很详细 ^_^
2018-01-29 14:10
akjarjash
等 级:
新手上路
帖 子:4
专家分:0
注 册:2018-1-16
第
7
楼
得分:0
回复 4楼 rjsp
谢谢,更具体了:D
2018-01-29 14:12
7
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-484521-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.384952 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved