gpt4 book ai didi

c++ - 将 libusb 设备存储在易于访问的容器中,没有所有权

转载 作者:行者123 更新时间:2023-11-28 04:11:06 25 4
gpt4 key购买 nike

我想存储 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也会释放接口(interface)并自行关闭,这很棒。

问题是,当创建一个新客户端时,它可能会询问一个已经打开的 std::shared_ptr<libusb_device_handle> (我使用“产品字符串”作为唯一描述符)。我不确定如何存储这些。如果我使用 map 到 weak_ptr我将无法创建已创建 shared_ptr 的拷贝秒。如果我使用 shared_ptr 的 map ,设备将永远不会被删除,因为 map 将始终包含一个引用。

就内存管理和容器而言,这里的最佳方法是什么?

最佳答案

您可以将 map 与 std::weak_ptr 一起使用。 weak_ptr 提供了一个方法 lock() 来从 weak_ptr 创建一个 shared_ptr 只要共享对象仍然存在.

您的 map 可能是这样的:

#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,您将必须检查其计算结果是否为真。

关于c++ - 将 libusb 设备存储在易于访问的容器中,没有所有权,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57777352/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com