草庐IT

二级指针

全部标签

c++ - 将指针转换为整数是否定义了指针的总顺序?

(与mypreviousquestion相关)在QT中,QMapdocumentation说:ThekeytypeofaQMapmustprovideoperatorspecifyingatotalorder.然而,在qmap.h,他们似乎使用类似于std::less的东西比较指针:/*QMapusesqMapLessThanKey()tocomparekeys.ThedefaultimplementationusesoperatorinlineboolqMapLessThanKey(constKey&key1,constKey&key2){returnkey1inlineboolqM

c++ - C/C++ : What's faster: a for loop, 或递增指针

我想知道以下哪个代码段最快,假设目标是从T类型的元素中读取数量为numElements的somePointer并用它们做一些事情。我特别感兴趣的是循环结构本身的效率,而不是对元素所做的事情。第一候选人for(inti=0;i第二个候选人T*tempPointer=somePointer;T*endPointer=somePointer+numElements;while(tempPointer当然,第一个候选人更清晰,更不容易出错。但是,如果它实际上被编译成它似乎会生成的代码,我认为它会更慢。使用for循环需要在每次循环迭代时增加i,以及从somePointer指向的地址偏移>i*si

c++ - 在 C++ 中防止整数 0 隐式转换为指针的最佳方法是什么

我正在尝试找出防止整数0隐式转换为nullptr_t然后传递给采用指针的构造函数的最佳方法。Explicit不会这样做,但我可以让nullptr_t导致模棱两可的重载错误:#includestructA{explicitA(char*){}};structB{B(nullptr_ta)=delete;B(char*){}};intmain(intargc,char*argv[]){Aa(0);//darnitIcompiled...Bb1(0);//good,fails,butwithonlyb/cambiguousBb2((char*)0);//good,succeedsBb3(1)

c++ - 用指向实例中方法的指针替换参数中的静态函数指针

我使用的第三方库需要将指向静态函数的指针作为回调参数传递。现在我必须做这样的事情:staticintMyCallback(...){//Callbackcodehere...}intmain(intargc,char*argv[]){ThirdPartyFunction(&MyCallback,...);}我想做的是用C++类实例的成员方法替换我必须提供的静态回调函数。像这样:classMyClass{public:intMyCallbackMethod(...);};intmain(intargc,char*argv[]){MyClassinstanceOfMyClass;Third

c++ - 在构造函数中引用此指针

Followingisanotherexampleofforwarddeclaration,whichmightbeusefuliftheapplicationneedsaself-sustainingarrayofobjectswhichisabletoaddandremoveobjectsfromitselfduringrun-time:Filea.h:classA{public:staticA*first,*last;A*previous,*next;A();~A();};Filea.cpp:#include"a.h"A*A::first=0,*A::last=0;//don't

c++ - 指向 C++ 类元素的指针

我有一个C++类c_image,它包含指向c_pixel类元素的指针vector:classc_image{public:vector>pixel;...};c_pixel类元素包含一个double类型的元素Z:classc_pixel{public:doubleZ;...};但是,它们使用c_pixel_pv类进行扩展,其中包含pv,一个包含三个double类型元素的数组:classc_pixel_pv:publicc_pixel{public:doublepv[3];...};类c_image还有一个函数filtervectorc_image::filter(???){...};它

c++ - protected 成员不能通过指针或对象访问

我有2个类Training和Testing,其中Training是基类,Testing是派生类训练类。我有Testing类成员函数,floattotalProb(Training&classProb,Training&total),它有2个参数,都是Training类对象。代码:voidTesting::totalProb(Training&classProb,Training&total){_prob=(_prob*((float)(classProb._nOfClass)/total._tnClass));coutfirst基本上这个函数所做的是计算test1(Testing类的一

c++ - 创建线程并让 "this"指针从构造函数中逃逸总是安全的吗?

我对以下代码感到困惑(来自PreferUsingActiveObjectsInsteadofNakedThreads):classActive{public:classMessage{//baseofallmessagetypespublic:virtual~Message(){}virtualvoidExecute(){}};private://(suppresscopyingifinC++)//privatedataunique_ptrdone;//lesentinelmessage_queue>mq;//lequeueunique_ptrthd;//lethreadprivate

c++ - 共享指针的双重检查锁定

免责声明:我有Java背景,因此,我不知道C++(和相关库)的许多内部机制是如何工作的。我已经阅读了足够多的资料,知道双重检查锁定是邪恶的,正确和安全地实现单例模式需要适当的工具。我认为以下代码可能不安全,受编译器重新排序和未初始化对象分配的影响,但我不确定我是否遗漏了一些我不了解该语言的内容。typedefboost::shared_ptrAPtr;APtrg_a;boost::mutexg_a_mutex;constAPtr&A::instance(){if(!g_a){boost::mutex::scoped_locklock(g_a_mutex);if(!g_a){g_a=bo

c++ - 如何使可变参数模板类方法将函数指针作为从函数模板派生的类型的参数?

抱歉标题有点啰嗦。我正在研究类似于讨论的数组类here.我想定义一个“映射”函数,它采用用户定义的函数并将其应用于数组的每个元素。出于类型检查的目的,我想将其定义为用户指定的函数必须采用与传递给map函数的参数数量相同的参数,以便doublef(doublea,doubleb){returna+b;}Arrayx,y,z;x.map(f,y,z);会编译但是doubleg(doublea,doubleb,doublec){returna+b+c;}Arrayx,y,z;.x.map(g,y,z);不会,因为g根据传递给map函数的内容接受了错误数量的参数。我试过这样的语法:templa