在C++中,this指针作为隐藏参数传递给方法,它实际上指向当前对象,但是“this”指针存储在内存中的什么位置......在堆栈、堆中,数据在哪里? 最佳答案 标准没有指定this指针的存储位置。当在函数调用中将其传递给成员函数时,一些编译器将其传递到寄存器中,而其他编译器将其传递到堆栈中。它还可能取决于编译器选项。关于您唯一可以确定的是this是一个基本类型的右值,因此您不能获取它的地址。并非总是如此。在准标准C++中,您可以分配给this,例如为了指示构造函数失败。这是在引入异常之前。指示构造失败的现代标准方法是抛出异常,以保
在具有几层的相当大的代码库中,有没有办法在vim或命令行中找到从基类派生的所有类?grep是一个选项,但可能会很慢,因为grep没有索引。 最佳答案 cscope和ctags都不允许我们直接处理继承,但是相对解决这个限制是很容易的,因为派生类也被索引了。控制范围在cscope中,寻找“C符号”Foobar通常会列出原始类和继承自它的类。由于搜索是针对数据库完成的,因此速度快如闪电。或者,您可以使用cscope的egrep搜索功能和类似:.*Foobar的模式来列出仅继承自Foobar的类。因此,即使我们没有专门的“查找继承自此类的类
根据以下测试:std::cout::value不是成员函数指针,而是普通函数,而这个:std::cout::value计算结果为真。我用gcc和msvc都试过了。这两个声明有什么区别?这些结果正确吗?为什么A::*周围的括号很重要? 最佳答案 intA::*()是函数类型,它返回A的int成员,不带任何参数。所以它不是成员函数指针,更不是函数指针。std::cout::value::value::value括号改变了优先级,int(A::*)()是A的成员函数指针类型,返回int并且不带任何参数。
考虑以下程序:#include#includeintmain(){std::this_thread::sleep_until(std::chrono::steady_clock::now()-std::chrono::seconds(10));return0;}当用GCC4.8.5编译时,它会挂起。用GCC4.9及以上或clang3.4及以上编译时,立即返回,为什么会挂?据我了解,GCC4.8.5完全支持C++11标准。 最佳答案 这是一个已确认的错误,已在gcc4.9中修复。https://gcc.gnu.org/bugzilla
让我们采用这个结构:structentry{atomicvalid;atomic_flagwriting;charpayload[128];}两个线程A和B以这种方式同时访问这个结构(让e成为entry的一个实例):if(e.valid){//dosomethingwithe.payload...}else{while(e.writing.test_and_set(std::memory_order_acquire));if(!e.valid){//writee.payloadonebyteatatime//(thepayloadwrittenbyAmaybedifferentfrom
#include#include#includeusingnamespacestd;intmain(){FILE*fPtr=fopen("english.txt","r");if(fPtr==NULL){coutfreq;while(!feof(fPtr)){fscanf(fPtr,"%s",word);freq[word]++;}multimapfreq_rev;map::iteratorit;for(it=freq.begin();it!=freq.end();it++)freq_rev.insert(make_pair(it->second,it->first));multima
我特别想到策略模式(设计模式,GoF94),其中建议传递给策略构造函数的上下文可以是包含策略(作为成员)本身的对象。但以下内容不起作用://analysis.hclassStrategyBase;classStrategy1;classStrategy2;classAnalysis{...voidChooseStrategy();private:StrategyBase*_s;...};//analysis.cppvoidAnalysis::ChooseStrategy(){if(...)_s=newStrategy1(this);elseif(...)_s=newStrategy2(
据我了解,[=]复制函数体内使用的所有变量,而[this]仅复制this指针。但是查看示例,我发现[=]被广泛使用,其中[this]或[this,foo]就足够了。是否有任何理由(例如性能提升)使用[this]而不是[=]? 最佳答案 没有性能提升,因为正如您所说,只有您在lambda中实际使用的变量会被复制用于[=]。†这主要是编码人员的懒惰和保持lambda头的简洁。如果您使用新变量,则必须扩展捕获子句以包含这些变量,等等。然而,有时,您希望/必须是明确的,例如当您想要混合按引用和按值捕获时。†请注意,目前,以下代码段中的[=]
对于类X的非const成员函数,this指针的类型为X*const。然后,成员函数的this指针始终为const。那么,我们是否总是需要像这样进行const转换:voidfoo::p(){const_cast(member)=1;}我是不是漏掉了什么? 最佳答案 ForanonconstmemberfunctionofclassX,thispointerisoftypeX*const.不,非const成员函数中的this指针的类型只是X*(而且它是一个右值)。但即使this是X*const,这仍然不会阻止您更改数据成员。您的代码示例
假设我有以下类(class):classfoo{public:intsomeNum;voidcalculation(intsomeNum);};定义:voidfoo::calculation(intsomeNum){someNum=someNum;}现在在someNum=someNum行中,指的是哪个someNum?如果我这样做:this->someNum=someNum那第二个someNum是什么?避免这个问题的好的命名风格是什么?例如,在objective-c中,在成员变量名前加上前缀“_”。(例如:_someNum); 最佳答案