文字列のマーシャリング
更新 : 2007 年 11 月
プラットフォーム呼び出しでは、文字列パラメータがコピーされ、必要に応じて .NET Framework 形式 (Unicode) からアンマネージ形式 (ANSI) に変換されます。マネージ文字列は変更不可なので、プラットフォーム呼び出しでは関数から制御が返されるときに、アンマネージ メモリからマネージ メモリへとマネージ文字列はコピーされません。
文字列に関するマーシャリングのオプションを次の表に列挙し、その使用方法を説明し、関連 .NET Framework サンプルへのリンクを示します。
文字列 |
説明 |
サンプル |
---|---|---|
値渡し。 |
文字列を In パラメータとして渡します。 |
|
結果として渡す。 |
アンマネージ コードから文字列を返します。 |
|
参照渡し。 |
StringBuilder を使用して、文字列を In/Out パラメータとして渡します。 |
|
構造体に組み込んで値渡し。 |
文字列を In パラメータである構造体に組み込んで渡します。 |
|
構造体に組み込んで参照渡し (char*)。 |
文字列を In/Out パラメータである構造体に組み込んで渡します。アンマネージ関数は文字バッファへのポインタを要求します。またバッファのサイズは構造体のメンバです。 |
|
構造体に組み込んで参照渡し (char[])。 |
文字列を In/Out パラメータである構造体に組み込んで渡します。アンマネージ関数は埋め込み文字バッファを要求します。 |
|
クラスに組み込んで値渡し (char*)。 |
文字列をクラスに組み込んで渡します (クラスは In/Out パラメータです)。アンマネージ関数は、文字バッファへのポインタを要求します。 |
|
クラスに組み込んで値渡し (char[])。 |
文字列をクラスに組み込んで渡します (クラスは In/Out パラメータです)。アンマネージ関数は埋め込み文字バッファを要求します。 |
|
文字列の配列として値渡し。 |
値渡しされる文字列の配列を作成します。 |
|
文字列を含む構造体の配列として値渡し。 |
文字列を含む構造体の配列を作成し、その配列を値渡しします。 |