开发者

How can you make a C compiler assume decimal literals (e.g. 1.23) are float and not double?

In my source code, if I write 1.23 as a literal, e.g. doThis(1.23), gcc assumes it's a double.

Rather than type doThis((float) 1.23), is there a way to use fl开发者_JS百科oats for decimal literals/constants unless otherwise specified in an individual source file?

Mega-bonus points, is there a way that works across (nearly) every C compiler?


Yes, the standard way is to write 1.23f. It works with every C compiler, since it is defined in ISO C99 section 6.4.4.2 Floating constants. ISO C90 and K&R have similar definitions.


try:

float fred = 0.37f;


try 123.4F for a float constant


Also gcc has the option -fsingle-precision-constant that tells the compiler to treat constants as single precision. See http://gcc.gnu.org/wiki/FloatingPointMath

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜