草庐IT

Constants

全部标签

指针函数/const 指针函数的 C++ 模板部分特化没有区别吗?

让我们考虑以下代码:templateclassFoo{};templateclassFoo{};templateclassFoo{};当我尝试编译它时(ideone)它没有告诉我这两个模板特化是相同的。这是令人惊讶的,因为通常U*和U*const是不同的东西(第二个是const指针)。这里有什么问题吗? 最佳答案 在确定函数的类型(通俗地称为其签名)时,将删除顶级cv限定符。§8.3.5/5...Thetypeofafunctionisdeterminedusingthefollowingrules....Afterproducin

c++ - const 参数值为 0 的重载决策不正确

我有一个类B,它有两个重载函数intSet(B*);和intSet(constA&);。A类需要一个构造函数参数unsignedchar。当使用值为0的constunsignedchar调用Set时,它被解析为Set(B*)而当传递的值不为零时,它解析为Set(constA&)(按照我的预期)。重载解析在非constunsignedchar上正常工作,但在值设置为0的constunsignedchar上失败。为什么?以下代码说明了使用const和非constunsignedchar调用Set时的差异#includeusingnamespacestd;classA{charm_byteV

c++ - 如果方法是const,如何找到 vector 的中值?

我创建了一个名为Collect的方法,它将一堆值添加到vector中(如下所示)voidMedian::Collect(doubledatum){myVector.push_back(datum);}我需要创建一个方法来计算我在上述方法中收集到的vector中的所有值的中位数。函数定义写在下面/*Calculatesthemedianofthedata(datum)fromtheCollectmethod.*/doubleMedian::Calculate()const{}所以我知道我首先需要对vector进行排序才能找到中位数。以下是我的尝试:doubleMedian::Calcul

c++ - 如何在 C++ 的构造函数中定义一个 extern const

两个config.json文件包含我想要存储到常量中的值。我的计划是在相应类的构造函数中加载并解析json文件,并将值赋值给常量。但是,在Debug模式下,出现“...LNK2019:unresolvedexternalsymbol...”的错误。那么,是不是不能在构造函数中定义常量呢?由于常量的值取决于变量VARIANT,我创建了一个ifelse来读取正确的.json文件。//constants.hexternconstintBARL;externconstintBAR_TOL;//constants.cppConstants::Constants(){Json::Readerrea

c++ - const 到非常量 c++

这可能吗:将常量变量变为非常量我正在创建一个全新的字符串类,我的构造函数如下所示LString(constcharstring1[]){/*whateverIdo*/}我不会放置const关键字,但这是我获得类似字符串的唯一方法LStringls="astring";我会有很多函数来修改这个字符串即使我复制了这个字符串,我仍然无法将const转换为非const有可能吗如果没有,谁能想到漏洞好吧,有些人说没问题,这是我的代码#include#includeusingnamespacestd;classLString{public:LString(constcharstring1[]){c

C++0x decltype 推导成员变量常量失败

考虑以下代码:templateclassB{};templateBf(T&t){returnB();}classA{classC{};Cc;public:A(){}decltype(f(c))get_c()const{returnf(c);}};intmain(){Aa;a.get_c();}当我尝试编译它时,出现错误:test.cpp:Inmemberfunction'BA::get_c()const':test.cpp:31:46:error:conversionfrom'B'tonon-scalartype'B'requested似乎在decltype中,编译器不知道这是一个co

使用 shared_ptr 到 const T 的 C++ 模板实例化

假设我有一个类templateclassA{public:templatevoidf(std::tr1::shared_ptr>v1,std::tr1::shared_ptr>v2){}};以下不编译:Aa;std::tr1::shared_ptr>v1(newstd::vector());std::tr1::shared_ptr>v2(newstd::vector());a.f(v1,v2);编译错误是:error:nomatchingfunctionforcallto'A,std::allocator>>::f(std::tr1::shared_ptr>>&,std::tr1::s

c++ - 将 args 作为对具有(无)常量性的指针的引用传递给不同的地址

voidf(char*&pch){cout给出下一个输出:0xbfa0d62c12345678900xbfa0d62c1234567890但如果我将第一行修改如下voidf(charconst*const&pch){我会得到:0xbfec7df812345678900xbfec7dfc1234567890是否因为需要将新的内存单元标记为const或其他原因而出现指针差异? 最佳答案 pch2是一个char*,而不是一个charconst*。您不能将charconst*&类型的引用绑定(bind)到char*类型的指针,因此以下格式不

c++ - 编译器如何决定调用哪个函数?

假设String类中有两个重载的成员函数(一个const版本和一个非const版本):char&String::operator[](inti)//Version1{cout还有一段测试代码片段intmain(){Stringa;cout编译器如何决定调用哪个函数?我发现运行程序时总是会调用版本1。谁能告诉我这是为什么?如何调用版本2? 最佳答案 如果a是const,将调用第二个重载。intmain(){constStringa;cout 关于c++-编译器如何决定调用哪个函数?,我们在

c++ - 警告 C4180 : qualifier applied to function type has no meaning; ignored

我已经设置了编译器/Za选项来禁用语言扩展,以便编译器严格使用标准ISOC++。这是我收到以下警告的示例接口(interface)类warningC4180:qualifierappliedtofunctiontypehasnomeaning;ignored这是关于函数返回类型中的const限定符,如果我删除const,警告就会消失,但我不想这样做,我想重新启用lanqage扩展。我的问题是:这个警告合理吗?如果不是,那么我将使用pragma禁用警告,但在此之前我想确保此警告是“误报”因为下面的类是正确的ANSIISOC++不是吗?所以警告应该被禁用?classIBet{public: