草庐IT

this-reference

全部标签

c++ - 使用空大括号初始化程序 : pointer or reference? 的重载分辨率

这个问题在这里已经有了答案:Overloadresolution:assignmentofemptybraces(2个回答)关闭5年前。当我发现下面的代码输出“指针”时,我遇到了一个真实的WTF时刻。#include#includetemplatestructbla{staticvoidf(constT*){std::cout>::f({});}更改std::pairint的模板参数或任何其他原始类型,给出(至少对我而言)预期的“模棱两可的重载”错误。似乎内置类型在这里很特殊,因为任何用户定义的类型(聚合、非平凡、具有默认构造函数等)都会导致调用指针重载。我相信模板不是复制它的必要条件

C++ boost库shared_memory_object undefined reference 'shm_open'

我尝试在ubuntu11.04上编译以下代码:#include#includeintmain(){boost::interprocess::shared_memory_objectshdmem(boost::interprocess::open_or_create,"Highscore",boost::interprocess::read_write);shdmem.truncate(1024);std::cout只得到以下错误:/tmp/cc786obC.o:Infunction`boost::interprocess::shared_memory_object::priv_open

C++ boost库shared_memory_object undefined reference 'shm_open'

我尝试在ubuntu11.04上编译以下代码:#include#includeintmain(){boost::interprocess::shared_memory_objectshdmem(boost::interprocess::open_or_create,"Highscore",boost::interprocess::read_write);shdmem.truncate(1024);std::cout只得到以下错误:/tmp/cc786obC.o:Infunction`boost::interprocess::shared_memory_object::priv_open

c++ - 常量不匹配 : 2 overloads have no legal conversion for 'this' pointer

我收到了这个奇怪的错误:errorC2663:'sf::Drawable::SetPosition':2overloadshavenolegalconversionfor'this'pointer我认为这与const不匹配有关,但我不知道在哪里,或者为什么。在下面的代码中,我有一个形状和Sprite的vector,当尝试访问其中一个vector形状并调用它的一个函数时,我遇到了错误。std::vectorShapes;std::vectorSprites;boolAddShape(sf::Shape&S){Shapes.push_back(S);returntrue;};boolAdd

c++ - 常量不匹配 : 2 overloads have no legal conversion for 'this' pointer

我收到了这个奇怪的错误:errorC2663:'sf::Drawable::SetPosition':2overloadshavenolegalconversionfor'this'pointer我认为这与const不匹配有关,但我不知道在哪里,或者为什么。在下面的代码中,我有一个形状和Sprite的vector,当尝试访问其中一个vector形状并调用它的一个函数时,我遇到了错误。std::vectorShapes;std::vectorSprites;boolAddShape(sf::Shape&S){Shapes.push_back(S);returntrue;};boolAdd

c++ - reference_wrapper 和 std::ref 是如何工作的?

我正在尝试了解std::ref的工作原理。#include#includetemplatevoidfunc(Cc){c+=1;}intmain(){intx{3};std::cout在上面的代码中,我认为模板参数C第三个函数调用被实例化为std::reference_wrapper.阅读时thereference,我注意到没有+=std::reference_wrapper中的运算符.那么,c+=1;怎么样?有效吗? 最佳答案 howisc+=1;valid?因为reference_wrapper可隐式转换为int&通过其转换运算符

c++ - reference_wrapper 和 std::ref 是如何工作的?

我正在尝试了解std::ref的工作原理。#include#includetemplatevoidfunc(Cc){c+=1;}intmain(){intx{3};std::cout在上面的代码中,我认为模板参数C第三个函数调用被实例化为std::reference_wrapper.阅读时thereference,我注意到没有+=std::reference_wrapper中的运算符.那么,c+=1;怎么样?有效吗? 最佳答案 howisc+=1;valid?因为reference_wrapper可隐式转换为int&通过其转换运算符

c++ - 从 'enable_shared_from_this' 派生一个类可以提高性能吗?

make_shared比单独调用new并创建shared_ptr性能更高,因为make_shared为引用分配空间在与客户端对象实例相同的内存块中计数和弱计数(有效地为shared_ptr提供了intrusive_ptr的大部分性能优势)。enable_shared_from_this给出一个共享指针,而不引用任何共享指针。因此,必须以某种方式从客户端对象内部访问诸如引用和弱计数之类的东西。因此,enable_shared_from_this导致类似于make_shared的侵入性计数是明智的。但是,我不知道如何实现类似的东西(即使我查看实际来源,我也不确定我是否会关注其中发生的事情)

c++ - 从 'enable_shared_from_this' 派生一个类可以提高性能吗?

make_shared比单独调用new并创建shared_ptr性能更高,因为make_shared为引用分配空间在与客户端对象实例相同的内存块中计数和弱计数(有效地为shared_ptr提供了intrusive_ptr的大部分性能优势)。enable_shared_from_this给出一个共享指针,而不引用任何共享指针。因此,必须以某种方式从客户端对象内部访问诸如引用和弱计数之类的东西。因此,enable_shared_from_this导致类似于make_shared的侵入性计数是明智的。但是,我不知道如何实现类似的东西(即使我查看实际来源,我也不确定我是否会关注其中发生的事情)

c++ - 私有(private)继承隐藏基类,出现 "inaccessible within this context"错误

我遇到了类似于Privateinheritancerendersclassinaccessible中描述的问题当我尝试在派生类中声明基类的成员时,私有(private)继承的基类给出“在此上下文中不可访问”错误。在上述情况下,使用::X显式引用X是可行的,但如果代码位于以下函数中会怎样:voidfooby(){classX{};classY:privateX{};classZ:publicY{public:Xx;//Compiler"inaccessiblewithinthiscontext"error};};在这种情况下你如何引用X?如果fooby是一个结构/类,那么::fooby: