博客
关于我
条款 15:在资源管理类中提供对原始资源的访问
阅读量:317 次
发布时间:2019-03-04

本文共 1285 字,大约阅读时间需要 4 分钟。

为什么要在资源管理类中提供对原始资源的访问?

在软件开发中,资源管理类(Resource Acquisition Is Initialization,RAII)被广泛使用来管理资源,避免了开发者直接处理资源的复杂性。然而,某些应用程序的API可能需要直接访问资源,而不能简单地传递资源管理对象。因此,为了实现这一点,资源管理类需要提供对原始资源的访问方式。

如何做到直接资源访问与获取?

为了在资源管理类中实现直接访问原始资源,可以通过显式转换或隐式转换两种方式。以下是具体实现方法:

显式转换

  • 通过指针访问资源

    在资源管理类中添加一个成员函数 get(),该函数返回一个指针,该指针指向原始资源。

    • 示例:
      class ResourceManager {public:    template
      T* get() { return resource_ptr.get(); }};
    • 该函数类似于 shared_ptrauto_ptr 中的实现方式。
  • 非通过指针访问资源

    如果资源不能通过指针访问,可以直接返回原始资源。

    • 示例:
      class ResourceManager {public:    T get() {        return resource;    }};
  • 隐式转换

  • 通过指针访问资源

    如果资源管理类内部使用智能指针(如 shared_ptrunique_ptr)管理资源,可以通过以下方式实现隐式转换:

    • 使用 * 运算符:
      ResourceManager manager = ...;auto* resource = manager->*
      ; // 或类似操作
    • 使用 ->* 运算符:
      ResourceManager manager = ...;auto* resource = new (manager->*
      );
  • 非通过指针访问资源

    在资源管理类中添加一个隐式转换函数,将资源管理对象直接转换为资源。

    • 示例:
      class ResourceManager
      {public: operator T() { return resource; }};
    • 使用时,只需传递资源管理对象即可。
  • 隐式转换与显式转换的选择?

    选择显式转换或隐式转换取决于具体的开发需求和使用场景:

    • 显式转换

      优点:接口不易被误用,代码更直观,减少潜在的错误风险。
      缺点:用户使用可能显得不够“自然”,需要明确调用特定方法。

    • 隐式转换

      优点:用户使用更为自然,代码更简洁,提升用户体验。
      缺点:如果资源管理类的转换逻辑复杂,可能导致意外的资源释放或其他问题。

    总结

    在资源管理类中提供直接访问原始资源的功能,可以通过显式转换或隐式转换实现。选择哪种方式取决于具体的应用场景和用户习惯。显式转换适合需要高安全性的场景,而隐式转换则更适合追求代码简洁和用户友好的环境。

    转载地址:http://pfgq.baihongyu.com/

    你可能感兴趣的文章
    Oracle内存结构详解(四)--Oracle SGA其他组成部分
    查看>>
    Oracle函数与存储过程和程序包
    查看>>
    Oracle分析函数之LEAD和LAG
    查看>>
    Oracle分组取前n条记录
    查看>>
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>
    oracle创建数据库的步骤
    查看>>
    Oracle创建用户、角色、授权、建表
    查看>>
    Oracle创建用户与授予表空间与权限
    查看>>
    oracle创建表(并且实现ID自增)
    查看>>
    oracle创建视图与生成唯一编号
    查看>>
    oracle删除重复数据保留第一条记录
    查看>>
    oracle判断空值的函数nvl2,【PL/SQL】 NVL,NVL2,COALESCE 三种空值判断函数
    查看>>
    Oracle发布VirtualBox 7.1稳定版!支持ARM、优化了UI、支持Wayland等
    查看>>
    oracle启动三步
    查看>>
    oracle启动关闭服务,启动关闭oracle服务.bat
    查看>>
    Oracle命令行创建数据库
    查看>>
    Oracle和SQL server的数据类型比较
    查看>>
    oracle和sybase的一些区别
    查看>>
    oracle在日本遇到的技术问题
    查看>>
    Oracle在线重定义
    查看>>