草庐IT

const_set

全部标签

c++ - 制作一个 const unique_ptr 然后尝试从它 std::move 给出相同的错误,就好像您试图访问复制构造函数一样

当我们尝试复制unique_ptr(例如,将一个唯一指针分配给另一个)时,我注意到错误是ErrorC2280std::unique_ptr#includeintmain(){std::unique_ptra=std::make_unique(2);std::unique_ptrb=a;}没关系,因为unique_ptr没有定义复制构造函数。您不会从唯一指针进行复制以在它们之间move(转移指针的所有权)。有趣的是(好吧,也许不是),这段代码抛出了同样的错误。现在我知道它是无效的(我将第一个unique_ptr声明为不可变对象(immutable对象)),但错误消息暗示它正在尝试调用复制

c++ - 为什么我不能使用与 'const int*' 相同的 'const char*' 创建一个 int 数组?

为什么我可以用这种方式创建一个字符串或字符数组:#includeintmain(){constchar*string="Hello,World!";std::cout?并且它正确输出第二个元素,而如果没有数组的下标符号[]我就不能创建整数类型的数组?char的一个和这个有什么区别:constint*intArray={3,54,12,53};。 最佳答案 “为什么”是:“因为字符串文字很特殊”。字符串文字存储在二进制文件中,作为程序本身的常量部分,constchar*string="Hello,World!";只是将文字视为存储在别

c++ - 为什么 const 变量是可修改的?

我正在阅读一本关于运算符重载示例的教科书,它让我想知道如何通过“常量值”返回(例如使用operator+)。据我了解,如果我以const形式返回任何内容,则以后无法对其进行修改。假设我有这个粗略的例子:#includeusingnamespacestd;classTemp{private:intval;public:Temp(){};Temp(intv):val(v){};constTempoperator+(constTemp&rhs)const{returnTemp(this->val+rhs.val);}intgetVal(){returnthis->val;}voidsetVa

c++ - 非常量调用 const 成员函数失败,只读位置 C++

正在关注thispost我实现了一个访问器,比如templateclassqv{virtualconstT&operator[](inti)const=0;T&operator[](inti){returnconst_cast(static_cast(this)->operator[](i));}};templateclassqq:publicqv{public:constT&operator[](inti)constoverride{returnthis->data[i];}protected:Tdata[5];};但是在尝试做类似的事情时得到一个只读位置的分配:intmain(in

c++ - std::map::const_iterator 泄露了对值的非常量引用?

我观察到std::map::const_iterator泄漏了对value_type的非常量引用:#include#includeintmain(intargc,char*argv[]){std::mapfoo={{1,1},{4,2}};constauto&m=foo;constauto&it=foo.find(1);printf("%d%d\n",it->first,it->second);int&i=it->second;i=3;auto&one=foo.at(1);printf("%d%d\n",1,one);return0;}输出$g++test.cc&&./a.out111

c++ - 你能初始化 unique_ptr 的 "static const vectors"吗? (C++17 与 GCC 7.3)

我正在尝试创建一个staticconst默认对象(规则)的列表太大而不能经常复制,因此我想将它们存储在vector中的unique_ptr.我注意到类似的问题已经进行了几次,但我不清楚这是否真的可行(我倾向于不可行)。即你不能使用initializer_list与unique_ptr因为对成员的访问是const导致复制操作。您不能通过引用传递临时变量,从而导致复制操作。因此两者:staticconststd::vector>kStrings={std::unique_ptr(newstd::string("String1")),std::unique_ptr(newstd::strin

c++ - 为什么 std::set 中的项目不能为 'popped' ?

我知道std::set不允许非常量访问它的项。我知道不可能将项目移出集合——因为任何类型的非常量访问都可能破坏集合的顺序。但是,我们可以从集合中删除一个项目。这不会破坏它,因为它只是迫使集合进行重组。那么为什么我们不能“弹出”一个项目呢?为什么我不能取出项目并同时将其删除?我问的原因是-我需要一个有序的unique_ptrs容器。有时我需要从一个容器中“弹出”unique_ptr并将它们转移到另一个容器中。它们必须是我制作的自定义仿函数。我不明白为什么不允许弹出功能? 最佳答案 要从std::set中提取节点,您可以使用extrac

c++ - 如何在 C++ 中将 const ref a 返回给局部变量?

我有一个无法更改函数参数的函数。我需要返回对在此函数中创建的std::string的const引用。我尝试使用boostshared_ptr,但这不起作用。为什么?我该如何进行这项工作?conststd::string&getVal(conststd::string&key){boost::shared_ptrretVal(newstd::string());...//buildretValstringwith+=operatorbasedonkeyreturn*retVal;} 最佳答案 您不能使用C++从函数返回对局部变量的引用

c++ - 使用构造函数向 std::set 插入一个元素

是否可以向std::set插入一个新元素,例如std::list的情况://插入一个名为“string”的元素到mylist的子列表std::list>mylist;mylist.push_back(std::list(1,"string"));现在,mylist在它的std::list类型的子列表中有一个std::string类型的元素。如果std::set是std::list的子集我的列表即std::list>mylist;如果你不能,那为什么不呢? 最佳答案 我认为这应该可以解决问题:intmain(){strings="te

c++ - 在 set<int> 与 vector<bool> 与 vector<boolean_t> 之间进行选择以用作位图(位集/位数组)

给定一系列索引(标识符),我想将每个索引映射到一个bool值,即://interfacepseudocodeinterfacebitmap{boolidentifier_is_set(unsignedintid_idx)const;voidset_identifier(unsignedintid_idx,boolval)const;};这样我就可以设置和查询每个ID(索引)是否已设置,您更喜欢用什么来实现它?我认为这叫做位数组或位图或位集,如果我错了请纠正我。假设最大标识符是预先确定的并且不大于1e6(1m),可能更小(10k-100k)。(这意味着sizeof(int)*maximu