草庐IT

static-initializer

全部标签

c++ - 位域 "In-class initialization"结果为 "error: lvalue required as left operand of assignment"

structbitfield{inti=0;//okintj:8=0;//error:lvaluerequiredasleftoperandofassignment};使用C++11“类内初始化”功能初始化位域的正确语法是什么? 最佳答案 这是作为C++标准的核心问题1341提出的,但在2015年10月被C++核心工作组拒绝为NAD(“不是缺陷”)-参见http://open-std.org/JTC1/SC22/WG21/docs/cwg_closed.html#1341 关于c++-位

c++ - 位域 "In-class initialization"结果为 "error: lvalue required as left operand of assignment"

structbitfield{inti=0;//okintj:8=0;//error:lvaluerequiredasleftoperandofassignment};使用C++11“类内初始化”功能初始化位域的正确语法是什么? 最佳答案 这是作为C++标准的核心问题1341提出的,但在2015年10月被C++核心工作组拒绝为NAD(“不是缺陷”)-参见http://open-std.org/JTC1/SC22/WG21/docs/cwg_closed.html#1341 关于c++-位

c++ - 如何在头文件中定义 const static std::string?

我有一个类,我想存储一个静态std::string,它要么是真正的const,要么是通过getter有效的const。我尝试了几种直接的方法1.conststaticstd::stringfoo="bar";2.constexternstd::stringfoo;//definedatthebottomoftheheaderlikeso...//remainingcodeinheader};//closeheaderclassdeclarationstd::stringMyClass::foo="bar"/#endif//MYCLASS_H我也试过了3.protected:static

c++ - 如何在头文件中定义 const static std::string?

我有一个类,我想存储一个静态std::string,它要么是真正的const,要么是通过getter有效的const。我尝试了几种直接的方法1.conststaticstd::stringfoo="bar";2.constexternstd::stringfoo;//definedatthebottomoftheheaderlikeso...//remainingcodeinheader};//closeheaderclassdeclarationstd::stringMyClass::foo="bar"/#endif//MYCLASS_H我也试过了3.protected:static

c++ - 在 C++ 中使用 static_cast 转换指向数组引用的指针是否合法?

我有一个指针T*pValues我想将其视为T(&values)[N]在这个SO答案中https://stackoverflow.com/a/2634994/239916,建议这样做的方法是T(&values)[N]=*static_cast(static_cast(pValues));我对此的担忧是。在他的示例中,pValues以如下方式初始化TtheValues[N];T*pValues=theValues;我的问题是,如果pValues来自以下任何构造,则强制转换构造是否合法:1:TtheValues[N+M];//M>0T*pValues=theValues;2:T*pValue

c++ - 在 C++ 中使用 static_cast 转换指向数组引用的指针是否合法?

我有一个指针T*pValues我想将其视为T(&values)[N]在这个SO答案中https://stackoverflow.com/a/2634994/239916,建议这样做的方法是T(&values)[N]=*static_cast(static_cast(pValues));我对此的担忧是。在他的示例中,pValues以如下方式初始化TtheValues[N];T*pValues=theValues;我的问题是,如果pValues来自以下任何构造,则强制转换构造是否合法:1:TtheValues[N+M];//M>0T*pValues=theValues;2:T*pValue

c++ - std::initializer_list{x, y, z} (CTAD) 有效吗?

在构建std::initializer_list时显式地,是否可以推导出模板参数(U)(例如,使用类模板参数推导(CTAD))?换句话说,我知道以下陈述是有效的:std::initializer_listx1{1,2,3};std::initializer_listx2={1,2,3};autox3=std::initializer_list{1,2,3};但以下陈述是否也有效?std::initializer_listx1{1,2,3};std::initializer_listx2={1,2,3};autox3=std::initializer_list{1,2,3};编译器对于s

c++ - std::initializer_list{x, y, z} (CTAD) 有效吗?

在构建std::initializer_list时显式地,是否可以推导出模板参数(U)(例如,使用类模板参数推导(CTAD))?换句话说,我知道以下陈述是有效的:std::initializer_listx1{1,2,3};std::initializer_listx2={1,2,3};autox3=std::initializer_list{1,2,3};但以下陈述是否也有效?std::initializer_listx1{1,2,3};std::initializer_listx2={1,2,3};autox3=std::initializer_list{1,2,3};编译器对于s

c++ - g++ __static_initialization_and_destruction_0(int, int) - 它是什么

编译c++文件(带有全局静态对象)后,我进入nm输出这个函数:00000000t_Z41__static_initialization_and_destruction_0ii__static_initialization_and_destruction_0(int,int)/*afterc++filt*/这是什么?它将调用__cxa_atexit()我可以禁用此函数的生成(并调用__cxa_atexit())并将所有构造函数和析构函数调用放在.ctors和.dtors部分? 最佳答案 这个doc文件似乎告诉你所有你想知道的关于这些函

c++ - g++ __static_initialization_and_destruction_0(int, int) - 它是什么

编译c++文件(带有全局静态对象)后,我进入nm输出这个函数:00000000t_Z41__static_initialization_and_destruction_0ii__static_initialization_and_destruction_0(int,int)/*afterc++filt*/这是什么?它将调用__cxa_atexit()我可以禁用此函数的生成(并调用__cxa_atexit())并将所有构造函数和析构函数调用放在.ctors和.dtors部分? 最佳答案 这个doc文件似乎告诉你所有你想知道的关于这些函