我有一个对象,在最基本的层面上看起来像这样:#includeclassx_link{public:x_link(){display_=XOpenDisplay(NULL);}~x_link(){XCloseDisplay(display_);}Display*display_ptr()const{returndisplay_;}private:Display*display_;};我想知道在这种情况下“const”x_link::display_ptr()应该如何。这个老问题,Shouldmemberfunctionsbe“const”iftheyaffectlogicalstate,
我目前正在为我的类(class)写一个作业,它应该充当一个非常基本的外壳。我快完成了,但是我遇到了execvp和我的参数字符数组的问题。这是我的代码的一小段。//Splittheleftcontentargsistringstreamiss(left);while(getline(iss,s,'')){v.push_back(s);}//Getthesplitstringandputitintoarrayconstchar*cmd_left[v.size()+1];for(unsignedinti=0;i这被...利用了execvp(cmd_left[0],cmd_left);我的错误
C++中何时需要constvolatile对象?注意:我确实理解指针到constvolatile内存位置的必要性,但这些并不要求对象本身是const或volatile。我问的是一些constvolatile类型的自身对象,例如:constvolatileTobj;这些在哪些情况下是必要的或有用的? 最佳答案 在C++中实际需要volatile的情况很少见。volatile对多线程不再有用。来自thiswebsitevolatile只有三种可移植用途。HansBoehmpointsoutthatthereareonlythreepor
我正在尝试优化我为处理应用程序协议(protocol)的多个层而编写的一些代码。我自由使用了std::string类,力求简单而不是过早的优化。该应用程序太慢了,valgrind和gprof显示我花费了大量时间来复制构造字符串,因为缓冲区在我的堆栈中向上移动。在我看来,在将字符从系统缓冲区复制到我的最低应用程序缓冲区之后,我应该能够避免再复制数据:毕竟,它在堆栈向上移动时不会发生变化。我的协议(protocol)格式是一个“传输”,由一个或多个以换行符结尾的记录组成,每个记录由几个制表符分隔的字段组成,并以特殊的结尾token。例如RECORD1\tHAS\tTHESE\tFIELDS
为了试验线程清理器,我创建了一个微型C++程序,它有意包含一个数据竞争。确实,tsan确实检测到错误,太棒了!但是我对生成的消息感到困惑......它报告了一个写-写数据竞争,而我原以为是一个读-写竞争。我希望find()不会写入我的容器。如果我做进一步的小代码调整,试图获得set::find()的const版本,似乎仍然存在相同的写-写竞争。它显示了在同一地址的4字节原子写入和8字节写入之间的写入冲突。容器类中的同一个字段被两种不同的访问类型访问,这似乎很奇怪。是否可以选择使用不写入STL容器的constfind()?这是经过测试的C++程序:/*******************
C++11x标准更改了“const”关键字的语义。现在它意味着真正的线程安全。据我了解,const成员变量等于javafinal字段。我想在CPUicore7G++4.7.1上检查。我使用as-std=c++0x-pthread-DCONST和不使用编译了以下代码。两个可执行文件是相同的。汇编版本没有*fence指令。我希望在构造函数的末尾看到*fence。classBig{public:#ifdefCONSTconst#endiflonga;Big(longa):a(a){}voidcheck()#ifdefCONSTconst#endif{assert(a==123L);}};in
我尝试编写一个迭代器,通过索引遍历容器。It和一个constIt两者都允许更改容器的内容。Const_it和一个constConst_it两者都禁止改变容器的内容。在那之后,我尝试写一个span在一个容器上。对于类型T这不是const,两者都是constspan和span允许更改容器的内容。两者constspan和span禁止改变容器的内容。代码无法编译,因为://*thisisconstwithinaconstmethod//ButItrequiresanon-const*thishere.//SothecodedoesnotcompileItbegin()const{returnI
classFrame表示像素类型为P的图像.由于底层数据缓冲区格式的多种灵active,遍历其像素的算法并非易事。template//Pispixeltype;RM=is_row_majorclassFrame{//...templatevoiditerate(Ff){//iterateinawaythatisperformantforthisbufferif(stride==(RM?size.w:size.h)){auton=size.area();for(index_tk=0;k(stride)*(RM?size.h:size.w);for(index_tk0=0;k0我希望能够同
我想实现一个简单的nativeC++固定容量数组模板类,为了方便起见支持基于范围的“foreach”语法,开销最小。我在const实例上支持它时遇到问题。有了这个实现:templateclassList{public:List(){mSize=0;}constT*begin()const{returnmItems;}constT*end()const{returnmItems+mSize;}T*begin(){returnmItems;}T*end(){returnmItems+mSize;}private:size_tmSize;TmItems[Capacity];};和这种用法:c
这是我关于堆栈溢出的第一篇文章,我希望将来能加入社区。我正在为ADT类编写哈希表实现;我的大部分方法都在作业范围内达到了标准,但这让我很伤心。在这个我一直用来测试我编写的各种函数的测试应用程序中,我收到错误“errorC2662:'customer::getPhone':cannotconvert'this'ponterfrom'constcustomer'to'customer&'引用行“光标=find_ptr(entry.getPhone());”和“list_head_insert(data[hash(entry.getPhone())],entry);”我的函数实现代码如下:t