次の方法で共有


方法: 署名のないフレンド アセンブリを作成する (C# および Visual Basic)

次の例は、署名のないアセンブリと共にフレンド アセンブリを使用する方法を示しています。

Visual Studio でアセンブリとフレンド アセンブリを作成するには

  1. Visual Studio コマンド プロンプトを開きます。

  2. 次のコードを含む、friend_signed_A という名前の Visual Basic ファイルまたは C# ファイルを作成します。 このコードは、InternalsVisibleToAttribute 属性により、friend_signed_B をフレンド アセンブリとして宣言します。

    ' friend_unsigned_A.vb 
    ' Compile with:  
    ' Vbc /target:library friend_unsigned_A.vb 
    Imports System.Runtime.CompilerServices
    Imports System
    
    <Assembly: InternalsVisibleTo("friend_unsigned_B")> 
    
    ' Friend type. 
    Friend Class Class1
        Public Sub Test()
            Console.WriteLine("Class1.Test")
        End Sub 
    End Class 
    
    ' Public type with Friend member. 
    Public Class Class2
        Friend Sub Test()
            Console.WriteLine("Class2.Test")
        End Sub 
    End Class
    
    // friend_unsigned_A.cs 
    // Compile with:  
    // csc /target:library friend_unsigned_A.cs 
    using System.Runtime.CompilerServices;
    using System;
    
    [assembly: InternalsVisibleTo("friend_unsigned_B")]
    
    // Type is internal by default. 
    class Class1
    {
        public void Test()
        {
            Console.WriteLine("Class1.Test");
        }
    }
    
    // Public type with internal member. 
    public class Class2
    {
        internal void Test()
        {
            Console.WriteLine("Class2.Test");
        }
    }
    
  3. 次のコマンドを使用して friend_signed_A をコンパイルおよび署名します。

    Vbc /target:library friend_unsigned_A.vb
    
    csc /target:library friend_unsigned_A.cs
    
  4. 次のコードを含む、friend_unsigned_B という名前の Visual Basic ファイルまたは C# ファイルを作成します。 friend_unsigned_A が friend_unsigned_B をフレンド アセンブリとして指定しているため、friend_unsigned_B 内のコードは、friend_unsigned_A の Friend 型 (Visual Basic) または internal 型 (C#) とそのメンバーにアクセスできます。

    ' friend_unsigned_B.vb 
    ' Compile with:  
    ' Vbc /r:friend_unsigned_A.dll friend_unsigned_B.vb 
    Module Module1
        Sub Main()
            ' Access a Friend type. 
            Dim inst1 As New Class1()
            inst1.Test()
    
            Dim inst2 As New Class2()
            ' Access a Friend member of a public type.
            inst2.Test()
    
            System.Console.ReadLine()
        End Sub 
    End Module
    
    // friend_unsigned_B.cs 
    // Compile with:  
    // csc /r:friend_unsigned_A.dll /out:friend_unsigned_B.exe friend_unsigned_B.cs 
    public class Program
    {
        static void Main()
        {
            // Access an internal type.
            Class1 inst1 = new Class1();
            inst1.Test();
    
            Class2 inst2 = new Class2();
            // Access an internal member of a public type.
            inst2.Test();
    
            System.Console.ReadLine();
        }
    }
    
  5. 次のコマンドを使用して friend_signed_B をコンパイルします。

    Vbc /r:friend_unsigned_A.dll friend_unsigned_B.vb
    
    csc /r:friend_unsigned_A.dll /out:friend_unsigned_B.exe friend_unsigned_B.cs
    

    コンパイラによって生成されるアセンブリの名前は、InternalsVisibleToAttribute 属性に渡されるフレンド アセンブリ名と一致している必要があります。 /out コンパイラ オプションを使用すると、アセンブリを明示的に設定できます。

    C# では、/out コンパイラ オプションを使用して出力アセンブリ (.exe または .dll) の名前を明示的に指定する必要があります。 Visual Basic の場合、これは省略可能です。 詳細については、「/out (Visual Basic)」および「/out (C# コンパイラ オプション)」を参照してください。

  6. friend_signed_B.exe ファイルを実行します。

    このプログラムでは、2 つの文字列 "Class1.Test" と "Class2.Test" が出力されます。

セキュリティ

InternalsVisibleToAttribute 属性と StrongNameIdentityPermission クラスには、いくつかの類似点があります。 主な違いは、StrongNameIdentityPermission は特定のコード セクションを実行するのにセキュリティ アクセス許可を要求し、InternalsVisibleToAttribute 属性は Friend 型 (Visual Basic) または internal 型 (C#) とそのメンバーの参照可能範囲を制御するという点です。

参照

処理手順

方法: 署名されたフレンド アセンブリを作成する (C# および Visual Basic)

関連項目

InternalsVisibleToAttribute

概念

アセンブリとグローバル アセンブリ キャッシュ (C# および Visual Basic)

フレンド アセンブリ (C# および Visual Basic)

C# プログラミング ガイド

その他の技術情報

Visual Basic のプログラミング ガイド