某些变量初始化中"l"的含义是什么 - C++
What is the meaning of "l" in some variables initialization - C++
在一些变量初始化中"l"的含义是什么?例如:
#define maxpossible (1000000000L)
double A = 1L;
double B = 999999999l;
"L"answers"L"有区别吗?
这是一个后缀类型说明符,对于A
和B
,您可以在这里阅读更多关于浮点字面值的信息。简而言之,L
和l
都表示long double
。对于maxpossible
,你可以在这里读到整数字面值,L
表示long
。
编辑
Mike Seymour善意地指出,所有的文字都是integer
文字。这只是表明,当你不仔细检查你的答案时,你会说错话。一个简单的完整性检查应该如下所示:
#include <iostream>
#include <typeinfo>
int main()
{
std::cout << typeid( decltype( 1L ) ).name() << std::endl ;
std::cout << typeid( decltype( 999999999l ) ).name() << std::endl ;
std::cout << typeid( decltype( 1000000000L ) ).name() << std::endl ;
}
每一个都是l
,通过c++filt -t
运行得到long
。是什么让这些字面值变成了浮点字面值?一个:
- 包含小数点的数字
- 指数表示的数字,例如
4e2
std::cout << typeid( decltype( .1l ) ).name() << std::endl ;
std::cout << typeid( decltype( 1e2L ) ).name() << std::endl ;
这两种情况下都是e
,通过c++filt -t
运行得到long double
。
因为这些都是文字常量。
后缀l
或L
使常数为long
或long double
。
在您的示例中,maxpossible
是long integer
。A
和B
都是长双精度对象。但是由于您将它们声明为double
,因此它们存储为doubles
。
相关文章:
- 为不同配置设置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函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么