static-initialization
全部标签 我有一个不同长度的(指向)数组的数组,我了解到我可以使用复合文字来定义它:constuint8_t*constminutes[]={(constuint8_t[]){END},(constuint8_t[]){1,2,3,4,5END},(constuint8_t[]){8,9,END},(constuint8_t[]){10,11,12,END},...};gcc很好地接受了这一点,但clang说:指针由一个临时数组初始化,它将在完整表达式结束时被销毁。这是什么意思?代码似乎可以正常工作,但话又说回来,许多事情似乎在指向不再分配的内存时可以正常工作。这是我需要担心的事情吗?(最终我真
不幸的是,我必须在调用第3方库时执行缩小转换。我不想在我的发布版本中增加开销,所以将使用static_cast。但是,它是一个数组索引,因此如果它最终为负数,可能会带来一些乐趣。是否有某种方法可以仅在Debug模式下创建安全转换,以检查值以确保转换期间没有丢失?我能想到的唯一方法是使用宏,但我不想这样做。例如,在使用MSVC的发布和Debug模式下:intmain(){longlongll=std::numeric_limits::max();++ll;std::cout(ll);std::cout输出结果:2147483648-2147483648使用宏:templatetochec
我正在尝试编写一个nativeNode插件,它枚举Windows机器上的所有窗口并将它们的标题数组返回给JSuserland。但是我被这个错误难住了:C:\ProgramFiles(x86)\MicrosoftVisualStudio14.0\VC\include\xmemory0(655):errorC3074:anarraycannotbeinitializedwithaparenthesizedinitializer[C:\xampp\htdocs\enum-windows\build\enumWindows.vcxproj]C:\ProgramFiles(x86)\Micros
我有以下模板函数:templatevoidfoo2(Tt){}我知道我不能使用以下方式调用它:foo2({1,2,3});因为初始化列表是模板参数的非推导上下文。我必须使用:foo2>({1,2,3});但我也可以使用:foo2(std::initializer_list({1,2,3}));这让我想知道之间有什么区别:{1,2,3}和std::initializer_list({1,2,3})? 最佳答案 Abraced-initlist不是表达式,因此没有类型。当你打电话时foo2({1,2,3});编译器不知道是什么类型{1,
对引用static_cast的引用是否与指向指针static_cast的指针具有相同的运行时间成本?例如classB;classA:publicclassB;Aobj;A&ref=obj;A*ptr=&obj;//1static_cast(ref);//2static_cast(ptr); 最佳答案 不,它们并不总是具有相同的成本。启用优化后,它们总是具有相同或非常接近相同的成本。如果您向上或向下转换继承层次结构,其中任何一个涉及多重继承,或者一个多态类继承自一个非多态类,然后指针的static_cast可能会产生condition
我想编写一个仅适用于2个数字(例如3和5)的模板函数,如果您尝试将其与其他数字一起使用,则会出现错误。我可以这样做:templatevoidf();templatevoidf(){cout()\n";}templatevoidf(){cout()\n";}然后我可以用正常的方式调用这个函数:f();f();它编译得很好,如果我尝试错误地使用我的函数:f();编译器给我一个错误。这种方法有两个问题:1.-这是标准吗?我可以使用整数专门化模板吗?2.-我不喜欢使用这种方法时出现的错误,因为错误不会告诉用户他做错了什么。我更喜欢写这样的东西:templatevoidf(){static_as
有一个非模板化的类,它有一个模板化的构造函数。是否可以在此类构造函数中初始化成员变量之前检查静态断言?例如,下面的代码在检查T是否有这样的方法之前执行T::value()。classMyClass{public:templateMyClass(constT&t):m_value(t.value()){static_assert(HasValueMethod::value,"Tmusthaveavalue()method");}private:intm_value;};将static_assert放在构造函数的主体中工作正常,除了它在最后打印“Tmusthaveavalue()met
我有一个程序分成两个源文件:example.cpp#includeclassA{public:A(intx){::std::cout例子__main.cppintmain(intargc,constchar*argv[]){return0;}这个程序的输出是否保证是:InA(1)InA(2)在所有平台和编译器上?如果是这样,它在标准中的哪个位置这样说?如果我使用命名空间并且first和second出现在不同的命名空间中,这有关系吗?如果它们不是静态的并且我使用的是匿名命名空间怎么办? 最佳答案 是的,如果声明出现在同一个翻译单元中,
我有一个关于在C++中使用多维std::intializer_list的问题。我有一个Matrix类,我希望能够像这样初始化它:Matrixm({{1,2,3},{4,5,6},{7,8,9}});我现在拥有的构造函数采用二维初始化列表作为参数,但编译器不喜欢我的使用方式。这是代码:templateMatrix::Matrix(std::initializer_list>set){std::vector>setVec=set;std::vector>v;for(std::vector>::iteratori=setVec.begin();i!=setVec.end();i++){v.p
假设我有以下结构:structmyStruct{intx;inty;intz;intw;};我想在调用以下函数时将此结构初始化为默认值。如果有帮助,我正在寻找一个简单的零初始化。voidmyFunc(myStructparam={0,0,0,0}){...}然而这段代码给我编译错误。我试过VS2003和VS2008。注意:我看过其他提到使用构造函数的答案。但是,我希望用户看到我正在使用哪些值进行初始化。 最佳答案 将默认构造函数添加到您的myStruct将解决您的问题。structmyStruct{myStruct():x(0),y