草庐IT

is_const

全部标签

c++ - 为什么这会在 const 方法中返回一个 const X* const 指针?

我在理解以下错误时遇到了麻烦:Error1errorC2440:'=':cannotconvertfrom'constX*const'to'X*const'我正在尝试使用指向const指针的指针在树遍历期间跟踪节点:boolIsValid()const{X*const*previousNode=newX*;returnthis->IsValid(previousNode);}boolIsValid(X*const*previousNode)const{...if(!*previousNode)*previousNode=this;//Error...returntrue;}为什么thi

c++ - 转换为 const vector

我手头有一些Foo的vector,我想将它转换成一个Bar的vector,以及一个const的vector.我能想到的最好的方法是:Barfoo2bar(constFoo&foo);std::vectorfoos={...};conststd::vectorbars=[&foos]{std::vectorbars;bars.reserve(foos.size());std::transform(foos.cbegin(),foos.cend(),std::back_inserter(bars),foo2bar);returnbars;}();我认为lambda的返回值应该被大多数编译器

C++/QML : ListView is not updated on dataChanged signal from QAbstractListModel

我正在尝试为大型动态C/Fortran模拟编写QMLGui。我要显示的数据存储在FortranCommonblock中,并按固定时间步长更新。我的问题是QMLListView在每个时间步后发出dataChanged信号时不会刷新,尽管Gui接收到该信号(测试在下面的代码中)。我可能错过了一些非常明显的东西,因为当我再次向下和向上轻弹我的ListView时,显示的数据已更新且正确(我猜是因为QML引擎会在元素“看不见”并返回时重新呈现它们再次进入)。所以唯一不起作用的是每次收到dataChanged信号时ListView都会更新,而不仅仅是在重新呈现时更新。下面是对我的方法和相关代码部分

c++ - 未对齐的内存访问 : is it defined behavior or not?

这个问题在这里已经有了答案:Whatdoesthestandardsayaboutunalignedmemoryaccess?(1个回答)关闭4年前。考虑以下代码:#includeintmain(){char*c=newchar('a');charac[4]={'a','b','c','d'};unsignedlonglongint*u=reinterpret_cast(c);unsignedlonglongint*uc=reinterpret_cast(&ac[3]);*u=42;*uc=42;std::cout这是否被视为有效代码,还是内存泄漏/未定义行为?我在问,因为通过:*u=

C++ - 方法和重载中的 const 关键字

为什么这个程序:#includeusingnamespacestd;classBase{public:Base(){coutfoo(12.0);base_ref.foo(7);base_ptr->bar(1.0);derived_ptr->bar(1.0);derived.bar(2);return0;}在调用base_ptr->bar(1.0);中调用Base::bar(double),而不是在derived_ptr->bar(1.0);被称为Derived::bar(double)const。我知道这是关于const关键字的,但我不明白为什么编译器会选择不同的重载函数。如果我删除c

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++ - C++中的继承, "...is an ambiguous base of ..."错误

如“TheC++ProgrammingLanguage3.Edition-BjarneStroustrup”中所写。我们可以使用范围解决方案来防止歧义错误。下面的基本程序,当我在类混合中使用3层范围时,会发生错误。但是当我使用2层时没问题。怎么了?还是像设计问题?错误是;deneme.cpp:Inconstructor‘mix::mix(std::__cxx11::string,int)’:deneme.cpp:45:22:error:‘plane’isanambiguousbaseof‘mix’pervaneli::plane::engine=b;我不想制作钻石模型。我对两个基础(平

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