Effective C++读书笔记之十五:在资源管理类中提供对原始资源的访问

Item 15:Provide access to raw resources in resource-managing classes

资源管理类很棒。它们是你对抗资源泄露的堡垒。排除此等泄露是良好设计系统的根本性质。然而许多APIs直接指涉资源,所以除非你发誓永不录用这样的APIs,否则只得绕过资源管理对象直接访问原始资源。

假如你使用智能指针保存factory函数createInvestment的调用结果:

std::tr1::shared_ptr<Investment> pInv(createInvestment());

假设你希望某个函数处理Investment对象,像这样:

int daysHeld(const Investment* pi);

而你想要这么调用它:

int days = daysHeld(pInv);

这样却通不过编译,因为daysHeld需要的是Investment*指针,你传给它的却是一个类型为tr1::shared_ptr<Investment>的对象。

这个时候你需要一个函数可以将RAII class对象转换为其所含之原始资源。有两个方法可以达成目标:显示转换和隐式转换

只能指针tr1::shared _ptr和auto_ptr都提供一个get成员函数,用来执行显示转换,也就是它们会返回智能指针内部的原始指针(的复件):

int days = daysHeld(pInv.get());

此外,你也可以通过指针取值操作符(operator->和operator*),来隐式转换至底部原始指针。

是否该提供一个显示转换函数将RAII class转换为其底部资源,或是应该提供隐式转换,答案主要取决于RAII class被设计执行的特定工作,以及它被使用的情况。最佳设计是坚持条款18的忠告:让接口容易被正确使用,不易被无用。通常显示转换函数如get是比较受欢迎的例子,因为它将“非故意之类型转换”的可能性最小化了。

请记住:

1.APIs往往要求访问原始资源,所以每一个RAII class应该提供一个“取得其所管理之资源”的办法。

2.对原始资源的访问可能经由显示转换或隐式转换。一般而言显示转换比较安全,但隐式转换对客户比较方便。





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章