长双文字的C++后缀是什么?
What's the C++ suffix for long double literals?
在c (和c)中,浮点字面的flo point默认为 double
,而后缀 f
表示 float
。但是获得long double
的后缀是什么?
不知道,我会定义,说
const long double x = 3.14159265358979323846264338328;
,但我担心的是,可变x
包含的3.14159265358979323846264338328
的显着位比64较少,因为这是double
字面的。这是有道理的吗?
来自C 标准
除非明确指定,否则浮动文字的类型是两倍 通过后缀。后缀F和F指定浮子,后缀L和L 指定长双。
与C标准的相应段落进行比较很有趣。在C中,使用术语floating constant
而不是C 中的floating literal
:
4一个未固定的浮动常数具有双型。如果字母f或f的后缀为float类型。如果字母l或l的后缀,它具有类型的长double
c后缀为 L
。我强烈怀疑C 是一样的。
您的担心是合理的。您的文字将首先转换为double
,因此被截断,然后转换回long double
。
您的担忧是有效的,您应该使用L
后缀为长双字面。
我尝试了l
后缀:
#include <iostream>
#include <iomanip>
#include <string>
using namespace std;
int main()
{
float t1 = 1.10000000000000000002l;
double t2 = 1.10000000000000000002l;
long double t3 = 1.10000000000000000002L;
cout << setprecision(25);
cout << t1 << endl;
cout << t2 << endl;
cout << t3 << endl;
}
我仍然得到此输出,表明缺乏所需的精度:
1.10000002384185791015625
1.100000000000000088817842
1.100000000000000088817842
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 在一行C 中,该代码后缀和前缀的输出的逻辑是什么
- 长双文字的C++后缀是什么?
- 整数后缀J是什么意思
- 以下代码片段中 push(po[i]-'0') 对评估后缀表达式的重要性是什么