草庐IT

c++ - type_traits - 连续内存

我有一个处理任何容器类型的接口(interface)。std::vector、std::array,甚至std::basic_string。问题是没有什么可以阻止某人传递没有连续内存的容器。我目前的解决方案是删除那些我想阻止的接口(interface)。voiddosoemthing(conststd::list&)=delete;voiddosoemthing(conststd::map&)=delete;但是,如果我可以只添加一个基于类型特征的静态断言,我会更愿意。这引出了我的问题。它们是否存在可用于识别其内存是否连续的容器类型特征?我一直在通过documentation来还没有找

c++ - 没有匹配函数调用 `std::basic_ofstream<char, std::char_traits<char>>::basic_ofstream(std::string&)'

我正在尝试编写一个程序,要求用户输入文件名,然后打开该文件。当我编译它时,出现以下错误:nomatchingfunctionforcalltostd::basic_ofstream>::basic_ofstream(std::string&)这是我的代码:usingnamespacestd;intmain(){stringasegurado;cout>asegurado;ofstreamentrada(asegurado,"");if(entrada.fail()){cout 最佳答案 std::ofstream如果您有C++11或

php - 交响乐 : is there a best practice about the directories' name including traits and interfaces?

我想我无法在我的包中创建Trait或Interface目录,因为这是一个在使用时会带来问题的关键字(即useMyBundle\trait\MyTrait).是否有关于如何命名这些目录的最佳实践? 最佳答案 SymfonybestpractisesSymfony-OrganizingYourBusinessLogicPSRcodingstandards特定于Symfony:将您的特征放在Util文件夹中。在接口(interface)方面;例如你有一个名为Hello和HelloInterface的服务类,那么它们都应该转到Service

php - PHP 中的 Traits 有哪些可能的使用场景?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:traitsinphp–anyrealworldexamples/bestpractices?在什么样的情况下会用到PHP中的Traits?我对此有一个很好的整体想法,但我似乎想不出在我编写的应用程序中使用它们的方法,但这可能是因为它当时不需要特征。我已经意识到需要特征的一个场景:事件。与其拥有一个实现观察者模式的类并让所有其他类继承它,不如将其设为特征并让想要触发事件或订阅的类使用该特征。例如,Yii框架通过在CComponent类中实现内容而不是使用Trait来做错。基本上可以在类之间共享的功能,但可能沿

c++ - 如果自定义分配器中不存在重新绑定(bind),std::allocator_traits 是否定义 rebind_alloc?

我正在尝试重新绑定(bind)我的自定义分配器类型,MyAllocator,用于basic_string类,例如:std::basic_string,MyAllocator>...分配器作为MyAllocator传递给上下文,所以我需要重新绑定(bind)分配器。来自std::allocator_traits的cppreference页面,http://en.cppreference.com/w/cpp/memory/allocator_traits:Memberaliastemplates:rebind_alloc:Alloc::rebind::otherifpresent,othe

c++ - 使用 std::allocator_traits<A>

我想设计一个类模板,它采用分配器类型(如标准第17.6.3.5节中所定义)作为模板参数。我怎么看std::allocator_traits有助于填补A的任何缺失成员使用默认设置。除此之外,标准库或boost中是否有任何有助于正确使用分配器的内容?特别是:尊重类型定义,如std::allocator_traits::propagate_on_container_copy_assignment,我是否必须在每个类的特殊成员函数中检查这些东西,每个类都有一个A类型的成员??或者是否有一些包装器类型我可以用作成员来代替它来处理这些东西?如果我想通过在用户可见对象旁边存储额外数据来过度分配以减少

c++ - XCode 4.5 'tr1/type_traits' 找不到文件

我使用wxwidget库,但遇到以下问题:#ifdefined(HAVE_TYPE_TRAITS)#include#elifdefined(HAVE_TR1_TYPE_TRAITS)#ifdef__VISUALC__#include#else#include#endif#endif这里找不到#include。我使用AppleLLVM编译器4.1。(使用c++11方言)。如果我切换到LLVMGCC4.2编译器,我在那里没有错误,但主要问题是所有c++11包含都不起作用。我怎样才能使用GCC编译器,但使用c++11标准或使LLVM可以找到?如有任何帮助,我们将不胜感激。

c++ - 如何使用 type_traits 生成依赖于类特化是否存在的代码?

背景我正在尝试写一个classtemplateHasher这将以两种不同的方式实现,具体取决于是否std::hash已为T实现:templatestructHasher{std::size_thash(Tt)const;//implementasA{std::hashh;returnh(t);}//orB{std::hashh;returnh(t.to_string());}};如果std::hash已经专精了,想用。如果没有,我希望T有一个to_string()函数返回一个key供我哈希。例如,根据cppreference,如果T是longlong、指针或std::string,我想

c++ - 为什么 boost::call_traits<T>::param_type 是枚举类型的引用?

基本的C++03枚举类型只是一个具有奇特名称的整数值,因此我希望按值传递它....出于这个原因,我还期望boost::call_traits::param_type与T=SomeEnum确定最有效的传球方式T是按值(value)。从boost文档中查看CallTraits:Definesatypethatrepresentsthe"best"waytopassaparameteroftypeTtoafunction.当我使用boost::call_traits::param_type时与T=SomeEnum它确定SomeEnum应该通过引用传递。我也期待C++11classenums也

C++ : how do I use type_traits to determine if a class is trivial?

在C++0x中,我想确定一个类是否简单/是否具有标准布局,以便我可以使用memcpy()、memset()等...我应该如何使用type_traits实现下面的代码,这样我才能确认一个类型是微不足道的?templateboolisTrivialType(){boolisTrivial=???returnisTrivial;}注意:is_pod()限制太多:我希望我的类有简单的构造函数等......为了方便。补充:我认为std::is_standard_layout可能会给我我正在寻找的东西。1.如果我添加构造函数,它仍然返回true2.如果我添加一个虚方法,它返回false这是我需要确