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



请问如何区分c语言中float和double的用法? 第1页

  

user avatar   zhan-qi-lai-74-48 网友的相关建议: 
      

sqrt函数的返回值是double类型。

相应的,返回float和long double的分别是sqrtf、sqrtl。

其他数学函数同理。


因为函数的可变参数列表中,float会自动提升为double,所以printf函数中%f和%lf都可以用于float和double,二者无区别。(但是C90及以前则只定义了%f、没有定义%lf)。

但是,可变参数列表中,float *不会提升为double *,或者说是因为float和double的长度不同(指针三要素:指向的首地址、指向目标的长度、指向目标的类型),所以scanf中float能且只能用%f、double能且只能用%lf。

至于long double,无论是printf还是scanf,都用%Lf。




  

相关话题

  c语言程序经过编译后,每条指令都有一个内存地址,那两个程序如果有相同内存地址的指令怎么办? 
  怎么在事先未知将要输入数字的个数的情况下,将其全部赋值给一个数组? 
  如何在运行时初始化静态成员变量? 
  Visual Studio 2019可以用来玩C语言吗? 
  C语言中逗号表达式存在的意义是什么? 
  为什么 C++ 能够源码级兼容C语言? 
  单片机编程最早是汇编,然后从汇编转为c语言,那么,c++会不会替代c语言来进行单片机编程 ? 
  老师要求我只能使用C++、C或者Java写算法,如何看这种做法? 
  对于一个大一计科新生,有什么代码行数在 500~1000 的程序(C 语言)可以试着写来练手? 
  semaphore和mutex的区别? 

前一个讨论
C++中lambda表达式中捕获的值变量存在哪?
下一个讨论
AMD Zen2偶发,Zen3高发的WHEA-18错误,可能是由什么原因造成的?





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