草庐IT

C++智能指针之unique_ptr

全部标签

c++ - G++:可以将 __attribute__((__may_alias__)) 用于指向类实例而不是类定义本身的指针吗?

我正在寻找以下问题的答案:may_alias是否适合作为指向某个类Foo对象的指针的属性?还是只能在类(class)级别使用?考虑以下代码(它基于更复杂的真实示例):#includeusingnamespacestd;#definealias_hack__attribute__((__may_alias__))templateclassFoo{private:/*alias_hack*/charData[sizeof(T)];public:/*alias_hack*/T&GetT(){return*((/*alias_hack*/T*)Data);}};structBar{intBaz

C++ ptr_fun 找不到 void 参数化函数

我尝试使用std::ptr_fun来包装我的函数,但是当我尝试使用void参数和bool返回类型来包装一个函数时,我得到了一个错误:代码:std::functioncr=std::not1(std::ptr_fun(&funct1));功能:boolfunct1(){returnfalse;}错误:error:nomatchingfunctionforcallto'ptr_fun(bool(*)())'但每当我将参数更改为int时,问题似乎就消失了。如何使用void参数包装函数? 最佳答案 std::ptr_fun仅适用于一元函数:

c++ - 在模板类中使用函数指针

这是我类(class)的选集template>classBinarySearchTree{public:BinarySearchTree&operator=(BinarySearchTreeconst&tree){if(this!=&tree){tree.VisitInOrder(Insert);}return*this;}boolInsert(TValueconst&value){returnm_Insert(value,pRoot);}templatevoidVisitInOrder(TVisitorvisitor)const;...};下面的序列将不起作用:VisitInOrde

c++ - 自动向下转换指向派生对象的指针

早上好我有一个模板化类,我想通过指针vector来操作对象。要使用指向模板化类的指针vector,我需要从非模板化类派生此类,我做到了。这是我的问题:要从指向基类的指针调用派生类的方法,我不能使用虚函数,因为不能将模板函数设为虚函数。我需要进行显式转换,这很乏味:一旦使用new创建数字对象,实际上需要向下转换为number*,尽管该对象事先已知为数字。我以一种笨拙的方式解决了这个问题:函数myset测试所有支持的typeid值以获得正确的动态转换。它是执行typeid检查的一长串嵌套ifs。除了繁琐之外,该函数仅适用于调用'set'方法,并且应定义类似的函数以调用其他方法。如果我可以对

c++ - 转换 Const 指针以使用遗留 C 代码

作为我之前问题(VariableLengthArrayPerformanceImplications(C/C++))的后续,我在使用C系统调用writev()维护const正确性时遇到了一些麻烦。也就是说,尽管我使用的是C++,但我似乎遇到了与该用户在C中遇到的完全相同的问题:https://codereview.stackexchange.com/questions/9547/casting-const-pointer-to-non-const-pointer-when-using-struct-iovec这是我的代码片段:intmy_awesome_transmit_functio

c++ - 奇怪的行为,用 int 初始化函数指针?

无意中,我发现这段代码可以在VS2012上编译。typedefvoid(*func)();funcf=func(12);f被初始化为一个整数12作为它的地址。据我所知,从整数转换为函数指针是有效的,如下所示:funcf=(func)12;虽然语句func(12)看起来更像是一个构造函数,所以我尝试了这个:funcf(12);编译失败。funcf=(func)12//ok,cast1funcf=func(12);//ok,what?2funcf(12);//failed3funcf=12;//failed4所以我的问题是:func(12)的真正底层语法是什么,是强制转换还是初始化?如何使

c++ - Visual Studio 2013 C++ - 将 std::unique_ptr 传递给绑定(bind)函数

使用VisualStudio2013RC和C++,我尝试将std::unique_ptr传递给已使用std::bind绑定(bind)的函数。但是,我遇到了麻烦,因为当我尝试这个时VS似乎不喜欢它。这是我要编译的内容:#include#include#includevoidfunc(std::unique_ptrarg){std::cout)>bound=std::bind(&func,std::placeholders::_1);std::unique_ptrptr(newint(42));bound(std::move(ptr));return0;}这可以在GCC4.8.1中编译,

c++ - 成员函数返回指向成员函数的指针

我想要一个带有成员函数的类,该类返回指向成员函数的指针。也就是说,类似于:classFoo{//typedef????(Foo::*func)????public:Funcs1();Funcs2();Funcs3();}FuncFoo::s1(){//dostuffreturn&Foo::s2;}FuncFoo::s2(){//dostuffreturn&Foo::s3;}FuncFoo::s3(){//dostuffreturn0;}基本上,我尝试做的是实现一个状态机,其中每个状态现在都是下一个状态并通过函数指针返回它。注意:我对其他实现状态机的方法不感兴趣。我真的很想知道它是否可以

c++ - boost::function 与函数指针

我正在实现一个通用设置读取器。我的想法是我有一个应用程序,它的设置可以是bool值、整数和字符串。然后我有一个Config类,其中实现了此类设置的getter,配置类在构造函数中接受了一个客户,因此它知道它将读取该客户的设置。我在让它工作时遇到了麻烦,我想我误用了boost::function,将它与普通函数指针混淆了。在映射中,我希望有引用,而boost::function应该只在配置读取时绑定(bind),因为我已经为那里分配了一个Config实例给定的客户。问题是我不能在没有typedef的情况下使用函数指针,这会使模板工作复杂化,有什么更明智的解决方案吗?#include"Co

c++ - 如何获得指向虚拟成员函数的 "direct"函数指针?

我在一个嵌入式平台上工作,该平台不能很好地处理动态代码(根本没有推测/OOO执行)。在这个平台上,我经常在同一个对象上调用虚拟成员函数,但是编译器无法优化vtable-lookup,因为它似乎没有识别出仅在第一次调用时才需要查找。因此我想知道:是否有一种手动方法可以将C++类的虚拟成员函数去虚拟化,以获得直接指向已解析地址的函数指针?我查看了C++函数指针,但由于它们似乎需要指定类型,我想这不会成功。提前致谢 最佳答案 没有通用的仅标准C++方法来查找虚函数的地址,仅给出对基类对象的引用。此外,没有合理的type,因为this不需要