草庐IT

load_functions

全部标签

c++ - SFINAE : Detecting if a function is called by a compile time known value

我喜欢在我的一个ctors以编译时已知值被调用时做一些检查。有办法检测吗?所以当有人调用它时:Aa(10);因为10是编译时已知常量,所以我喜欢调用一个特殊的构造函数,如下所示:template>A(intValue){}知道如何解决这个问题吗?谢谢! 最佳答案 积分常量可以解决您的问题:structA{template*=nullptr>A(std::integral_constant){}};然后,你可以像这样使用它:Aa{std:integral_constant{}};为了便于使用,您还可以使用类似于boost::hana的

c++ - std::function 的移动赋值不是 noexcept,但 std::function::swap 是。是什么赋予了?

std::function在func.wrap.func中的概要告诉我们function&operator=(function&&);移动赋值运算符不是noexcept,禁止将其用于标准容器中的仅移动类型。但是!它还告诉我们voidswap(function&)noexcept;同样,默认的构造函数是function()noexcept;因此我们可以使用默认构造函数后跟交换来实现移动构造函数。因为我们可以用swap实现移动赋值运算符(swap有更强的后置条件):如何在std::function中实现noexcept交换?为什么std::function的移动赋值运算符不是noexcep

c++ - GCC、Unicode 和 __FUNCTION__

我正在尝试让我的项目在GCC下编译(VisualStudio可以完美地编译它)。我有一个自定义断言函数,它会抛出一条wstring消息。它的一部分是__FUNCTION__宏,我使用MSDN中的WIDEN宏将其“统一编码”#defineWIDEN2(x)L##x#defineWIDEN(x)WIDEN2(x)它在MSVC中编译正常,但在GCC中打印如下:error:‘L__FUNCTION__’wasnotdeclaredinthisscope我能想到的唯一解决方案是在运行时使用mbstowcs将__FUNCTION__的内容转换为wstring,但我想找到一种编译时方法来完成它。感谢

c++ - 错误 : invalid use of member in static member function

我有两个类,这是其中一个的标题:#ifndefWRAPPER_HPP#defineWRAPPER_HPP#includeusingnamespacestd;classWrapper{private://SDL_Surface*screen;public:staticSDL_Surface*screen;staticvoidset_screen(SDL_Surface*_screen);staticvoidset_pixel(intx,inty,Uint8color);staticvoidclear_screen(intr,intg,intb);staticSDL_Surface*loa

c++ - load-acquire 应该立即看到 store-release 吗?

假设我们有一个简单的变量(std::atomicvar)和2个线程T1和T2我们有以下代码T1:...var.store(2,mem_order);...和T2...var.load(mem_order)...我们还假设T2(load)执行时间比T1晚123ns(按照C++标准的修改顺序)(店铺)。我对这种情况的理解如下(针对不同的内存顺序):memory_order_seq_cst-T2load有义务加载2.如此有效,它必须加载最新值(就像RMW操作的情况一样)memory_order_acquire/memory_order_release/memory_order_relaxed

c++ - SIMD 内部函数 : _mm_stream_load_si128 vs _mm_load_si128

什么时候应该使用流媒体版本以及什么时候使用SSE2与_mm_load_si128?什么是性能权衡? 最佳答案 流加载内在(mm_stream_load_si128)执行加载“使用非时间内存提示”(根据IntelIntrinsicsGuide)。这意味着加载的值不会导致从缓存中逐出任何内容。如果您将大量数据组合在一起,您将立即对其进行操作并且“很长”一段时间内不再查看,这将非常有用。最常见的情况是在流操作期间发生这种情况。当我知道我正在对一个大数据集执行一个简单的操作时,我就使用过它,我知道数据无论如何都会很快从缓存中被逐出。memc

c++ - C2280 : attempting to reference a deleted function (union, 结构体,复制构造函数)

当我尝试在VisualStudio2015中编译以下最小示例时,我遇到了误导性错误消息的问题:classVector{floatx;floaty;public:Vector(floatx,floaty):x(x),y(y){}Vector&operator=(constVector&v){x=v.x;y=v.y;return*this;}//Vector(Vector&&)=default;};classRect{public:union{struct{Vectorp1,p2;};struct{floatp1x,p1y,p2x,p2y;};};Rect():p1(0,0),p2(0,0

c++ - 为什么我可以将接受值的可调用对象传递给接受引用的 std::function?

当我声明一个变量时function,编译器仍然允许我分配一个接受值的lambda:functionhandler;handler=[](Foof){};(参见http://cpp.sh/5dsp)因此当处理程序被调用时,会生成一个拷贝。标准的哪一部分允许这样做?有没有一种方法可以标记客户端代码这将是一个问题(某种static_assert之类的?)? 最佳答案 根据[func.wrap.func.con]std::function有一个templatefunction&operator=(F&&f);附上以下备注:Thisassig

c++ - 使用带有 std::optional 参数的 std::function 重载歧义

这是一个简单的示例程序:usingfn_string=function;usingfn_optional_string=function&)>;voidfoo(fn_string){cout&){});//它有2个重载foo()--一个使用string的函数参数和另一个optional.为什么第二次调用foo()模棱两可?有没有简单的方法来修复它?没有Actor?更新以上是我试图解决的以下现实世界问题的过度简化示例,即:usingdelegate=variant,function,function&)>>;structfoo{voidadd_delegate(delegatefn){f

c++ - gcc -finline-functions 行为?

我将gcc与-finline-functions优化一起用于发布构建。为了对抗代码膨胀,因为我在嵌入式系统上工作,我想说不要内联特定功能。显而易见的方法是通过函数属性,即attribute(noinline)。问题是当我打开作为-O3开关一部分的全局-finline-functions优化时,这似乎不起作用。它也与它被模板化有关,因为同一函数的非模板化版本没有像预期的那样被内联。有人知道当这个全局开关打开时如何控制内联吗?代码如下:#include#includeusingnamespacestd;classBase{public:templatestatic_Type_fooT(_T