gpt4 book ai didi

c++ - 如何从多个对象访问同一个资源?

转载 作者:行者123 更新时间:2023-11-30 04:49:21 30 4
gpt4 key购买 nike

我对 C++ OOP 比较陌生,所以请耐心等待。

我正在使用针对专用硬件(PCIE 模块)实现的 CAN 总线协议(protocol)的第 3 方驱动程序。它带有一个类,允许您实例化 can_readcan_write 对象。

这个库在我自己的程序中使用,我有一个类和上述类的 7 个实例,它们需要访问在主文件的全局范围内定义的 can_write 对象。

我遇到的问题是 can_write 对象。作为驱动程序级库,它从 can_write 对象访问相同的内存地址。如果我有一个按值获取 can_writer 的成员函数,则程序会在访问时崩溃并出现“双重释放或损坏”错误。

我现在通过引用传递 can_writer 对象(参数为“CanClass &a”),它似乎有效,但我不确定这是一个好的做法还是传统的做法它。这是正确的做法吗?如果不是,什么是正确的方法?任何引用资料甚至简短的解释都会非常有帮助!

编辑:我必须避免创建 can_writer 的拷贝,因为它会读取到内存损坏,因此我的 Class Foo 的所有 7 个实例都需要访问完全相同的实例can_write.

最佳答案

您可以在您的类(class)中使用单例模式的变体 (https://en.wikipedia.org/wiki/Singleton_pattern)。

例如,您可以使用 get_can_write() 方法来检查 can_write 对象是否已实例化,如果是,则返回对该对象的引用,否则它会创建一个 can_write 对象,保留对该对象的引用并返回它。

提供 can_write 和 can_read 的类将如下所示:

class Bar {
private:
static can_write* cw;
static can_read* cr;

public:
static can_write* get_can_write(){
if(cw == null)
cw = new can_write;
return cw;
}

static can_read* get_can_read(){
if(cr == null)
cr = new can_read;
return cr;
}
}

使用 can_write 和 can_read 的类看起来像:

class Foo{
public:
void doSomeRead(){
string s = Bar::get_can_read()->doSomething();
}

void doSomeWrite(){
Bar::get_can_write()->doSomething("test");
}
}

关于c++ - 如何从多个对象访问同一个资源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55450086/

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