今天在制定完算法学习计划后复习C语言,看到一个讲位运算(以前用得很少)的题目。题目中涉及到左移操作,short n = 15; n<<=15; n = ?,我手动算了下,n=1,000,000,000,000,000。结果应该是32768,可一跑发现结果竟然是-32768。 查了下资料,羞愧难当啊! 竟然忘了计算机中有符号数的概念、负数的补码表示等,这该好好补补基础知识了,这半年花太多时间做一些表面的东西,丢掉了CS的根基。
下面是有关原码、补码、反码的链接,供查阅:
今天在制定完算法学习计划后复习C语言,看到一个讲位运算(以前用得很少)的题目。题目中涉及到左移操作,short n = 15; n<<=15; n = ?,我手动算了下,n=1,000,000,000,000,000。结果应该是32768,可一跑发现结果竟然是-32768。 查了下资料,羞愧难当啊! 竟然忘了计算机中有符号数的概念、负数的补码表示等,这该好好补补基础知识了,这半年花太多时间做一些表面的东西,丢掉了CS的根基。
下面是有关原码、补码、反码的链接,供查阅: