1

ローカル インターフェイスが使用されているときに Brew でコードを記述すると、反復的でエラーが発生しやすくなり、堅牢になります。

Foo()
{
ISomeInterface* interface = NULL;
int err = ISHELL_Createnstance(…,...,&interface);

err = somethingThatCanFail();
if (AEE_SUCCESS != err)
    ISomeInterface_Release(interface);

err = somethingElseThatCanFail()
if (AEE_SUCCESS != err)
    ISomeInterface_Release(interface);

etc....

関数の終了時にインターフェイスを自動的に解放する RAII クラスを作成するのは簡単ですが、特定のインターフェイスに固有のものになります (もちろん、デストラクタで ISomeInterface_Release を呼び出します)。

さまざまなタイプのインターフェイスに使用できるジェネリック RAII クラスを作成する方法はありますか? つまり、インターフェイス固有のリリースやその他のメカニズムの代わりに、RAII で呼び出すことができる一般的なリリース関数はありますか?

--- 編集 ---- 申し訳ありませんが、最初にこの投稿に C++ および RAII タグを追加しましたが、現在は削除しています。答えとして、C++ の知識ではなく、Brew の知識が必要です。時間を割いて回答してくれた人々のおかげで、最初から情報を追加するべきであり、追加のタグを追加するべきではありませんでした。

4

2 に答える 2

3

shared_ptrあなたが求めることをします:

ISomeInterface* interface = NULL;
int err = ISHELL_Createnstance(…,...,&interface);
std::shared_ptr<ISomeInterface*> pointer(interface, ISomeInterface_Release);

参照: http://www.boost.org/doc/libs/1_46_1/libs/smart_ptr/shared_ptr.htm#constructors


編集ここにサンプルがあります:

#include <cstdio>
#include <memory>

int main(int ac, char **av) {
  std::shared_ptr<FILE> file(fopen("/etc/passwd", "r"), fclose);
  int i;
  while( (i = fgetc(file.get())) != EOF)
    putchar(i);
}
于 2011-05-19T17:18:09.617 に答える
2

デストラクタで指定された関数を呼び出す RAII クラスは次のようになります。

template<typename T, void (*onRelease)(T)>
class scope_destroyer {
    T m_data;

public:
    scope_destroyer(T const &data) 
        : m_data(data)
    {}

    ~scope_destroyer() { onRelease(m_data); }

    //...
};

次に、型T(たとえば a Foo*) と、型の単一パラメーターで呼び出すことができる関数を渡しT、オブジェクトを解放します。

scope_destroyer<Foo, &ISomeInterface_Release> foo(CreateFoo());
于 2011-05-19T16:32:59.483 に答える