草庐IT

TRANSPORT_INIT

全部标签

c++ - init-declarators 的完整表达式的定义

在init-declarator的情况下完整表达式的定义据说“包括”初始化程序的组成表达式,以及应用的任何转换/隐式调用的函数(构造函数)。这意味着完整表达式甚至不需要是表达式,这没有意义,因为它被称为一个(初始化声明符不是表达式)。进一步在标准中,完整的表达式被用作表达式,那么如果它可以包含不相交的表达式,甚至不是表达式的东西,那有什么意义呢?无论如何,我的主要问题是为什么不总是表达式的完整表达式被视为表达式?这应该如何运作? 最佳答案 Thismeansthatafull-expressionneednotevenbeanexp

c++ - std::begin 如何推导 braced-init-list 的类型?

以下代码失败:templatevoidfunc(T&t){}intmain(){func({1,2,3});}但是对于autoa={1,2,3};它是有效的,因为规则允许auto推导出一个std::initializer_list。std::begin如何编写以允许std::begin({1,2,3})工作? 最佳答案 std::begin({1,2,3})有效是因为std::begin有一个overloadtakinganstd::initializer_list. 关于c++-std

c++ - 这是未定义的行为还是 struct init 的错误?

请考虑这段代码:#includeintmain(){structA{intx;inty;intz;intfoo(){std::coutxyzxyzx=1;this->z=10;return2;}};Ab{b.foo(),b.z=b.moo(),3};std::cout我的VS2017(x64版本)中的结果:enterfoo:0,0,0entermoo:5,0,0final:1,2,3ideone.com(gcc6.3)的结果https://ideone.com/OGqvjW):enterfoo:0,0,3entermoo:5,0,3final:1,2,2一个编译器立即将z成员设置为3,

c++ - 链接错误 : undefined reference to EVP_CIPHER_CTX_ and EVP_CIPHER_CTX_init

我在我的代码中使用了crypto++。我不想使用它的依赖项,所以我尝试在我的文件夹中导入crypto++文件并将它们包含在我的.cpp文件中我有以下错误:TEST.cpp:(.text+0x89a0):undefinedreferenceto`EVP_CIPHER_CTX_init'TEST.cpp:(.text+0x8cb0):undefinedreferenceto`EVP_aes_128_cbc'TEST.cpp:(.text+0x8cdd):undefinedreferenceto`EVP_CipherInit_ex'TEST.cpp:(.text+0x8d49):undefi

c++ - P0960,在 c++20 中是否有任何类型的机制来检测新聚合 init 中是否有 ()s 缩小?

与P0960“允许从带括号的值列表初始化聚合”,您也可以使用()进行聚合初始化。但是,此初始化允许缩小,而{}不允许。#include#includestructFoo{intx,y;};intmain(){//autop=newFoo{INT_MAX,UINT_MAX};//stillwon'tcompileautoq=newFoo(INT_MAX,UINT_MAX);//c++20allowsnarrowingaggregatesinitstd::vectorv;//v.emplace_back(Foo{INT_MAX,UINT_MAX});//stillwon'tcompilev

c++ - (Swig to python)导入错误:dynamic module does not define init function

我正在尝试通过swig将我的C++代码移植到Python。当我完成py、pyd、cxx和lib文件的构建时,在Python(命令行)下,我键入“模块Dnld”,它显示->导入错误:动态模块未定义初始化函数。以下是我的代码,进一步:添加我的构建步骤以避免误解,谢谢MarkTolonen文件->新建->项目->Windows控制台应用程序->选择DLL和空项目(无unicode)将我的SerialComm文件夹添加到项目中(包括DownloaderEngine.hSerial.hPortEnumerator.h等)。配置属性->c/c++->附加包含目录->C:\Python27\incl

c++ - GCC 中的 __attribute__((init_priority(X)))

我在GCC中使用__attribute__((init_priority(X)))是这样的:Type1__attribute__((init_priority(101)))name1=value1;Type2__attribute__((init_priority(102)))name2=value2;在不同的源文件中。比方说file1.cpp和file2.cpp。如果我在同一个库中使用它,它会按预期工作,name1在name2之前初始化,但如果我在不同的库中使用它,则初始化顺序不是预期的顺序。我在gcc文档中读到这应该像我期望的那样在不同的库中工作,以定义初始化的顺序。我使用它的方式

c++ - Microsoft 的 GCC 选项 init_priority 是什么?

在编译和链接C++库或程序时,无法保证翻译单元之间静态C++对象的初始化顺序。GCCoffersinit_priority解决静态存档、共享对象和程序的问题:init_priority(priority)    InStandardC++,objectsdefinedatnamespacescopeareguaranteedto    beinitializedinanorderinstrictaccordancewiththatoftheir    definitionsinagiventranslationunit.Noguaranteeismadefor    initializ

c++ - 在 init 方法中绕过 const

所以我can'tuseinitializersinmyclassconstructor因为使用数组,所以我决定改用init()方法。现在我有一个不同的问题。我有这样一个类:classEPWM{private:volatileEPWM_REGS*constregs;public:voidinit(volatileEPWM_REGS*_regs);};我需要通过初始化regs=_regs;来实现init()但我不能因为const。有没有办法在我的init方法中强制分配?我想保留const关键字,这样我就不会不小心重新分配到别处。编辑:尽管我很想使用构造函数+初始值设定项来解决这个问题(我的

c++ - Braced-init-lists 和函数模板类型推导顺序

我有一个关于函数模板参数类型推导过程的问题。举个例子:#include#include#include#include#includeintmain(){std::ifstreamfile("path/to/file");std::vectorvec(std::istream_iterator{file},{});//如果我理解正确,第二个参数被推断为std::istream_iterator类型其中调用了默认构造函数。适当std::vector构造函数声明为:templatevector(InputIteratorfirst,InputIteratorlast,constalloca