草庐IT

enable-shared

全部标签

c++ - 将 boost::shared_lock 升级为独占锁

谁能解释一下boost::upgrade_lock的正确用法。以下代码导致死锁//Globaltypedefboost::shared_mutexMutex;typedefboost::shared_lockReadLock;typedefboost::upgrade_lockUpgradeLock;typedefboost::upgrade_to_unique_lockWriteLock;MutexsharedMutex;//Multithreadedreaderandwriter{ReadLockread(sharedMutex);for(intii=0;ii如果我在升级前用rea

c++ - 使用 enable_if 为有符号和无符号变量创建可变参数构造函数

我想为一个类创建一个构造函数,使用任何整数类型,但要区分有符号和无符号。我不希望它成为类本身的模板。以下不起作用。VisualStudio只是说没有参数匹配。classThing{public:templateThing(typenamestd::enable_if::value&&!std::is_same::value&&std::is_signed::value,Integral>::typenum){//constructorusingsignedvariableasinput}templateThing(typenamestd::enable_if::value&&!std:

C++ 重载基于 shared_ptr 派生类的函数

有很多与此类似的SO问题,但我无法准确找到我要找的内容。如果这是重复的,我很抱歉。我有一个Parent类和继承自它的两个派生类:classSon:publicParent{...};classDaughter:publicParent{...};然后我声明两个shared_ptr到基类,并用shared_ptr实例化它们对于每个派生类:shared_ptrson=shared_ptr(newSon());shared_ptrdaughter=shared_ptr(newDaughter());最后,我想要一个处理shared_ptr的类基于它指向哪个派生类。问题是我可以使用函数重载来实

c++ - SFINAE: std::enable_if 作为函数参数

因此,我正在按照此网页某处的代码设置的示例进行操作:http://eli.thegreenplace.net/2014/sfinae-and-enable_if/这是我所拥有的:templatevoidfun(consttypenamestd::enable_if_t::value,T>&val){std::cout";}templatevoidfun(consttypenamestd::enable_if_t::value,T>&val){std::cout";}intmain(){fun(4);fun(4.4);}这样我就得写:fun(4);fun(4.4);我该如何避免这种情况?

c++ - 为什么 enable_if 不能在这里工作?

我有这段代码,我期望会有两个不同版本的运算符()基于模板参数的类型。#include#includetemplatestructImpl{std::enable_if_t::value,T>operator()(conststd::string&key,intnode){returnstatic_cast();}std::enable_if_t::value,T>operator()(conststd::string&key,intnode){returnnewT();}};intmain(){}相反,我在编译时遇到错误:'std::enable_if_t::value,T>Impl:

c++ - 我应该使用 shared_ptr<Object> myObject = (shared_ptr<Object>) new Object() 来访问私有(private)构造函数吗?

我正在使用广泛使用以下语法的代码库:shared_ptrmyObject=(shared_ptr)newObject();我注意到我无法使用make_shared访问私有(private)构造函数,但是shared_ptrmyObject=(shared_ptr)newObject();工作得很好。我应该仅仅因为它看起来有效而使用它吗?有什么危险吗?它与make_shared有何不同??我知道this中的答案问题,它在make_shared之间进行比较和:std::shared_ptrp2(newObject("foo"));但我没能找到对我遇到的语法的引用。和上面有什么不同,还是一样

C++ 内部代码重用 : compile everything or share the library/dynamic library?

一般问题:对于非托管C++,内部代码共享有什么更好的?通过共享实际源代码来重用代码?或者通过共享库/动态库(+所有头文件)重用代码无论是哪一个:您减少重复代码(复制粘贴综合症)、代码膨胀的策略是什么?具体例子:以下是我们在我的组织中共享代码的方式:我们通过共享实际源代码来重用代码。虽然我们的项目实际上需要跨平台,但我们使用VS2008在Windows上进行开发。我们有许多项目(.vcproj)提交到存储库;有些可能有自己的存储库,有些可能是存储库的一部分。对于每个可交付的解决方案(.sln)(例如,我们交付给客户的东西),它将svn:externals从存储库中获取所有必要的项目(.v

c++ - 如何避免 shared_ptr 歧义? (STL 与提升)

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whyis‘usingnamespacestd;’consideredabadpracticeinC++?我在我的代码中的很多地方都使用了STL的shared_ptr并且我在我使用过的任何地方都使用了以下using语句shared_ptr:usingnamespacestd::tr1;现在我需要使用boost::bimap。所以我必须在我的代码中包含以下头文件:#include一旦我包含了bimap头文件,shared_ptr类型就变得不明确了,我必须将shared_ptr的所有用法更改为std::tr1::

c++ - 使用 std::enable_if 时的对象切片

我正在尝试使用std::enable_if来专门化一个类,如果它的一个子类定义了特定的成员函数。否则,它应该使用在基类中定义的默认实现。#include#include#include#include#include#includeBOOST_TTI_HAS_MEMBER_FUNCTION(f2)classBase{public:virtualdoublef1(doublex,doubley)const{std::coutclassA:publicBase{public:templatetypenamestd::enable_if,boost::function_types::cons

c++ - 为什么 std::shared_ptr 没有 [] 运算符?

这个问题在这里已经有了答案:Whyisn'tthereastd::shared_ptrspecialisation?(1个回答)关闭7年前。我想知道std::shared_ptr没有为数组定义[]运算符这一事实背后的基本原理是什么。特别是为什么std::unique_ptr具有此运算符而不是std::shared_ptr?