我需要从double值指定要打印的字符串的确切长度,但我不想限制输出超出必要的范围。

当用printf()格式化时,6位精度双精度的最大长度是多少?

具体来说,我应该在printf("%X.6lg",doubleValue);中给X赋予什么值以确保没有值被截断?

我需要具体说明长度的原因是我定义了一个MPI派生数据类型,该数据类型由许多双值的字符串表示组成,并且必须知道它们的确切长度才能在MPI进程之间划分文件的区域

我希望这很清楚。在此先感谢您的回答。

有帮助吗?

解决方案

使用printf("%.6g", doubleValue)printf("%.6Lg", doubleValue)

请注意,在精度说明符中省略前导数字(<!> quot; width <!> quot;)不要求值的整数部分的长度。

还要注意大写<!>“l <!>”;将指定您的值是一个long int。大写<!>“L <!>”;指定一个long double值。

另请注意,如果您不希望将其更改为科学记数法(如果它是一个较短的表示法),那么您将使用<!> quot; f <! > QUOT;而不是<!>“g <!>”。

请参阅 printf参考

其他提示

IEEE双精度的最大指数为1023,因此最大双精度为1 + 1/2 + 1/4 + 1/8 + ...等* 2 ^ 1023。这将是大约318个字符长,十进制表示法。

为什么不使用<!>“e <!>”;格式说明符?

有<!> lt; float.h <!> gt;包含许多有用的值,其中包括DECIMAL_DIG,用于 long double

同一个文件很可能会告诉您平台上的 double 超过6位精度......

PS:还请注意Demi上面的回答。他指出你的printf()中的各种漏洞逃过了我。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top