关于移位运算符的问题
书中是这么写的:对移位运算符右侧的参数需要进行模32的运算(除非左边的操作数是long类型,在这种情况下需对右侧操作数模64)。例如1<<35与1<<3或8是相同的。这一...
书中是这么写的:
对移位运算符右侧的参数需要进行模32的运算(除非左边的操作数是long类型,在这种情况下需对右侧操作数模64)。例如1<<35与1<<3或8是相同的。
这一句话完全不懂,首先模32与模64是什么,其次1<<3是8这个懂,1<<35是什么,求解,谢谢 展开
对移位运算符右侧的参数需要进行模32的运算(除非左边的操作数是long类型,在这种情况下需对右侧操作数模64)。例如1<<35与1<<3或8是相同的。
这一句话完全不懂,首先模32与模64是什么,其次1<<3是8这个懂,1<<35是什么,求解,谢谢 展开
2个回答
展开全部
右侧的参数需要进行《模32的运算》...
这就是求:除以 32,所得到的余数。
那么,35,除以 32,余数,就是 3。
因此,<< 35,就和 << 3,等效。
都是左移 3 位。
都是,乘以 8。
----------------
1 << 35,左侧的 1,应该是指整型数,是 32 位的数字。
一个数字,仅仅才 32 位,对其移位 35 位?
超出了总位数,怎么移?
所以,就限定,最多就移位 32 位。
超过 1 位,就算移 1 位。
超过 2 位,就算移 2 位。
超过 3 位,就算移 3 位。
……
实际的移位个数,就是《模 32》得来的。
这就是求:除以 32,所得到的余数。
那么,35,除以 32,余数,就是 3。
因此,<< 35,就和 << 3,等效。
都是左移 3 位。
都是,乘以 8。
----------------
1 << 35,左侧的 1,应该是指整型数,是 32 位的数字。
一个数字,仅仅才 32 位,对其移位 35 位?
超出了总位数,怎么移?
所以,就限定,最多就移位 32 位。
超过 1 位,就算移 1 位。
超过 2 位,就算移 2 位。
超过 3 位,就算移 3 位。
……
实际的移位个数,就是《模 32》得来的。
更多追问追答
追问
那模64也就类似对吧,还有左侧是long类型指的是什么,我记得long很大很大才对啊,能帮忙举个例子么
追答
早期,初学C语言时,整型数是 16 位数。
现在的计算机和编译软件,都把整型数当做 32 位数。
现在的 long 型,就是 64 位数。
1 << 35,左侧的 1,如果是 LONG,64 位数。
就限定,最多,就移位 64 位。
超过 1 位,就算移 1 位。
超过 2 位,就算移 2 位。
超过 3 位,就算移 3 位。
……
实际的移位个数,就是《模 64》得来的。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询