草庐IT

func_pointer

全部标签

c++ - 表达式 : auto p {make_pointer()}; 的不同编译器行为

以下程序的正确行为是什么?//example.cpp#include#includestructFoo{voidBar()const{std::coutMakeFoo(){returnstd::make_shared();}intmain(){autop{MakeFoo()};p->Bar();}当我在我的LinuxRHEL6.6工作站中编译它时,我得到以下结果:$g++-vgccversion5.1.0(GCC)$g++example.cpp-std=c++14-Wall-Wextra-pedantic$./a.outFoo::Bar()但是$clang++-vclangversio

c++ - 如何通过扩展以下类型特征来删除 decltype(& MyClass::func) 部分?

我想拥有类型特征,这将帮助我获得类的类型从成员函数指针。我查看了thisanswer并找到了我的目标。看起来像这样:#include//exampleclassstructMyClass{voidfunct(){std::coutstructget_class{};templatestructget_class{usingtype=Class;};templateusingget_class_t=typenameget_class::type;intmain(){get_class_tmyObj;//^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^--->thi

C++ 类型转换 : cast a pointer from void pointer to class pointer

如何将指向void对象的指针转换为类对象? 最佳答案 使用static_cast。请注意,只有当指针确实指向指定类型的对象时,您才必须这样做;也就是说,指向void的指针的值取自指向此类对象的指针。thing*p=whatever();//pointertoobjectvoid*pv=p;//pointertovoidthing*p2=static_cast(pv);//pointertothesameobject如果您发现自己需要这样做,您可能需要重新考虑您的设计。你放弃了类型安全,让编写无效代码变得容易:something_el

java - ‘value semantics’ 和 ‘pointer semantics’ 是什么意思?

什么是“值语义”,什么是“隐式指针语义”? 最佳答案 Java对对象类型使用隐式指针语义,对基元使用值语义。值语义意味着您直接处理值并传递拷贝。这里的重点是,当您拥有值(value)时,您可以相信它不会在您背后改变。使用指针语义,您没有值,只有“地址”。其他人可以改变那里的东西,你不知道。C++中的指针语义:voidfoo(Bar*b)......b->bar()...你需要一个*来请求指针语义和->调用指针上的方法。Java中的隐式指针语义:voidfoo(Barb)......b.bar()...由于您无法选择使用值语义,因此不

C++函数参数: use a reference or a pointer (and then dereference)?

我得到了一些代码,其中一些参数是指针,然后指针被取消引用提供值(value)。我担心指针取消引用会花费周期,但是在查看之后上一篇StackOverflow文章:Howexpensiveisittodereferenceapointer?,也许没关系。这里有一些例子:boolMyFunc1(int*val1,int*val2){*val1=5;*val2=10;returntrue;}boolMyFunc2(int&val1,int&val2){val1=5;val2=10;returntrue;}就风格而言,我个人更喜欢通过引用传递,但有一个版本更好(在流程周期方面)比另一个?

c++ - 如何检测是否有func。是一个常量?并标记其他功能。 constexpr 取决于它?

假设我有一些函数模板f1:templateintf1(inti,intj)noexcept{returni+j+f2(i,j);}有没有办法确定f2(i,j)可以是constexpr.(无论是函数还是仿函数)等等标记f1作为constexpr也是?我正在考虑如何在这里使用SFINAE,但没有找到如何检测constexpr使用typetraits 最佳答案 您可以将f1标记为constexpr。templateconstexprintf1(inti,intj)noexcept{returni+j+f2(i,j);}模板函数f1将是co

c++ - shared_dynamic_cast 和 dynamic_pointer_cast 的区别

谁能给我解释一下:shared_dynamic_cast和dynamic_pointer_cast来自Boost库?在我看来它们可能是等价的。 最佳答案 给定一个shared_ptr,这两个函数确实是等价的。区别在于shared_dynamic_cast仅适用于shared_ptr的,而dynamic_pointer_cast适用于任何类型的指针(通过重载)。这使您可以对任何指针concept执行动态转换,而不管该指针实际上是如何构成的:#include#includestructfoo{};structbar:foo{voidf(

c++ - 函数名 __func__ 的预定义宏

我正在尝试构建一个调试日志消息函数,用于记录调用日志消息的文件、行和函数。#defineDEBUG_PANIC(p)CLogging::Debuglogf("Debugmarker(%s)-::%s()infile:%s(%d)",p,__func__,__FILE__,__LINE__);上面的代码适用于一些编译器,但不是全部。我的代码需要与GCC以及MicrosoftVisualStudio交叉兼容。我添加了以下定义以帮助兼容性。#ifndef__FUNCTION_NAME__#ifdefined__func__//Undeclared#define__FUNCTION_NAME_

c++ - __func__ 外部函数定义

如果我们在C(C99/C11)和C++中的函数之外使用预定义变量__func__会发生什么?#includeconstchar*str=__func__;intmain(void){printf("%s",str);return0;}gcc4.7.2只给出警告(启用-Wall-W-pedantic)并且什么也不打印。标准没有明确说明:ISO/IEC14882:20118.4.1一般[dcl.fct.def.general]8Thefunction-localpredefinedvariable__func__isdefinedasifadefinitionoftheformstatic

c++ - unique_ptr 的 static_pointer_cast 的替代方案

我了解将static_pointer_cast与unique_ptr一起使用会导致所包含数据的共享所有权。换句话说,我想做的是:unique_ptrfoo=fooFactory();//dosomethingforawhileunique_ptrbar=static_unique_pointer_cast(foo);无论如何,这样做会导致两个unique_ptr永远不应该同时存在,所以它是被禁止的。是的,这是有道理的,绝对是,这就是为什么确实不存在像static_unique_pointer_cast这样的东西。到目前为止,如果我想存储指向这些基类的指针,但我还需要将它们强制转换为一些