草庐IT

auto_array_ptr

全部标签

c++ - 通过 unique_ptr 和自定义删除器使用自动扣除

我目前正在使用一个C库,该库定义了许多数据类型,所有这些类型都需要由用户管理它们的生命周期。有许多函数以这种方式定义:int*create(){returnnewint();}voiddestroy(int*i){deletei;}其中大部分在创建后不需要访问。他们只需要存在。因此,我尝试使用在我需要它们存在的范围内声明的unique_ptr来管理它们。这样的声明是这样的://NotethatI'mavoidingwritingthetype'snamemanually.autoa=std::unique_ptr,decltype(&destroy)>{create(),&destro

c++ - 为什么这个悬空的 std::weak_ptr 不会导致 SEGFAULT?

这个问题在这里已经有了答案:Whendoesinvokingamemberfunctiononanullinstanceresultinundefinedbehavior?(2个答案)关闭4年前。在下面的代码中,我在范围内创建了一个shared_ptr并将其分配给一个weak_ptr。为什么在运行代码时我没有得到SEGFAULT,因为wp应该在范围之外无效,对吧?namespace{structDummy{intx;voidfoo(){std::coutwp;{autosp=std::make_shared();wp=sp;}wp.lock()->foo();};

c++ - 当通过 FFI 从 Rust 调用时,您如何使用返回 shared_ptr<T> 的 C++ 函数?

C++shared_ptrcreate_foo();使用rustextern"C"{pubfncreate_foo()->???;}Bindgen将shared_ptr变成不透明的blob。我不能只使用原始指针,因为这样C++代码就不知道我有一个对Foo的引用,并且可能会调用它的解构函数。 最佳答案 std::shared_ptr是一个C++类和一个非平凡的类型,不能按原样从库中导出——您需要它在目标语言中的定义符合C++中的定义.要使用FFI,您需要为您的库函数提供一个简单的CABI(C++ABI不稳定,可能会在编译器版本之间发生

c++ - 动态分配 std::unique_ptr 有什么用?

使用new创建一个std::unique_ptr是否有意义?在下面的代码片段中,我怀疑std::unique_ptr管理的SimpleClass对象不会被销毁,除非我删除std::unique_ptr我自己。我想不出它在什么情况下有用,所以我想知道是否存在实际使用它的情况。std::unique_ptr*ptr_to_unique_ptr=newstd::unique_ptr();ptr_to_unique_ptr->reset(newvector_test::SimpleClass(555));deleteptr_to_unique_ptr; 最佳答案

c# - memcpy array 到 int 的 C# 等价物是什么?

编辑:我认为这个问题与潜在的重复问题不同,因为那个问题的答案都不包含我使用的方法,即BitConverter类。如果我将其标记为不重复,则删除潜在的重复问题链接hereitis.我想知道这段代码的C#等价物是什么考虑到数组中的每个元素都是一个字节并且它被复制到一个int。byteoffsetdata[sizeof(int)]={0,0,0,0};offsetdata[0]=m_Response[responseIndex++];offsetdata[1]=m_Response[responseIndex++];offsetdata[2]=m_Response[responseIndex

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++ - 将 std::map<int, std::shared_ptr<Base>> 转换为 std::map<int, std::shared_ptr<Derived>> 的最有效安全方法

我们目前存储了几个不同的数据模型集合,如下所示:std::map>>models;字符串映射到一个已知的类型列表,这都是通过序列化处理的。嵌套映射包含“对象ID”和关联(反序列化)std::shared_ptr的集合DataObject是一个基类,我们从中派生出多种类型。我们有一个方法来获取给定类型的所有数据对象:staticstd::map>*getAll(std::stringtype);这只是在给定的“类型”键处返回指向map的指针。今天我遇到了一个代码审查来添加我认为调用UB但似乎起作用的以下内容。这让我有点紧张并寻找有效的解决方案:templatestaticstd::map

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]

c++ - 为什么这些 shared_ptr 不指向同一个容器?

我有一个类模型:classModel{...boost::shared_ptr_deck;boost::shared_ptr_stack[22];};Deck继承自CardStack。我试图让_stack[0]指向与_deck指向相同的东西:{_deck=boost::shared_ptr(newDeck());_stack[0]=_deck;}似乎对_stack[0]的_deck的赋值导致生成了_deck的拷贝。(我知道这一点是因为对_stack[0]的修改不会导致对_deck的修改。)如何让它们指向同一事物?好的-没有调用复制构造函数。我已经通过实现它并查看它是否被调用来验证这一点

如何通过引用对Android Auto MediaBrowser的引用来在MediaBrowserServiceCompat中设置Extra_page和extra_page_size?

我有一个Android自动应用程序。我想利用分页以在应用程序中浏览。似乎您可以通过获取对MediaBrowserCompat的引用并在.subscribe()中传递这些常数来设置Extra_page和extra_page_size。但是,我无法弄清楚如何获得对AndroidAutoAudio用来调用.subscribe()的MediaBrowserCompat的引用。对于应该简单的事情来说,这似乎太复杂了,我只是想出事情吗?看答案如何获取对AndroidAutoMediaBrowser的引用?为此,您想知道包名称和类名(如果您要在应用程序之外绑定它)。如果您不知道这些详细信息,则可以从软件包管