草庐IT

arg_scope

全部标签

c++ - C++11 中的 BOOST scoped_lock 替换

我面临这样一种情况,我必须用C++11中的等效项替换BOOSTscoped_lock。在visualstudio2013下。由于c++11不支持scoped_lock,我不确定下面的替换代码是什么。我应该选择lock_guard还是try_lock?boost::mutex::scoped_lockobjectLock(ObjectVectorMutex,boost::try_to_lock);if(objectLock){//...}在代码中我有以下“等待”语句if(ObjectsCollection.empty()){//Thisiswherewewaittilsomethingi

c++ - 在类 : scoped_ptr or shared_ptr? 中将智能指针作为参数传递

我有一个类在一个公共(public)方法中创建一个对象。该对象是私有(private)的,对类的用户不可见。此方法然后调用同一类中的其他私有(private)方法并将创建的对象作为参数传递:classFoo{...};classA{private:typedefscoped_ptrFooPtr;voidprivateMethod1(FooPtrfooObj);public:voidshowSomethingOnTheScreen(){FooPtrfooObj(newFoo);privateMethod1(fooObj);};};我相信在这种情况下正确的智能指针将是一个scoped_pt

c++使用va_arg调用父类(super class)构造函数

我有一个基类,其中包含一个带有可变参数列表的构造函数:classSuper{public:Super(intnum,...);...}现在,在我的子类构造函数中,我需要以某种方式调用这个父类(superclass)构造函数,但我该怎么做呢?通常的事情自然是行不通的:classSub{public:Sub(intnum,...):Super(???){...}...}那么我应该输入什么而不是???我确实有另一个接受vector的构造函数,但有这样一个构造函数是客户的直接要求。 最佳答案 与任何变量函数一样,也始终提供列表版本:void

c++ - 声明为 consts 的函数 args 随定义变为非常量

这个问题在这里已经有了答案:Whydoesafunctiondeclarationwithaconstargumentallowcallingofafunctionwithanon-constargument?(4个答案)关闭4年前。代码classA{public:voidf(constinti);};voidA::f(inti){std::cout为什么编译器在这种情况下不报错?为什么定义会覆盖常量参数?此外,当参数的类型为reference(&)时,编译器会抛出错误,但在这种情况下为什么不呢?是否有任何编译器标志可以对这些提到的情况发出警告?我对编译器错误POV更感兴趣。因为可以很

c++ - 当没有传递任何参数时,#__VA_ARGS__ 应该生成什么?

示例代码:#defineFOO(...)Youpassed:#__VA_ARGS__FOO(1,2,3)FOO()使用VisualC++(版本14CTP)进行预处理,得到:Youpassed:"1,2,3"Youpassed:在最后一行,#__VA_ARGS__变成了虚无。我希望它变成“”。对于应该发生的事情是否有明确的引用?我用Google搜索了很多,但没找到。任何建议的解决方法也会很有用。 最佳答案 根据6.10.3.2#运算符(C11):Semantics2-[...]Thecharacterstringliteralcorr

c++ - 在简单的情况下使用 scoped_ptr 是否有点矫枉过正?

我在像这样的小函数中使用scoped_ptr。这样我就不必调用delete了。这是这种用法的矫枉过正吗?我的团队成员更喜欢原始指针和删除。如果这恰好用在非常关键的路径中,那么使用scoped_ptr的成本是多少?这不应该是内联的并且完全等同于在优化的二进制文件中使用普通删除吗?voidmyfunc(){boost::scoped_ptrobjptr=someFactory::allocate();callsomeotherfunc(objptr.get());} 最佳答案 我不确定对性能的影响,但是在这里使用scoped_ptr确保

c++ - 应该使用哪个 header 来使用 scoped_ptr

我想在我的C++应用程序中使用智能指针。使用stdscoped_ptr应该包含哪个头文件? 最佳答案 标准C++库中没有scoped_ptr。全部C++11smartpointers在标题中.如果你想要boost::scoped_ptr那么你需要boost/scoped_ptr.hpp. 关于c++-应该使用哪个header来使用scoped_ptr,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q

C++ 错误 : ‘_mm_sin_ps’ was not declared in this scope

我正在尝试对将函数应用于数组的不同方法进行基准测试。为什么是https://software.intel.com/sites/landingpage/IntrinsicsGuide/#expand=3260,2124,4779,4779&cats=Trigonometry&text=_sin_mm_sin_ps在我的范围内未知,但_mm_sqrt_ps是?我如何让它为人所知?并编译无误。#include#include#include#include#include#include#include"immintrin.h"#includeintmain(){std::coutdis(-

c++ - std::is_constructible<T, Args> 是如何实现的?

这个问题在这里已经有了答案:C++98/03std::is_constructibleimplementation(4个答案)关闭5年前。到目前为止,我在网上找不到任何ELI5。对于一个学习项目,我想实现我自己的is_constructible。有人可以解释一下它是如何工作的吗?

c++ - QScopedPointer、boost::scoped_ptr - 为什么提示类型不完整?

我有一个c-Structure,我想将它嵌入到一个cpp类中而不破坏我的全局命名空间,所以我不想包含c-header。这就是为什么我想使用具有前向声明结构名称的智能作用域指针(QScopedPointer或boost::scoped_ptr)。我不明白的是上述两个在编译时失败的作用域指针的实现:boost:errorC2027:useofundefinedtype'xxx'templateinlinevoidchecked_delete(T*x){//intentionallycomplex-simplificationcausesregressionstypedefchartype_