草庐IT

is_function

全部标签

c++ - std::is_trivially_equality_comparable_v<T>

相关但比C++11staticassertforequalitycomparabletype?神秘得多—JFBastien的论文N4130"PadThyAtomics!"让我想到如果我们要使用atomic::compare_exchange_weak()其中T是类或者结构类型,比如structCount{intstrong_count;intweak_count;};然后我们真的想静态断言两件事:首先,T实际上是无锁原子的:templatestaticconstexprboolis_lockfree_atomic_v=std::atomic::is_always_lock_free;其

c++ - clang、std::function 和 -fno-rtti

我在Windows上通过clang-cl使用Clang5,在使用std::function-fno-rtti)时遇到问题.这是我无法编译的示例:#includevoidfoo(std::functionra2){}intmain(){autobar=[](){};foo(bar);returnEXIT_SUCCESS;}命令行:clang-cltest.cpp-Xclang-fno-rtti错误是:C:\ProgramFiles(x86)\MicrosoftVisualStudio\Preview\Community\VC\Tools\MSVC\14.13.26128\include\

c++ - 访问并调用 std::function 的变体

我正在使用std::variant存储std::function的不同签名秒。所述函数存储在vector中,后者从map中检索。如何调用vector中的每个函数std::variant?我觉得我应该使用std::visit但我不知道正确的用法。#include#include#include#include#includeusingvar_t=std::variant,std::function>;enumclassEventEnum{A,B,C};structController{templatevoidsubscribe(var_tfn){auto&callbacksVec=cal

c++ - 将 lambda 传递给可变参数 std::function 时的类型推导

我正在尝试使用用于处理它们的函数的类型信息从数组元组中检索值。但是,由于(部分?)需要为std::function的类型名使用标识结构,因此在这种情况下类型推导失败。这里有没有办法恢复扣除?#include#include#includeclasscomp_a{public:staticconstsize_tid=0;intval=0;};classcomp_b{public:staticconstsize_tid=1;intval=0;};classcomp_c{public:staticconstsize_tid=2;intval=0;};templatestructstorage

c++ - 如果我使用 std::function 来捕获 lambda,我是否应该担心它被释放?

考虑以下代码,std::functionf=[](){};std::function*fp=newstd::function(f);每当程序离开这些行的上下文时(假设它们在函数内部被调用并且函数返回),f和fp的内存可能会在一些点。这很好,因为我只对fp感兴趣,而且我得到了它的拷贝。关键是有一个函数指针(fp),以后我可以随时调用它。所以,只要我不deletefp,问题就是:f是否会被释放,导致fp无效? 最佳答案 声明:std::function*fp=newstd::function(f);调用复制构造函数function(st

c++ - 从 lambda 构造 std::function 参数

我有以下模板化函数(编译器中启用了C++最新标准-但也许17就足够了)。#includetemplatevoidMyFunction(conststd::function&callback);intmain(){MyFunction(std::function([](int){}));MyFunction([](int){});}当我将它显式转换为std::function时,第一个调用编译通过,但第二个调用没有编译。在第一种情况下,模板推导是自动完成的,编译器只知道它应该将其转换为某个std::function并能够推导参数和返回类型。但是在第二种情况下,它应该(?)也知道lambd

c++ - boost static_vector 而不是 std::is_trivially_destructible

根据thisexample(左例)#include#includestructX{intk;std::arraya;boost::container::static_vectorb;~X()=default;};inthuh(){std::arrayx;return0;}看起来像boost::container::static_vector当T时可以轻易破坏是(当b被销毁时,不会在X上循环)。huh优化为xoreax,eax;ret(即return0不遍历数组。当我改用具有非平凡析构函数的包含类型时(右例)#include#includestructY{~Y();};structX{i

c++ - 基类中的唯一指针禁止实例化,错误为 "attempting to reference a deleted function"

我将我的C++工具链从VisualStudio2013更新到VisualStudio2017/2019。现在我遇到了一些形式的编译错误:(13):errorC2280:'OfflineFixture::OfflineFixture(constOfflineFixture&)':attemptingtoreferenceadeletedfunction(8):note:compilerhasgenerated'OfflineFixture::OfflineFixture'here(8):note:'OfflineFixture::OfflineFixture(constOfflineFi

c++ - 编译器错误 : ‘std::array<...>::~array()’ is implicitly deleted

我有以下.hpp文件:#ifndefCODE_HPP#defineCODE_HPP#include#includeusingstd::vector;usingstd::array;template>classstack;template,typenameK=stack>classstack_array;templateclassstack{Cpile;stack();~stack();voidpush(T&);friendclassstack_array>;};templateclassstack_array{private:staticconstsize_tmax_elem=10;a

c++ - 警告: "when type is in parentheses, array cannot have dynamic size"?的原因是什么

我已经发布了一个关于与数组的动态内存分配相关的GCC错误的问题:Anerrorisissuedbygccrelativetoparsingtype-idinanewexpression现在使用ClangHEAD10.0.0我收到以下警告:rog.cc:9:37:warning:whentypeisinparentheses,arraycannothavedynamicsizeint(**a)[N3]=new(int(*[n1])[N3]);~~^~~当我运行这个演示程序时:#includeintmain(){constsize_tN3=4;size_tn1=2;int(**a)[N3]