ParameterModifier 構造体

定義

型が変更されているパラメーター シグネチャでバインドを機能させるためにパラメーターに修飾子をアタッチします。Attaches a modifier to parameters so that binding can work with parameter signatures in which the types have been modified.

public value class ParameterModifier
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public struct ParameterModifier
type ParameterModifier = struct
Public Structure ParameterModifier
継承
ParameterModifier
属性

次のコード例では、3つの文字列引数 (1 番目と3番目の引数) が参照によって渡されるメンバーに対してこれを示します。The following code example shows this for a member that has three string arguments, the first and third of which are passed by reference. という名前objの変数に、COM オブジェクトへの参照が含まれているとします。Assume that a variable named obj contains a reference to the COM object.

// Create an array containing the arguments.
array<Object^>^ args = {"Argument 1", "Argument 2", "Argument 3" };

// Initialize a ParameterModifier with the number of parameters.
ParameterModifier p = ParameterModifier(3);

// Pass the first and third parameters by reference.
p[0] = true;
p[2] = true;

// The ParameterModifier must be passed as the single element
// of an array.

array<ParameterModifier>^ mods = { p };

// Invoke the method late bound.
obj->GetType()->InvokeMember("MethodName", BindingFlags::InvokeMethod,
     nullptr, obj, args, mods, nullptr, nullptr);
// Create an array containing the arguments.
object[] args = {"Argument 1", "Argument 2", "Argument 3" };

// Initialize a ParameterModifier with the number of parameters.
ParameterModifier p = new ParameterModifier(3);

// Pass the first and third parameters by reference.
p[0] = true;
p[2] = true;

// The ParameterModifier must be passed as the single element
// of an array.
ParameterModifier[] mods = { p };

// Invoke the method late bound.
obj.GetType().InvokeMember("MethodName", BindingFlags.InvokeMethod,
     null, obj, args, mods, null, null);
' Create an array containing the arguments.
Dim args As Object = {"Argument 1", "Argument 2", "Argument 3" }

' Initialize a ParameterModifier with the number of parameters.
Dim p As New ParameterModifier(3)

' Pass the first and third parameters by reference.
p(0) = True
p(2) = True

' The ParameterModifier must be passed as the single element
' of an array.
Dim mods() As ParameterModifier = { p }

' Invoke the method late bound.
obj.GetType().InvokeMember("MethodName", BindingFlags.InvokeMethod, _
     Nothing, obj, args, mods, Nothing, Nothing)

注釈

構造ParameterModifier体は、遅延バインディングType.InvokeMember(String, BindingFlags, Binder, Object, Object[], ParameterModifier[], CultureInfo, String[])にアクセスされる COM コンポーネントへの参照によってパラメーターを渡すときに、メソッドオーバーロードと共に使用されます。The ParameterModifier structure is used with the Type.InvokeMember(String, BindingFlags, Binder, Object, Object[], ParameterModifier[], CultureInfo, String[]) method overload when passing parameters by reference to a COM component that is accessed late bound. 参照によって渡されるパラメーターは、1つの要素をParameterModifier含む配列で渡す必要がある1つの構造体によって指定されます。The parameters that are to be passed by reference are specified by a single ParameterModifier structure, which must be passed in an array containing a single element. この配列ParameterModifier内の1つの構造体は、呼び出されるメンバーのパラメーターの数で初期化される必要があります。The single ParameterModifier structure in this array must be initialized with the number of parameters in the member that is to be invoked. これらのパラメーターのうち、どのパラメーターが参照渡しで渡されるかItem[Int32]を示すには、 C#プロパティのtrue値 (のインデクサー) をに設定します。これにより、パラメーターの0から始まる位置に対応するインデックス番号が設定されます。To indicate which of these parameters are passed by reference, set the value of the Item[Int32] property (the indexer in C#) to true for the index number corresponding to the zero-based position of the parameter.

コンストラクター

ParameterModifier(Int32)

指定されたパラメーター数を表す ParameterModifier 構造体の新しいインスタンスを初期化します。Initializes a new instance of the ParameterModifier structure representing the specified number of parameters.

プロパティ

Item[Int32]

指定したインデックス位置にあるパラメーターが現在の ParameterModifier によって変更されるかどうかを指定する値を取得または設定します。Gets or sets a value that specifies whether the parameter at the specified index position is to be modified by the current ParameterModifier.

適用対象