草庐IT

C_Func_using_Func_ptr

全部标签

c++ - 唯一 ptr 初始化断言失败

这导致我的程序断言失败:inta=5;std::unique_ptrintptr(&a);错误File:f:\dd\vctools\crt\crtw32\misc\dbgdel.cppLine:32Expression:_BLOCK_TYPE_IS_VALID(pHead>nBlockUse)当我使用“new”或“=make_unique(..)”初始化它时效果很好,但我很想知道为什么我不能通过提供现有变量的地址来初始化它。 最佳答案 变量a在栈上,如果你将它绑定(bind)到一个unique_ptr,当unique_ptr超出作用

c++ - 为什么 (void)sizeof(param) 不是 "using"参数?

我有一个定义如下的宏:#defineUNREF_PARAM_1(a)do{\(void)sizeof(a);\}\while(0)去除编译器警告。在我正在处理的一个新项目中,VS2013突然再次提示未引用的形式参数。奇怪的是,如果我只使用(void)param,它确实有效。有没有人知道为什么它在与(void)sizeof(param)一起使用时不起作用? 最佳答案 因为在sizeof(param)中,param是所谓的未计算的操作数,因此未被odr使用-也就是说,不是在运行时需要。但是,(void)param确实构成了odr-use

c++ - SSE 内在函数 : masking a float and using bitwise and?

基本上这个问题与x86汇编器有关,您有一个数字,您希望使用and将其设置为零或数字本身。.如果你andnumber为负数你会得到number本身,但如果你and它与零你得到零。现在我在使用SSEinstrinsics时遇到的问题是float在二进制中与double不同(或者我弄错了)。无论如何,这是代码,我尝试使用各种float来掩盖第二个和第三个数字(分别为127.0f和99.0f),但没有成功。#include#includevoidprint_4_bit_num(constchar*label,__m128var){float*val=(float*)&var;printf("%

C++ set 和 shared_ptr

我有X类:classX{public:booloperator然后我有以下代码:std::multiset>m;我的问题是:m中的数据是如何排序的?X(shared_ptr)的地址或X.operator?如果按地址X订购,我怎样才能按X.operator订购呢??为此m,如果我想从小到大访问它的元素,下面的代码能保证吗?如果没有,怎么办?for(auto&i:m){f(i);} 最佳答案 您的集合是根据您的key_type排序的,即std::shared_ptr.作为您的std::shared_ptr是comparable,std:

c++ - 为 std::shared_ptr 指定一个删除器,它适用于特定类型或其派生类型的所有对象

我的项目中有以下类classBase{public:virtual~Base(){};}classDer1:publicBase{public:virtual~Der1(){};}classDer2:publicBase{public:virtual~Der2(){};}我将这些类的对象保存为std::shared_ptr。我需要为类型为Base或其任何derivedtypes的所有对象提供自定义删除器。我想要的删除方法中的代码将对所有这些对象做同样的事情,比如classDeleter{public:voidoperator()(Base*b){//Dosomethingdeleteb

c++ - std::shared_ptr:带有自定义删除器的 typedef

这个问题在这里已经有了答案:Typedefashared_ptrtypewithastaticcustomdeleter,similartounique_ptr(2个答案)关闭7年前。我正在使用SDL2开发C++应用程序,并希望使用shared_ptr来保存指针内容。所以我做例如这个:typedefstd::shared_ptrSDLWindowPtr;而且我需要在整个过程中使用自定义删除器。是否可以将其包含在typedef中?如果是,如何?删除函数称为SDL_DestroyWindow。如果没有,如何让shared_ptr使用SDL_DestroyWindow作为自定义删除函数?提前

c++ - 另一个命名空间内的 `using namespace` 范围

这个问题在这里已经有了答案:scopeofusingdeclarationwithinanamespace(5个答案)关闭5年前。我知道我将using指令的范围限制在一个block或一个函数中。然后它将仅适用于该范围。但是如果该block是一个命名空间,它显然适用于同一命名空间的所有block。那是对的吗?至少,以下示例表明:(http://ideone.com/K8dk7E)namespaceN1{structFoo{};}namespaceN2{usingnamespaceN1;Foof;}namespaceN2{Foof2;}intmain(){N2::f2;}我原以为Foof2

c++ - 为什么auto_ptr中有模板复制构造函数和重写操作函数?

为什么auto_ptr中有模板复制构造函数和重写操作函数?C++的ISO标准为auto_ptr指定了以下接口(interface)。(这是直接从2003年的标准中复制出来的。)namespacestd{templatestructauto_ptr_ref{};templateclassauto_ptr{public:typedefXelement_type;//20.4.5.1construct/copy/destroy:explicitauto_ptr(X*p=0)throw();auto_ptr(auto_ptr&)throw();templateauto_ptr(auto_ptr

c++ - 构造一个 constexpr std::weak_ptr

根据std::weak_ptr文档可以构造一个constexprweak_ptr:#includeconstexprweak_ptrfoo{};但是,使用clang尝试此操作会产生编译错误,提示constexpr变量不能具有非文字类型'conststd::weak_ptr',这是因为weak_ptr有一个用户提供的析构函数。(确实如此,查看libc++header)我的问题是,这是一个libc++错误,还是做constexprweak_ptr只是没有意义并且拥有constexpr默认构造函数是一个错误?我可以期待它在未来发挥作用吗? 最佳答案

c++ - 为什么存在 shared_ptr 的原子重载

为什么有shared_ptr的原子重载,如here所述而不是为处理shared_ptr的std::atomic专门化。似乎与其余C++标准库采用的面向对象模式不一致。在使用shared_ptr实现readcopyupdateidiom时,为了确保我做对了我们需要通过这些函数对共享指针进行所有访问(读取和写入)吗? 最佳答案 因为:std::atomicmaybeinstantiatedwithanyTriviallyCopyabletypeT.来源:http://en.cppreference.com/w/cpp/atomic/at