c++ - 将 libusb 设备存储在易于访问的容器中,无需所有权
问题描述
我想存储libusb_device_handle*
s 供多个客户端使用(一个句柄可以被多个客户端使用),所以我考虑将它们存储为:
libusb_open(device, &handle);
libusb_claim_interface(handle, 0);
auto sharedHandle = std::shared_ptr<libusb_device_handle>(handle, [=](libusb_device_handle* handle) {
libusb_release_interface(handle, 0);
libusb_close(handle);
});
作为参考,客户端如下所示:
struct Client
{
Client(std::shared_ptr<libusb_device_handle> handle_, uint8_t endpoint_) : handle(handle_), endpoint(endpoint_) {}
std::shared_ptr<libusb_device_handle> handle;
uint8_t endpoint;
};
当所有相同的客户端handle
都被销毁时,handle
也会释放接口并关闭自己,这很好。
问题是,当创建一个新客户端时,它可能会询问一个已经打开的客户端std::shared_ptr<libusb_device_handle>
(我使用“产品字符串”作为唯一描述符)。我不知道如何存储这些。如果我将使用地图,weak_ptr
我将无法创建已创建shared_ptr
s 的副本。如果我使用 的地图shared_ptr
,则该设备将永远不会被删除,因为该地图将始终包含参考。
就内存管理和容器而言,这里最好的方法是什么?
解决方案
您可以将地图与std::weak_ptr
. 只要共享对象仍然存在,就提供weak_ptr
一种方法lock()
来创建一个。shared_ptr
weak_ptr
你的地图可能是这样的:
#include <map>
#include <memory>
using libusb_device_handle = ...;
using map_type = std::map<uint8_t, std::weak_ptr<libusb_device_handle>>;
map_type map;
Client get_client(uint8_t endpoint)
{
auto it = map.find(endpoint);
if (it != map.end()) {
return Client(it->second.lock(), endpoint);
}
return Client(std::shared_ptr<libusb_device_handle>(), endpoint);
}
请注意,shared_ptr
如果它包含有效的 libusb_device_handle,则必须检查其计算结果是否为 true。
推荐阅读
- python-3.x - 使用 python 的 FireStore 推送通知
- mysql - 使用 mysql 插入和选择时 Golang-goroutines 中的错误
- android - MuPDF 使用 Android SAF 保存文档
- c++ - C++:'if-else' 和 'switch' 坏了
- android - 在屏幕旋转等之后,使用 Transformations 会产生一个新的 LiveData 值
- mysql - 为什么mysql不使用索引?
- google-cloud-platform - 我无法解除 CloudSQL 实例的暂停
- python - Matplotplt 标签在 jupyter 笔记本中不起作用
- python-3.x - 我的时间序列预测变压器模型的训练损失和准确度都在下降
- python - Python 的复制对象即使在被删除后仍然存在(copy.copy 函数)