草庐IT

initialize-error

全部标签

c++ - #error inside of#define - 可能在 C++ 中(如果未定义某些常量,则在调用宏 MyMacro 时生成错误)?

我想定义宏,它基于某些条件(#defineINITED的存在,而不是宏的参数)将返回值,或生成编译器错误,例如:#errorNotinitialized!我试过(对于myIdea.h):#ifdefINITED#defineMyMacro(x)x->method();//somethingwithx#else#defineMyMacro(x)#errorNotinitalized!#endif但是该代码会生成错误(不是我想要的那个)预期的宏格式参数。请注意,我不想要该代码(工作,但做了一些不同的事情):#ifdefINITED#defineMyMacro(x)x->method();/

c++ - 'Windows.h : No such file or directory"error when changing Platform Toolset to v140_xp

这个问题在这里已经有了答案:HowtotargetWindowsXPinMicrosoftVisualStudioC++[duplicate](2个答案)关闭4年前。我尝试为WindowsXP编译一个应用程序;正常的可执行文件给出错误:"...isnotavalidWin32application."我读到我可以通过将平台工具集更改为VisualStudio2015-WindowsXP(v140_xp)来创建与XP兼容的可执行文件,但是当我这样做然后尝试编译时,它给了我以下错误:Cannotopenincludefile:'Windows.h':Nosuchfileordirector

c++ - 将 apiVersion 参数设置为 0 时的 VK_ERROR_INCOMPATIBLE_DRIVER

我正在尝试创建一个vulkan实例。这是我的代码:vk::ApplicationInfoappInfo("Test",1,nullptr,0,0);vk::InstanceCreateInfoinfo;info.pApplicationInfo(&appInfo);vk::Instanceinstance;constautoresult=vk::createInstance(&info,nullptr,&instance);std::cout但是这会返回VK_ERROR_INCOMPATIBLE_DRIVER。如果我不提供自己的ApplicationInfo而是使用默认构造的,它就可以

c++ - std::initializer 列表全局/静态对象的生命周期

std::initializer_list主要用作类构造函数/函数参数,以便将列表元素复制到另一个容器中。但是如何使用std::initializer_list创建一个全局对象呢?例如:structElemType{constchar*name;boolflag;};std::initializer_listMyGlobalData={{"One",true},{"Two",false}};如果查看std::initializer_list模板定义(在VisualStudio2017中选中),它仅包含2个数据成员:const_Elem*_First和_最后。这意味着初始化列表数据应该存

c++ - 在 T 的构造函数中使用 *this = T() 将 "initialize"类型为 T 的对象安全吗?

构造函数Year()在这种情况下安全吗?structYear{intyear;Year(inty):year(y){}Year(){*this=Year(1970);}//*this=this->operator=(Year(1970));};Yeary;我认为是的,因为一旦执行流到达构造函数主体,year就已经用int()初始化了。还有其他问题需要考虑吗?不要考虑同样的技巧可能会引起麻烦的其他情况。 最佳答案 当然,thiswillwork,并且有效。说明在你的ctor-body运行时,所有的数据成员和基础都已经构建好了,并且:[

centos yum/dnf 命令安装报错 Error: GPG check FAILED

centos用dnf命令安装包的时候出现包签名错误报错信息[root@localhost]#dnfinstallgitCentOS-8-AppStream388kB/s|4.4kB00:00CentOS-8-Base3.7kB/s|3.9kB00:01CentOS-8-Extras376kB/s|2.9kB00:00Dependenciesresolved.PackageArchitectureVersionRepositorySizeInstalling:gitx86_642.39.3-1.el8AppStream104kInstallingdependencies:git-corex86_

c++ - 仿函数和 initializer_list 的拷贝

我对复制仿函数和/或初始化器时发生的情况感到有点困惑。在下面的代码中,我认为我会一直复制/移动对象,但不管它是否存在段错误。我似乎做错了什么,但还没有弄清楚,我的错误假设是什么。奇怪的是,在cppreference.com我找不到initializer_list的复制或移动构造函数,所以我想知道在这些情况下实际发生了什么。#include#include#include#includestd::initializer_list>getInitializer(){return{[]()->std::string{return"If";}};}intmain(){std::function

c++ - std::runtime_error 子类的 "call to deleted constructor of"编译器错误

我从std::runtime_error派生了一个异常类,以便添加对异常流的支持。我收到一个奇怪的编译器错误输出,我不确定如何解决?clang++-std=c++11-stdlib=libc++-g-Wall-I../-I/usr/local/includeMain.cpp-cMain.cpp:43:19:error:calltodeletedconstructorof'EarthException'throwEarthException(__FILE__,__LINE__)^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~../EarthExce

c++ - error LNK2019 未解析的外部符号

我对C++很陌生,所以我下载了一个示例C++程序。示例程序在编译时似乎遇到了以下错误:-Error22errorLNK2019:unresolvedexternalsymbol_acsEnumServerNames@12referencedinfunction"protected:virtualint__thiscallCOpenTsrv::OnInitDialog(void)"(?OnInitDialog@COpenTsrv@@MAEHXZ)Opentsrv.obj我将其追溯到所引用的函数,但我不知道它有什么问题吗?BOOLCOpenTsrv::OnInitDialog(){CDia

c++ - 在模板函数中使用 initializer_list

我正在尝试使用函数模板foo将参数转换为initializer_list。但是,它转换的initializer_list具有与输入参数不同的奇怪值。#include#include#include#includeusingnamespacestd;templatevoidfunc(std::initializer_lista_args){if(a_args.begin()!=a_args.end()){autolast=prev(a_args.end());copy(a_args.begin(),last,ostream_iterator(cout,","));coutstructfi