草庐IT

c++ - 抽象类和运算符!= 在 C++ 中

我在从抽象类派生的集合类中实现operator!=时遇到问题。代码如下所示:classAbstract{public://tomakethesyntaxeasierlet'susearawpointervirtualbooloperator!=(constAbstract*other)=0;};classImplementation{SomeObjectimpl_;//thatalreadyimplementtheoperator!=public:booloperator!=(constAbstract*other){returndynamic_cast(other)->impl_!=

C++:const char * 到 stringstream

是否可以将constchar*放入字符串流中?假设size是我的constchar*变量:stringstreams;s.write(temp,size);如何获取尺寸?谢谢。 最佳答案 我测试了它,它工作正常......#include#includeusingnamespacestd;intmain(){stringstreams;constchar*token="HELLO";s 关于C++:constchar*到stringstream,我们在StackOverflow上找到一个

c++ - Qt - QList 常量正确性

AQList不容易成为常量正确的。考虑函数voidf(QListlist){list[0]->constFunction();}我可以把f改成voidf(QListlist)但是我做不到f(QList());//Compileerror不再,因为编译器不能隐式转换QList至QList.但是,我可以明确地重新解释-转换QList,如下所示:templateinlineQList&constList(constQList&list){return(QList&)list;}这使我能够使用constList用于转换任何QList的模板函数进入QList,如f(constList(QList

c++ - 改变 const std::string 引用的引用

我正在研究C++中的引用,并注意到一些我无法解释的奇怪行为。我的理解是,如果我有一个非常量变量和对同一变量的const引用,然后修改非常量变量,该引用应该反射(reflect)该修改。例子:voidfoo(){intx=5;constint&y=x;x=10;std::cout为我生成以下输出:x=10y=10但是,如果我将类型更改为std::string,const引用似乎不会反射(reflect)修改后的变量:voidfoo(){std::stringx="abc";conststd::string&y=x;x="xyz";std::cout为我生成以下内容:x=xyzy=abc这

c++ - 具有智能指针的虚拟构造函数习语

我有一个多态类的层次结构,比如Shape抽象基类及其派生类,例如Rectangle、Circle等。在VirtualConstructorIdiom之后,我想知道为什么在使用智能指针时,派生类中的虚构造函数的返回类型应该返回与其父类相同的类型?例如,看下面的代码,其中clone()和create()成员函数需要返回smart_pointers到Shape类。但是,当使用简单指针时,返回类型可以与派生类的类型相同。谁能解释为什么我们需要以引用的方式处理这些功能?classShape;typedefstd::unique_ptrshape_ptr;classShape{public://t

c++ - 当我在 C++ 中将临时 int 分配给 const 引用时会发生什么?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Doesaconstreferenceprolongthelifeofatemporary?假设我有一个函数f:intf(intx){returnx;}constint&a=f(1);我知道f(1)只是一个临时的,我会在这条语句之后被销毁,但是将引用设为const会使f(1)的生命周期更长吗?如果是,f(1)将存储在哪里?这是否意味着x在超出范围时也没有被销毁?f(1)和x有什么区别?

c++ - 无法将 'LPCWSTR {aka const wchar_t*}' 转换为 'LPCSTR {aka const char*}

我一直在尝试让Glew和opengl3.2在win32上下文中使用代码块(minGW)。我找到了一个不错的小教程here因为我一直在努力弄清楚在代码块中编译glew是否真的可行,所以我想在学习教程之前先试用一下源代码,看看它是否可行。在稍微调整代码后,我尝试编译并遇到了几个我以前从未见过的错误。它们如下|Infunction'boolcreateWindow(LPCWSTR,int,int)':||73|error:cannotconvert'LPCWSTR{akaconstwchar_t*}'to'LPCSTR{akaconstchar*}'inassignment||80|erro

c++ - 为什么参数修饰符(即 'const' 或 'volatile' )不被视为函数类型或签名的一部分?

请注意,以下两个函数具有相同的类型和签名:voidfoo1(intt){}//foo1hastype'void(*)(int)',andsignature'(*)(int)'voidfoo2(constintt){}//Alsotype'void(*)(int)',signature'(*)(int)'(const不是函数类型或函数签名的一部分)。同样,返回类型上的修饰符(const或volatile)不会影响函数类型或函数签名。但是,在函数定义本身(未显示)中,命名变量t确实在foo2中保持const资格。有许多StackOverflow问题在讨论为什么函数的返回类型不被视为函数签名

c++ - 为什么非 const、非 int/enum 静态数据成员必须在定义之外初始化?

我知道只有静态、常量和int/枚举(c++11之前)的数据成员才能在类声明中初始化。“所有其他静态数据成员必须在全局命名空间范围内定义(即在类定义的主体之外)并且只能在这些定义中初始化”。为什么不能在类定义中初始化其他静态数据成员?是否有具体原因禁止这样做?如果数据成员特定于类,为什么它们在全局命名空间范围内声明,而不是在与其类相关的某些范围内声明? 最佳答案 Whycan'totherstaticdatamembersbeinitializedintheclassdefinition?Wasthereaspecificreason

c++ - 带有返回 const 引用的隐式转换运算符的类的 static_cast<> 行为

我有以下类(class)(精简后只包含相关部分):#includeclassText{private:std::string_text;public:Text(std::string&&text):_text(std::move(text)){}operatorconststd::string&()const{return_text;}};我的问题是:如果我想获得一个conststd::string&,我可以这样做而不会受到任何惩罚吗:Texttext("fred");auto&s=static_cast(text);或者这会构造一个我最终得到引用的中间std::string吗?这种情