草庐IT

pointer-address

全部标签

c++ - pointer_traits 为既不是 X<A, T...> 也没有提供成员 typedef element_type 的类型提供什么?

下面的结果是什么?它是格式错误、未定义的行为还是定义良好且格式正确的行为?structA{};std::pointer_traitsx;我之所以问,是因为好奇想知道,也想知道任意类型是不是指针。我还想包括shared_ptr和friend。我想知道是否有类型特征(谓词),如果没有,我是否可以使用pointer_traits并检测是否声明了element_type。 最佳答案 它表示从20.6.3p1开始格式错误,因为它没有element_type并且不是类模板实例化typedefseebelowelement_type;Type:P

c++推导 "non type pointer to function"类模板参数

考虑一个模板类:templateclassProxy{voidrun(){ReturnTyperet=Fn();//...dosomething...}};//andafunctionsintfn1(){return5;}floatfn2(){return5;}这可以通过使用实例化:Proxyp1;但是显式声明返回值类型似乎是不必要的。我想要实现的是:someProxyInstantationp1;someProxyInstantationp2;不幸的是,我对c++没有任何期望,这似乎是该语言的一个隐藏角落(至少对我而言)。如果我可以从指向函数的指针获取它的类型——类似于:std::t

c++ - auto_ptr 和 dynamic_pointer_cast

如果我想将dynamic_cast与shared_ptr一起使用,我可以使用dynamic_pointer_cast。如果我想转换auto_ptr,我该用什么?我假设如下所示。structB:A{};...auto_ptrbase(...);auto_ptrderive=dynamic_pointer_cast(base);我正在为shared_ptr使用boost 最佳答案 auto_ptrbase(...);if(B*query=dynamic_cast(base.get())){//takeownershipbase.rele

c++ - Xcode4 : "bad codegen, pointer diff" linker error again

这个问题与此相关:"badcodegen,pointerdiff"linkererrorwithXcode4和"badcodegen,pointerdiffinboost"errorin32-bitbuild和XCode3.2.6and4linkererrorsld:badcodegen,pointerdiffin...toglobalweaksymbol我目前正在将我的所有项目升级到Xcode4,但我遇到了一些奇怪的事情。-仅当我构建通用二进制文件或32位版本时才会出现上述错误。如果我只坚持64位,一切正常。我正在自己构建一个自定义静态库,现在我不在该代码中使用任何可见性设置(即at

c++ - C/C++ 警告 : address of temporary with BDADDR_ANY Bluetooth library

我在使用g++和在Ubuntu下使用蓝牙库的C/C++程序的编译过程时遇到了一些问题。如果我使用gcc,它可以正常工作,没有任何警告;相反,如果我使用g++,我会收到此警告:warning:takingaddressoftemporary即使程序编译正常并且可以运行。报错涉及的线路有:bdaddr_t*inquiry(){//dosomestuff..bacpy(&result[mote++],BDADDR_ANY);returnresult;}//...voidzeemote(){while(bacmp(bdaddr,BDADDR_ANY)){/..}}在这两种情况下,都涉及BDAD

c++ - POINTER_32 - 它是什么,为什么?

我刚刚接到任务,将遗留应用程序从32位更新到64位。在审查任务的范围时,我在包含外部(例如平台)header之前立即发现了以下定义:#definePOINTER_32我找不到这个定义的用途或它有什么作用,但它看起来像是与我的任务直接相关的那种东西!它有什么用?它有什么用?立即移除它是否安全(我认为从长远来看有必要移除它)?这是使用MSVC++2008,即将成为2010。 最佳答案 这是一个通常在WindowsSDKheaderBaseTsd.hheader文件中声明的宏。在32位模式下编译时,它的定义如您所示。在64位模式下编译时定

c++ - 从其他容器中辨别 smart_pointer 的模板函数

考虑以下模板函数:templateconstT*DoSomething(constT&t){auto&id=typeid(T);coutT*DoSomething(T*t){auto&id=typeid(T);coutclasscontainer>T*DoSomething(constcontainer&t){auto&type_id=typeid(T);auto&container_id=typeid(container);coutclasscontainer,templateclassdeleter=default_delete>T*DoSomething(constcontain

c++ - int8_t 和 char : converts between pointers to integer types with different sign - but it doesn't

我正在处理一些嵌入式代码,并且正在从头开始编写一些新东西,因此我更愿意坚持使用uint8_t、int8_t等类型。然而,当移植一个函数时:voidfunctionName(char*data)到:voidfunctionName(int8_t*data)在将文字字符串传递给函数时,我收到编译器警告“在指向具有不同符号的整数类型的指针之间转换”。(即调用functionName("putthistextin");时)。现在,我明白了为什么会发生这种情况,并且这些行只是调试,但我想知道人们认为什么是最合适的处理方式,而不是对每个文字字符串进行类型转换。在实践中,我不认为一揽子类型转换比使用

c++ - 多重继承 : Different Address same address

我写了一个示例程序。如果我打印pa和pb的地址都是不同的。你能告诉我为什么会这样吗?#includeusingnamespacestd;classA{intx;};classB{inty;};classC:publicA,publicB{intz;};intmain(){Cc;A*pa;B*pb;pa=&c;pb=&c;cout 最佳答案 作为KerrekSB把它,pa和pb在您的示例中,实际上并不指向c,而是指向A和Bc的子对象.通过多重继承,来自基类的数据本质上是一个接一个地堆叠起来。基类型指针只是偏移到该基类的数据。正因为如此

C++ 错误 : "taking address of temporary array"

我试图在if语句中声明一个数组。我以这种方式编写代码,以便在ifblock退出后对象保留在范围内,但现在我遇到了一个新问题:“获取临时数组的地址”。我怎样才能用另一种方式重写它,以便为maskArray分配正确的值?int*maskArray;if(conditional==true)maskArray=(int[9]){0,1,0,1,-4,1,0,1,0}; 最佳答案 假设您以后不打算修改maskArray指向的内容,那么最好/最简单的解决方案是:constint*maskArray;if(conditional==true){