jjzjj

initialization

全部标签

c++ - 警告 : non-static data member initializers only available with -std=c++11 or -std=gnu++11 [enabled by default]

这个问题在这里已经有了答案:C++ArrayInitializersWarnings(2个答案)关闭8年前。我刚刚在我的机器上安装了最新版本的cygwin和eclipseluna。它工作正常,我能够运行我的项目。但是,当我构建它们时,我收到了我不明白的警告。例如,这是我从“c++Primer”一书的网站上获得的头文件“Sales_item.h”的警告:warning:defaultedanddeletedfunctionsonlyavailablewith-std=c++11or-std=gnu++11[enabledbydefault]Sales_item()=default;^..

c++ - initializer_list 作为数组引用参数的参数?

下面对foo的调用是否有效?GCC似乎对此很满意,而Clang为foo给出了“无匹配函数”错误;以及无法推断出N的注释。templatevoidfoo(constint(&x)[N]){}intmain(intargc,char*argv[]){foo({1,2,3});return0;} 最佳答案 编辑:随着CWGissue1591决议的通过在委员会2014年11月的session上,现在允许使用OP中的代码。编译器现在可以推断出数组中元素的类型和数量。§14.8.2.5[temp.deduct.type]/p5:Thenon-d

c++ - 从子类初始化 protected 静态成员

我想知道是否可以从子类中初始化一个protected静态成员。例如,//headfileclassTest{protected:staticinti;};classTest2:publicTest{};//cppfile#include"headfile.h"intTest2::i=1;如您所见,当我初始化这个静态成员(i)时,我使用了子类名称(Test2)。令我惊讶的是,我用visualstudio2013测试了这段代码,它没有出错。但是如果我在Linux下使用Netbeans(gcc11)尝试它,我得到一个提示错误:无法解析标识符i然后我编译了一下,报错信息是:错误:ISOC++不

c++ - 如何在C++中初始化成员的构造函数参数

我有以下代码(头文件):classInnerClass{InnerClass(intvar);}classBigClass{BigClass();InnerClassmember(5);}如何将BigClass中的member参数初始化为5(上面的代码会产生错误,您可能已经猜到了)?如果我将InnerClassmember(5)行放在代码(而不是头文件)文件中,那么没问题。 最佳答案 您可以通过in-classbrace-or-equalinitializer初始化成员变量BigClass::member(自c++11起):Inne

c++ - 结构化绑定(bind)的标识符是否按顺序初始化?

很难从proposal中推断出.C++17结构化绑定(bind)会从左到右初始化它们的标识符吗?这是否保证打印“first”、“second”、“third”?#includestructA{A(){std::cout 最佳答案 结构化绑定(bind)不会复制值;它引用它们。在您的示例中,a不是返回值第一个成员的拷贝;这是对它的引用。由于您正在初始化引用而不是值,因此无法通过查看构造函数调用的顺序来检测初始化顺序。对于具有公共(public)成员的结构,获取这些引用的顺序无关紧要,因为您无法干扰该过程。对于实现结构化绑定(bind)

c++ - 为什么 vector<double> 接受带有整数元素的 initializer_list?

#include#includeintmain(){//caseI:uniforminitialization//intii=100;//Error:cannotbenarrowedfromtype'int'to'double'//ininitializerlist//doubledd{ii};//caseII:initializer_list//std::vectorvecDouble{1,2.2};//fine!//caseIII:initializer_list//std::vectorvi={1,2.3};//error:doubletointnarrowing//caseIV

c++ - 为什么 std::initializer_list 会复制项目?

我一直认为std::initializer_list是一个轻量级代理对象,它只会从列表项中获取const引用,而不是复制它们。但是后来我发现在这种情况下实际上执行了复制:structTest{Test(){std::cout以上代码的输出:0x63e5acdadefaultctor0x63e5acdbdefaultctor0x63e5acdcdefaultctorforbegin0x63e5acddcopyctor0x63e5acdecopyctor0x63e5acdfcopyctorCurrent:0x63e5acddCurrent:0x63e5acdeCurrent:0x63e5a

c++ - 不可复制类型的 std::initializer_list 替代品

我知道尝试使用std::initializer_list导致错误,因为元素被复制到由initializer_list表示的临时数组中.我还阅读了一些解释,说明为什么在列表中使用右值引用是不对的,我对此很满意。问题是我想传递不可复制的东西不是为了从它们中移动,而只是想const-访问它们,因此关于右值的论点不适用。如果可能的话,我该怎么做才能保留列表初始化语法和引用语义(没有包装器,没有原始指针)?NonCopyablea{...},b{...};ListInitializedc{a,b};我想我在这里遗漏了一些非常明显的东西。更新:这行得通(*),ListInitialized(std

c++ - 不稳定的行为

我是C++的新手。小代码示例如下:intmain(intargc,char*argv[]){charch1;intint1;cin>>ch1;cin>>int1;cout当我运行程序并输入以下内容时:az我得到的输出是:a32767我理解“a”,但为什么整数值是32767?我只是想测试看看如果我使用“z”而不是分配给int1的数值会发生什么。我尝试输入:ax...我也得到了相同的结果。现在如果我使用shortint1而不是intint1并使用输入运行程序:az我得到输出:a0附言sizeof(int)=4sizeof(short)=2我使用的是64位机器。

c++ - 当 Py_initialize 失败时如何捕获并处理 fatal error ?

我将python嵌入到C++dll中(因此最终我可以将其放入xll中)。当设置错误时,Py_Initialize被记录为最终失败-参见http://docs.python.org/c-api/init.html,"...如果初始化失败是fatalerror。".是否可以捕获此错误以及如何捕获?考虑可能是一个全局窗口钩子(Hook)? 最佳答案 我通过创建一个单独的可执行文件来尝试初始化python来解决这个问题。我的主要进程将启动它并检查退出代码,并且仅在子进程成功时才调用PyInitialize。因此,python被初始化了两次,