草庐IT

EidosValue_Int_vector

全部标签

c++ - std::vector 类型引用的无效初始化

这是错误:DummyService.hpp:35:error:invalidcovariantreturntypefor'virtualstd::vector>&DummyService::list(conststd::string&)'classBean{public:typedefstd::stringPath;virtual~Bean(){};virtualconstPath&getPath()=0;virtualconststd::string&getName()=0;protected:Bean();};classResourceBean:publicBean{public:

c++ - boost::ptr_vector 对比 std::vector<std::unique_ptr<T>>?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。他们做类似的事情。在两者之间进行选择时应该考虑什么?在哪种情况下,哪一个是首选?

c++ - 检测具有范围的 vector 数组中的弧形和圆形

我有一个二维顶点数组,我想检测数组中是否有任何拱形或圆形。有时这些值不是那么精确,我需要一个小范围。这是值(value)观。第3个verticlevalue值保持0:verticle:-0.014848,-13.2684,0angle:0.141274verticle:-0.0174556,-4.84519,0angle:90verticle:0,0,0angle:90verticle:-9.53674e-07,14.14,0angle:40.7168verticle:-12.1101,14.0709,0angle:7.94458verticle:-12.0996,10.6442,0a

c++ - 从原始内存位置 memcpy 到 vector<wchar_t>

我正在使用一个API,它在内存中提供感兴趣的字符串的内存地址和长度。我想将这些字符串读入更友好的对象,如wstring。对于较小的字符串,静态大小的缓冲区使用以下代码可以正常工作://Thiscodeworks(butmayhaveotherissues)//_stringLengthOffsetand_bufferOffsetareprovidedearlierbytheAPI//stringOIDisthememorylocationofthestring(andintermsoftheAPI,theObjectID)DWORDstringLength;memcpy(&string

c++ - vector<int> 上的 memset

根据MarkRansomsanswer关于使用memset,我在vector上使用memset为所有元素赋值。memset(&match_begin[0],0xff,sizeof(match_begin[0])*match_begin.size());它确实比std::fill有了显着的性能提升它工作正常(g++4.3.2、64位linux)。这段代码是否安全,如std::vector实现是否始终保证数据的内存分配是连续的?是否有可能在STL库的future(或不同的)实现中,这可能会改变并在以后破坏我的代码? 最佳答案 would

c++ - 迭代器可以在 C++ 中的 vector 之间共享吗?

在c++中,如果我有两个数组a[10]和b[10],我可以引入一个索引i可以用于两个数组指向第(i+1)个元素,a[i]和b[i]。迭代器是否也可以共享,或者我需要做类似的事情:vectora;vectorb;//assumebothareinitiatedandsamevector::iteratori;//assumeprogramknowi=10and*i=20invectoravector::iteratorj=b.begin();for(;j!=b.end();j++){if(*j==*i){break;}}然后我得到迭代器j,它指向相同的位置但在vectorb中?我可以简单

c++ - 为什么 "unsigned int ui = {-1};"是缩小转换错误?

标准§8.5.4/7解释了什么是缩小转换:Anarrowingconversionisanimplicitconversion—fromafloating-pointtypetoanintegertype,or—fromlongdoubletodoubleorfloat,orfromdoubletofloat,exceptwherethesourceisaconstantexpressionandtheactualvalueafterconversioniswithintherangeofvaluesthatcanberepresented(evenifitcannotberepres

C++ 将 long、short 和所有 int 转换为 uint32_t、int32_t 等等有帮助吗?

我运行着一个使用C++编码的游戏服务器,其中还有一些ASM和C。我看到有人更新了我运行的同一台服务器,在所有更新中,所有int、unsigned、short和其他所有内容都已更改为int32_t、uint32_t、uint64_t和其他内容。全部改成上面说的有什么好处吗?假设我将所有int更改为int32_t,并将所有unsignedint更改为uint32_t,当然还有所有其他可能更改的内容。我试图阅读和理解是否有任何好处,但我根本没有理解它们的真正含义。所以,是的,问题是:按照我刚才所说的去做有什么好处吗?我使用的编译器是OrwellDev-C++ 最佳

c++ - 在 C++ 中将字符串 vector 转换为 char 数组

我正在尝试将字符串vector转换为C++中的字符数组。更具体地说,我正在尝试做的是使用以下命令拆分一个shell命令,例如“ls–latr”:istringstreamf(x);while(getline(f,x,'')){strings.push_back(x);}我相信这会给我strings[0]=="ls"和strings[1]=="-latr"。然后我正在尝试执行以下操作:execvp(strings[0],strings);但是,我得到这个错误:error:cannotconvert‘std::basic_string,std::allocator>’to‘constcha

c++ - std::list<int> 的默认构造函数可以抛出吗?

我(快速)查看了C++标准和在线C++引用,但找不到这个简单问题的答案:可以std::list的默认构造函数吗?扔?如果是这样,为什么会抛出? 最佳答案 简短回答:它可以,但它可以以相当安全的方式实现:默认构造函数构造了一个空列表,因此几乎不需要在进程中实际分配内存。大多数列表实现不会为空列表分配任何内存。但是,默认构造函数不是真正默认构造函数,因为它有一个默认参数:explicitlist(constAllocator&=Allocator());Allocator本身是一个模板参数,因此如果Allocator有一个足够笨(或复杂