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



C语言中整型输出(%d)有什么用? 第1页

  

user avatar   pansz 网友的相关建议: 
      

这个问题涉及到早期的C语言设计。也就是在第一个C标准(C89)诞生以前的K&R C。

那时候的 C 语言不需要声明函数原型,函数参数在传入时会被转化,具体转化规则有两个:

第一:所有小于 int 类型的整数都会被转化到 int 型 或者 unsigned int。

第二:所有 float 会被转化为 double。

无论你实际上输入的是 char,还是short,函数调用的时候,这些参数都会被转化为 int 并传入。

同样,无论你输入的 是 float 还是 double,函数调用时实际都以 double 传入。

以上规则作用于两类函数:第一是没有函数原型,或者函数原型内没有参数类型的函数。第二是变参函数中的可变参数。


在现代C语言中,C89以后开始标准建议是不会使用无函数原型的函数,但变参函数依然存在,所以这种自动转化输入参数的调用规则实际上在 printf 这样的函数中被保留了下来。

printf 是一个变参函数,其中的可变参数也符合转化原则,因此实际上所有小于 int 的类型最终都会被转化为 int,小于 double 的浮点都会被转化为 float 。

所以当处理 format 的时候,后面可变参数的传入的值并不是你传入的实际类型。你必须在 format 中指定要显示为何等参数类型,才能正确显示。




  

相关话题

  编程序,写一个函数,输入一个十六进制数,输出相应的十进制数。怎么做啊? 
  C++为何没有一个简便的调库方法? 
  C++整型有__int8、__int16、__int32等等,为什么还要short、int、long? 
  C语言中,stdio.h是最重要的头文件吗? 
  C语言中for语句的赋初值用int i=1和i=1有什么区别? 
  写C with class很丢人么? 
  C++需要反射吗? 
  网游服务器逻辑和传输如何分层/解耦? 
  Linus Torvalds 开过哪些著名的嘴炮? 
  C语言中float的取值范围的问题,为啥? 

前一个讨论
微软为什么要做 WSL 而不是 LSW?
下一个讨论
12600KF 和 5800X 选哪个?





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