草庐IT

make_member_delegate

全部标签

Maven打包项目报错:Unable to make field private com.sun.tools.javac.processing.JavacProcessingEnvironment

报错信息为:Unabletomakefieldprivatecom.sun.tools.javac.processing.JavacProcessingEnvironment$DiscoveredProcessorscom.sun.tools.javac.processing.JavacProcessingEnvironment.discoveredProcsaccessible:modulejdk.compilerdoesnot"openscom.sun.tools.javac.processing"tounnamedmodule@73076bce报错原因:因为JDK版本太高与项目中使用的j

vivado 错误总结1——WARING:[Labtools 27-3361] the debug hub core was not detected make sure the clock

我在programdevice后无法打开debug的调试界面,出现了如下错误:WARING:[Labtools27-3361]thedebughubcorewasnotdetectedmakesuretheclockconnectedtothedebughubcoreisafreerunningclockandisactivemakesuretheBSCAN_SWITCE_USER_MASKdevicepropertyinvivadohardwaremanagerreflectstheuserscanchainsettinginthedesignandrefreshthedevice.解决办法

c++ - shared_ptr 的静态成员函数 make_shared

使用libc++我在公共(public)部分找到了std::shared_ptr::make_shared()静态成员函数。当我已经为std::shared_ptr的特化定义了类型别名时,这非常方便:usingT=int;usingP=std::shared_ptr;autop=P::make_shared(123);//std::make_shared(123)static_assert(std::is_same::value);我担心标准合规性,因为来自可信来源的文章(1,2)没有提到std::shared_ptr的静态成员函数make_shared>.目前使用该功能是否不好?为什

c++ - 是什么让 union 成员(member)活跃起来?

是什么让union成员活跃起来?我已经阅读了C++14标准的第9.5章(关于union的那一章),但是对于什么使union成员活跃,我还没有找到明确的答案。有一个注释:Ingeneral,onemustuseexplicitdestructorcallsandplacementnewoperatorstochangetheactivememberofaunion.例如,unionU{inti;shorts;}u;new(&u.i)int(42);好的,placementnew改变了activemember,很清楚了。但是在处理具有普通构造函数的类型时,我们通常不使用placementn

c++ - enable_shared_from_this 和 make_shared 是否提供相同的优化

据我了解make_shared(...)可以提供一些内存分配优化(它可以在与类T的实例相同的内存块内分配引用计数器)。enable_shared_from_this是否提供相同的优化?所以:classT:std::enable_shared_from_this{};...autot=std::shared_ptr(newT);等同于:classT{};...autot=std::make_shared();如果不考虑sizeof(T)。 最佳答案 Doenable_shared_from_thisprovidesthesameopt

c++ - 使用 make_tuple 进行比较

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Implementingcomparisionoperatorsvia'tuple'and'tie',agoodidea?有时候我需要写一些丑陋的仿函数例如lhs.date_这让我很生气。所以我开始避免这样写:std::make_tuple(lhs.date_,lhs.time_,lhs.id_)我几乎很高兴,但请注意,我可能不是出于他们的目的使用元组让我担心。您能批评一下这个解决方案吗?或者这是一个很好的做法?您如何避免这种比较?更新:感谢您指出std::tie以避免复制对象。并感谢您指出重复的问题

c++ - 为什么 std::make_tuple 将 std::reference_wrapper<X> 参数转换为 X&?

在C++11标准中它声明(参见cppreference.com,另请参见标准的第20.4.2.4节)它声明templatetuplemake_tuple(Types&&...args);Createsatupleobject,deducingthetargettypefromthetypesofarguments.ForeachTiinTypes...,thecorrespondingtypeViinVtypes...isstd::decay::typeunlessapplicationofstd::decayresultsinstd::reference_wrapperforsome

c++ - 如果为 false,则 std::is_member_function_pointer 不编译

我在寻找什么:我有一个模板化类,如果该类具有所需的函数,我想调用一个函数,例如:templatedo_something(){ifconstexpr(std::is_member_function_pointer::value){this->_t->x();//_tistypeofT*}}会发生什么:如果T没有带来函数,编译器就不会编译。小例子:#include#includeclassFoo{public:voidx(){}};classBar{};intmain(){std::cout::value::value编译器说:is_member_function_pointer.cpp

c++ - C++11 中的委托(delegate)

C++11是否提供委托(delegate)?如果不是,那么在C++中执行类似操作的最佳(最有效)方法是什么?升压信号?快速委托(delegate)?还有别的吗? 最佳答案 您可以使用bind将成员函数绑定(bind)到类实例,从而获得类似委托(delegate)的语义:#includestructC{voidFoo(int){}};voidBar(std::functionfunc){func(42);//callsobj.Foo(42)}intmain(){usingnamespacestd::placeholders;Cobj;

c++ - 如何将编译标志 -g 添加到 make 文件?

我有一个C++程序,其他人为其制作了一个make文件。我想用标志-g编译程序,但我不知道在哪里添加它。下面是make文件。CC=g++LOADLIBES=-lmCFLAGS=-Wall-O2SRC1=Agent.cppBreeder.cppCandidateSolution.cpp\Cupid.cppFateAgent.cppGrid.cppReaper.cpp\fitness.cppSRC2=main.cppSRC=$(SRC1)$(SRC2)OBJS=$(SRC1:.cpp=.o)AUX=$(SRC1:.c=.h)main:$(OBJS)#$(CC)$(CFLAGS)-o$(SRC