草庐IT

const_object

全部标签

c++ - 为什么不允许将右值引用绑定(bind)到非 const 引用,但允许在一个上调用非 const 成员函数

就危险性而言,以下内容大致相同,但语言不允许使用后两个,而第一个则不是。#include#includeintmain(){std::vectorv;//allowedstd::vector().swap(v);//notallowedv.swap(std::vector());//notallowedstd::swap(std::vector(),v);}我知道VisualStudio允许所有这些作为编译器扩展通过,我忽略了这个问题。我实际上并不是在争论第一个是不允许的——我实际上更喜欢第二个是允许的(有些地方这会使代码更优雅,通常当C++允许你做一些可能很危险但让它通过可能是有益的

c# - 什么是 C++ const 引用返回值的 c# 模拟

我确实为类成员编写了C++访问器SomeClassconst&x()const{returnm_x;}似乎在C#中这种类型的唯一保护是使用私有(private)(或未定义)集定义属性。但这只能防止分配,不能防止对某些类状态的操纵。旁注:c++允许通过const指针删除m_x-恕我直言,这简直是对标准主体的惊人监督。 最佳答案 现在,在C#7.2中,您可以使用refreadonly来达到同样的目的。您可以查看更多信息here.检查第三点。 关于c#-什么是C++const引用返回值的c#模

c++ - const 指针和 const 数组的输出

当我们有两个运算符用于输出对象和这些对象的数组,并尝试输出常量对象数组时,就会涉及到对象运算符。有没有办法强制数组的运算符与常量对象的c数组一起使用?示例代码:#include#includeusingstd::size_t;namespacenm{structC{inti;};templateusingc_c_array=C[N];inlinestd::ostream&operatorinlinestd::ostream&operatorconst&){returnlhs输出:1211此外,在我的例子中,2运算符使用1作为输出。 最佳答案

c++ - Q_OBJECT 和 moc 用于继承

我在一个项目中工作,其中在我需要继承的类中使用了Q_OBJECT宏。已经定义了Q_OBJECT的类如下所示,classcBaseObject:publicQObject,publiccinformation{Q_OBJECT//...//...}我正在通过cBaseObject的公共(public)继承创建一个新类。我是否需要再次编写Q_OBJECT宏?我尝试使用和不使用该宏,如果我不包含QT_MACRO,我没有看到生成moc_XXX.cxx文件classcEnhancedbaseObject:publiccBaseObject{Q_OBJECT//ifididn'tincludeth

c++ - "Naked function cannot contain objects that would require unwinding..."静态初始化变量

我在使用VisualStudio15编译某些东西时遇到了问题。这段代码说明了这一点:constchar*getx(){return"foo";}void__declspec(naked)nf(){staticconstchar*x=getx();}失败并出现以下错误:错误C3068“nf”:“裸”函数不能包含在发生C++异常时需要展开的对象。不过,我真的不明白为什么会失败;静态对象不是自动的,就存储而言,它们的行为或多或少像全局对象,并且在执行入口点之前被初始化(据我所知)。如果是这样,那么这条消息指的是什么展开?此时堆栈上没有任何内容,所以没有什么可以放松的。此外,如果我删除函数调用

c++ - QTimer::singleShot(0, object SLOT(obj_slot())) 是做什么的?

我是学习Qt的初学者,并试图理解提供的Qtexample用于下载操作。在downloadmanager.cpp,成员函数如下:voidDownloadManager::append(constQUrl&url){if(downloadQueue.isEmpty())QTimer::singleShot(0,this,SLOT(startNextDownload()));downloadQueue.enqueue(url);++totalCount;}我很困惑,为什么如果downloadQueue为空,则需要在添加url之前激活startNextDownload()。(注意:如果down

c++ - 返回填充在函数内部的 const char* vector 是否是明确定义的行为

我目前正在学习vulkan。在其中一个教程中,我看到了一个大致执行以下操作的函数:#defineSOMESTRING"HelloWorld!"std::vectorbuildVector(){std::vectorvec;vec.push_back(SOMESTRING);returnvec;}当我看到这个时,我想知道:这是定义的行为吗?字符串"HelloWorld!"的内容不是位于堆栈中,因此一旦函数返回就无效了吗?如果这是未定义的行为,那么正确的方法是什么?不幸的是,由于vulkanAPI,无法使用std::string。 最佳答案

c++ - 在 C++ 中将 char* 转换为 const char*

C++中如何将char*转换为constchar*?为什么程序1可以运行而程序2不能运行?程序1(工作):char*s="teststring";constchar*tmp=s;printMe(tmp);voidprintMe(constchar*&buf){printf("GivenStr=%s",buf);}程序2(不工作)char*s="teststring";printMe((constchar*)s);//typecastingnotworkingvoidprintMe(constchar*&buf){printf("GivenStr=%s",buf);}我收到的错误:x.c

c++ - 将 zlib 与 const 数据一起使用

要使用zlib压缩/解压缩数据,首先我需要设置一个名为z_stream的结构.z_stream有两个非常量指针叫做next_in和next_out.如果我想做这样的功能:voidungzip(std::vector&dst,conststd::vector&src){z_streamstrm;//morecode}和其他类似的voidgzip(std::vector&dst,conststd::vector&src);我该怎么办?在本地复制srcstd::vectorstd::vectortmp(src);并像这样将其用作源或设置指针,strm.next_in=const_cast(&

c++ - 为什么别名 int& 允许创建非函数类型 const (int&)?

通常在使用常量引用时会出现编译器错误,但在使用别名或使用模板时不会。为什么会这样?inta=5;usingmy_t=int&;my_tconstb=a;//#1OKint&constc=a;//#2Compilererror当运行最新的clang编译器(x86-64clang(实验性P1144))时,#1给我警告:[x86-64clang(experimentalP1144)#1]warning:'const'qualifieronreferencetype'my_t'(aka'int&')hasnoeffect[-Wignored-qualifiers]#2给出了错误:[x86-64