百科问答小站 logo
百科问答小站 font logo



为什么C语言整型常量十进制形式的类型与八进制、十六进制的不一样? 第1页

  

user avatar   Ivony 网友的相关建议: 
      

这个问题很有意思啊,提问者的问题是:

对于十进制的为什么不经过unsigned int,直接从int跳到long;按理说它应该像八进制与十六进制一样,从小到大逐一选取。


其实这个是不对的,因为不经过unsigned int才是正常的,反之八进制和十六进制表达式没有跳过这个才是不正常的。

这是因为我们用16进制或者8进制的时候,更多是为了位运算,例如int是16位的,那么0xFFFF就用int装不下,这样就会变成32位的long,变成0x0000FFFF,很显然这是一种浪费,因为位运算根本用不着这么多位,譬如说我们要把x的高八位和y的低八位组合在一起,一般是这样写:

(x&0xFF00)|(y&0xFF)

因为int是16位的,就装不下0xFF00的正数,就必须升位成long,结果就会变成:

(x&0x0000FF00)|(y&0xFF)

最后得到的结果就莫名其妙变成了long型的。




  

相关话题

  C「带坏了」多少程序语言的设计? 
  到底存在不存在不适合学编程的人? 
  网传华为研发出属于我国的编程语言「仓颉」,这是真的吗?这意味着什么? 
  电脑怎样执行编程语言的? 
  对于这一条add指令,ALU是不是会被使用2次来分别计算有效地址和数据?而且是在1个阶段内还是2个阶段 
  计算机大一新生,压力大,天天都在学习,我该怎么办? 
  为什么 C 语言没有被 C++ 取代? 
  你对你认为比较漂亮的编程语言的语法有什么理解? 
  华为自研的「仓颉」编程语言,未来能取代java的地位吗? 
  请问如何区分c语言中float和double的用法? 

前一个讨论
微软 IE 比起其他浏览器,是否做得不够好用?为什么?
下一个讨论
如何优雅地配一台台式机?





© 2025-03-03 - tinynew.org. All Rights Reserved.
© 2025-03-03 - tinynew.org. 保留所有权利