智能指针和std::make_shared函数,c++,linux

复制代码
#include <iostream>  
#include <memory> // 用于std::shared_ptr和std::make_shared  
  
class SocketCanClient {  
public:  
    SocketCanClient() {  
        std::cout << "SocketCanClient created\n";  
    }  
      
    ~SocketCanClient() {  
        std::cout << "SocketCanClient destroyed\n";  
    }  
      
    void doSomething() {  
        std::cout << "SocketCanClient is doing something\n";  
    }  
      
    // 假设这里还有其他与CAN通信相关的方法和成员变量  
};

然后,在程序的某个部分,我们使用std::make_shared来创建SocketCanClient的实例:

复制代码
int main() {  
    // 使用std::make_shared创建SocketCanClient的共享指针  
    std::shared_ptr<SocketCanClient> canBusClient = std::make_shared<SocketCanClient>();  
      
    // 使用共享指针调用SocketCanClient的方法  
    canBusClient->doSomething();  
      
    // 当canBusClient离开作用域或被重置时,SocketCanClient对象将被自动删除  
    // 在这个例子中,当main函数结束时,对象将被销毁  
      
    return 0;  
}

在这个例子中,当main函数开始执行时,canBusClient变量通过std::make_shared被初始化为指向新创建的SocketCanClient对象的共享指针。随后,我们通过canBusClient调用了doSomething方法。当main函数结束时,由于canBusClient是一个局部变量,它将被销毁。由于canBusClient是一个std::shared_ptr,它将自动删除它所指向的SocketCanClient对象,从而避免了手动管理内存的需要。

输出将类似于:

复制代码
SocketCanClient created  
SocketCanClient is doing something  
SocketCanClient destroyed

这展示了如何使用std::make_sharedstd::shared_ptr来管理动态分配的对象的生命周期,并自动处理其内存释放。

相关推荐
vibecoding日记13 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213815 小时前
Verilog参数化游程编码RLE模块
算法
望易15 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络19 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
orion571 天前
Missing Semester Class1:course overview and introduction of shell
linux
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
用户120487221612 天前
Linux驱动编译与加载
linux·嵌入式