英語で読む

次の方法で共有


LocalVariableInfo クラス

定義

ローカル変数の属性を取得し、ローカル変数のメタデータにアクセスできるようにします。

public class LocalVariableInfo
[System.Runtime.InteropServices.ComVisible(true)]
public class LocalVariableInfo
継承
LocalVariableInfo
派生
属性

次の例では、 という名前 MethodBodyExampleのテスト メソッドを定義し、そのローカル変数情報を表示します。 メソッドは GetMethodBody 、テスト メソッドのオブジェクトを MethodBody 取得するために使用されます。 LocalVariablesその後、 プロパティを使用してオブジェクトのLocalVariableInfo一覧を取得し、その型とインデックス順序を表示します。

このコード例は、MethodBody クラスのために提供されている大規模な例の一部です。

using System;
using System.Reflection;

public class Example
{
    public static void Main()
    {
        // Get method body information.
        MethodInfo mi = typeof(Example).GetMethod("MethodBodyExample");
        MethodBody mb = mi.GetMethodBody();
        Console.WriteLine("\r\nMethod: {0}", mi);

        // Display the general information included in the
        // MethodBody object.
        Console.WriteLine("    Local variables are initialized: {0}",
            mb.InitLocals);
        Console.WriteLine("    Maximum number of items on the operand stack: {0}",
            mb.MaxStackSize);

// Display information about the local variables in the
// method body.
Console.WriteLine();
foreach (LocalVariableInfo lvi in mb.LocalVariables)
{
    Console.WriteLine("Local variable: {0}", lvi);
}
    }

    // The Main method contains code to analyze this method, using
    // the properties and methods of the MethodBody class.
    public void MethodBodyExample(object arg)
    {
        // Define some local variables. In addition to these variables,
        // the local variable list includes the variables scoped to
        // the catch clauses.
        int var1 = 42;
        string var2 = "Forty-two";

        try
        {
            // Depending on the input value, throw an ArgumentException or
            // an ArgumentNullException to test the Catch clauses.
            if (arg == null)
            {
                throw new ArgumentNullException("The argument cannot be null.");
            }
            if (arg.GetType() == typeof(string))
            {
                throw new ArgumentException("The argument cannot be a string.");
            }
        }

        // This filter clause selects only exceptions that derive
        // from the ArgumentException class.
        // Other exceptions, including ArgumentException itself,
        // are not handled by this filter clause.
        catch (ArgumentException ex) when (ex.GetType().IsSubclassOf(typeof(ArgumentException)))
        {
            Console.WriteLine("Filter clause caught: {0}", ex.GetType());
        }

        // This catch clause handles the ArgumentException class, and
        // any other class derived from Exception.
        catch(Exception ex)
        {
            Console.WriteLine("Ordinary exception-handling clause caught: {0}",
                ex.GetType());
        }
        finally
        {
            var1 = 3033;
            var2 = "Another string.";
        }
    }
}

// This code example produces output similar to the following:
//
//Method: Void MethodBodyExample(System.Object)
//    Local variables are initialized: True
//    Maximum number of items on the operand stack: 2
//
//Local variable: System.Int32 (0)
//Local variable: System.String (1)
//Local variable: System.Exception (2)
//Local variable: System.Boolean (3)

注釈

メソッド内のローカル変数の一覧を取得するには、 プロパティを MethodBody.LocalVariables 使用します。 オブジェクトの を MethodBase.GetMethodBody 取得するには、 MethodBody メソッドを MethodInfo 使用します。

注意

ローカル変数名はメタデータに保持されません。 Microsoft 中間言語 (MSIL) では、ローカル変数はローカル変数シグネチャ内の位置によってアクセスされます。

コンストラクター

LocalVariableInfo()

LocalVariableInfo クラスの新しいインスタンスを初期化します。

プロパティ

IsPinned

ローカル変数が参照するオブジェクトがメモリに固定されているかどうかを示す Boolean 値を取得します。

LocalIndex

メソッド本体内のローカル変数のインデックスを取得します。

LocalType

ローカル変数の型を取得します。

メソッド

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。

(継承元 Object)
GetHashCode()

既定のハッシュ関数として機能します。

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。

(継承元 Object)
ToString()

ユーザーが判読できる、ローカル変数を示す文字列を返します。

適用対象

製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

こちらもご覧ください