- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我目前正在手动管理项目中对象的生命周期。我正在考虑切换到智能指针,特别是 tr1::shared_pointer 和 tr1::weak_ptr。但是,我发现了一些问题,并希望就最佳实践获得一些意见。
考虑下面的类图:
在此图中,粗箭头表示与所有权语义的关联(源负责删除一个或多个目标)。细箭头代表没有所有权的协会。
据我所知,实现与所有权语义关联的一种方法是使用 tr1::shared_ptr(或其集合)。可以使用 tr1::shared_ptr 或 tr1::weak_ptr 实现其他关联。如果前者可能导致循环引用,则禁止使用前者,因为这会阻止资源的正确释放。
如您所见,类 Edge 和 Side 之间有一个关联环。我可以通过使用 tr1::weak_ptrs 实现从 Edge 到 Side 的“左”和“右”关联来轻松打破这一点。但是,我更喜欢使用智能指针在代码中记录关联的所有权语义。所以我只想对图中粗箭头表示的关联使用 shared_ptrs,对其他所有内容使用 weak_ptrs。
现在我的第一个问题是:我应该如上所述自由使用 weak_ptr,还是应该尽可能少地使用它们(只是为了避免循环引用)?
下一个问题是:假设我有一个计算一组顶点平均值的函数。进一步假设我已经实现了从多面体到它的顶点的关联,如下所示:
class Vertex;
class Polyhedron {
protected:
std::vector<std::tr1::shared_ptr<Vertex> > m_vertices;
};
并且我已经实现了从一个边到它的顶点的关联,如下所示:
class Vertex;
class Side {
protected:
std::vector<std::tr1::weak_ptr<Vertex> > m_vertices;
};
请注意,边的顶点集是多面体顶点集的子集。现在假设我有一个计算一组顶点平均值的函数。该函数当前声明如下:
const Vertex centerOfVertices(std::vector<Vertex*> vertices);
现在,如果我如上表示关联,如果我理解正确的话,我突然需要两个函数:
const Vertex centerOfVertices(std::vector<std::tr1::shared_ptr<Vertex> > vertices);
const Vertex centerOfVertices(std::vector<std::tr1::weak_ptr<Vertex> > vertices);
因为我无法在 shared_ptr vector 和 weak_ptr vector 之间进行转换。这对我来说很有趣。我想知道我应该采取什么方法来避免这种情况。
最佳答案
However, I would prefer using the smart pointers to document, in code, the ownership semantics of the associations.
如你所愿。毕竟,这就是他们完美表达的内容。
So I would like to use shared_ptrs only for the associations represented by thick arrows in the diagram, and weak_ptrs for everything else.
去做吧,有一个警告:您的所有权看起来不像共享所有权,它简单,是唯一的所有权。因此,这里合适的智能指针不是 shared_ptr
而是 std::unique_ptr
,然后弱指针将只是原始指针。
Now if I represent the associations as above, I suddenly need two functions …
是的。好吧,或者你使用模板。
或者,由于该函数实际上对共享所有权根本不感兴趣,您可以将原始指针传递给它,但这当然意味着首先从您的结构中获取原始指针,这需要为客户端增加一个步骤,这可能对界面不利。
关于c++ - 使用智能指针建模所有权的含义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11015908/
我正在使用 tcod-rs。用于绘制到 RootConsole 的每个方法都采用一个可变引用。中央循环是一个 while 循环,它等待窗口关闭、清除屏幕、绘制,然后刷新。 “检查窗口关闭”方法也采用可
我写了一个具有这种形式的函数: 结果 f(const IParameter& p); 我的意图是这个签名将明确表明函数没有取得参数 p 的所有权。 问题是 Result 将保留对 IParameter
这个问题在这里已经有了答案: 关闭 9 年前。 Possible Duplicate: What is a smart pointer and when should I use one? 我正在阅
假设我有一个类: class Scheduler { Scheduler(JobService *service); AddJob(JobID id, ISchedule *sched
我试图弄清楚所有权如何与函数 CVMetalTextureGetTexture 一起工作: CVMetalTextureRef textureRef; // ... textureRef is cre
这个问题在这里已经有了答案: Should we pass a shared_ptr by reference or by value? (10 个答案) 关闭 4 年前。 例如 class A {
我正在做一个附带项目,我需要根据他的 gmail 帐户或任何其他参数来验证 channel 是否属于某个用户……这基本上是为了避免假帐户。是否可以? 最佳答案 是的, 跟随 youtube 记录的链接
我在使用Core Foundation Array时发现了一个奇怪的问题!这是代码片段 fname = CFStringCreateWithFormat(kCFAllocatorDefault, NU
有没有一种方法可以设置在 apache 下运行的 php 来创建文件夹,该文件夹的文件夹属于创建它的程序的所有者,而不是由 apache 拥有? 使用 word press 它会创建要上传到的新文件夹
我编写了以下函数来使用 boost.date_time 获取日期/时间字符串. namespace bpt = boost::posix_time; string get_date_time_stri
我在使用 Docker 容器时遇到了一个有点烦人的问题(我在 Ubuntu 上,所以没有像 VMWare 或 b2d 这样的虚拟化)。我已经构建了我的镜像,并且有一个正在运行的容器,它有一个来 sel
根据大多数示例,逻辑上最少有 3 个组织 ( org1, org2, orderer )。 实际上只有 2 个物理组织 ( org1, org2 )。任一组织或约定的第 3 方必须移交订购者组织的职责
我开始学习 Rust,在进行实验时,我发现所有权如何应用于我不理解的元组和数组的方式有所不同。基本上,以下代码显示了差异: #![allow(unused_variables)] struct Inn
我们有一个应用程序,其表单上有许多组件(面板、选项卡、编辑、组合框等)。但根据用户配置文件,其中大多数可以自动填充和/或不可见。因此,用户可以更快地完成工作。 问题:是否有更简单的方法可以在运行时创建
我有以下代码片段: fn f u32>(c: T) { println!("Hello {}", c()); } fn main() { let mut x = 32; let
我想执行示例中的代码: require_once 'google-api-php-client/vendor/autoload.php'; $client = new Google_C
这个问题在这里已经有了答案: What is move semantics? (11 个答案) 关闭 3 年前。 我有一个看起来像这样的构造函数: Thing::Thing(std::vector
我们正在使用服务帐户从服务器上传文件,但它已达到其存储配额限制。所有文件都已添加到另一个用户(具有 100 Gb 存储配额的 @gmail.com 帐户)创建的文件夹下,但上传的所有文件均归该服务帐户
我正处于 this question 中描述的 sme 情况。 .那个提问者找到的解决方案是 Full access !== Owner. I need to read the documentati
我正处于 this question 中描述的 sme 情况。 .那个提问者找到的解决方案是 Full access !== Owner. I need to read the documentati
我是一名优秀的程序员,十分优秀!