C语言实形常数字母后缀,实型常量在C语言中只能用()表示,表示方法有:()。

我觉得这两个是正确的实型常量阿引用如下:严格来说,C语言中没有“实型”real type这种数据类型。

C语言中非构造类型只有整型int、short、long、long long和对应的unsigned修饰的类型,以及同义写法,以及浮点型包括单精度浮点型float,双精度浮点型double,长双精度浮点型long double两大类。

其中float和double内部储存形式遵循IEEE 754标准,long double取决于编译平台。

C语言中的浮点型数内部储存形式为指数计数法分段存储的二进制形式的小数,即使在规定大小和字长精度范围之内也不能严格无误差地表示所有十进制小数、有理数,更不用说实数。

而C语言源代码中除了16进制整数表示的实际存储形式以外,直接表示的所有浮点数都只能是十进制的,因此除非在二进制下也是有限小数分数形式中分母是2的幂,且不是太长,否则在编译过程中即会产生误差。

尽管如此,有时候float、double、long double这三者或者前两者会被不严格地统称为“实型”。

C语言中,数值常量的后缀大小写同义可以表达常量的类型,例如0UL表示unsigned long型数0。

如果没有后缀,则通过具体的写法来确定。

总的原则是尽可能避免精度损失。

不过也不是范围越小越好,例如0是int型而不是char型常量。

对于没有后缀的十进制小数小数部分或整数部分之一完全不写的也算,当作省略了0,默认为double常量,例如3.1415等同于3.1415D。

如果要用float常量,应该使用3.1415f或3.1415F。

对于指数形式的,默认也是double,例如0.329e2或者0.329E+2之类的也可以。

至于0.329*10^2如果出现在源代码中,会被当做是一个表达式,先计算0.329和10的积,结果再和2作^位异或运算。

但由于积是double类型的,不能参与位运算,会给出编译错误。

871是int常量,不是“实型”常量。

871.、871.f、871.0F、871.d、871.0D、8.71E+2、0.871e3这类才是“实型”常量。

回答者: 幻の上帝 - 十四级 2010-1-16 19:52

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值