次の方法で共有


StrongNameIdentityPermission.Union メソッド

現在のアクセス許可と指定したアクセス許可の和集合を表すアクセス許可を作成します。

Overrides Public Function Union( _
   ByVal target As IPermission _) As IPermission Implements IPermission.Union
[C#]
public override IPermission Union(IPermissiontarget);
[C++]
public: IPermission* Union(IPermission* target);
[JScript]
public override function Union(
   target : IPermission) : IPermission;

パラメータ

  • target
    現在のアクセス許可と和集合を持つアクセス許可。これは、現在のアクセス許可と同じ型であることが必要です。

戻り値

現在のアクセス許可と指定したアクセス許可の和集合を表す新しいアクセス許可。

実装

IPermission.Union

例外

例外の種類 条件
ArgumentException target パラメータが null 参照 (Visual Basic では Nothing) ではなく、現在のアクセス許可と同じ型でもありません。

解説

Union を呼び出すと、現在のアクセス許可と指定したアクセス許可の両方が表す操作をすべて表すアクセス許可が作成されます。いずれかのアクセス許可を要求し、その要求が満たされた場合、両者の和集合を表すアクセス許可に対する要求も満たされます。

アクセス許可と null 参照 (Visual Basic では Nothing) の和集合では、アクセス許可は null 参照 (Nothing) にはなりません。アクセス許可とそのアクセス許可のサブセットの和集合では、アクセス許可に残りの部分が含まれます。その他の組み合わせでは、アクセス許可が null 参照 (Nothing) になります。

使用例

[Visual Basic, C#, C++] 次に示すのは、 Union メソッドを使用した場合の結果を示す例です (メソッドの使用方法を示すものではありません)。よりよく理解するためには、コード全体を記述して実行し、その出力を確認することをお勧めします。ここに示すコードは、より長いコードの一部です。完全なコードについては、 StrongNameIdentityPermission クラスを参照してください。

 
' Union creates a new permission that is the union of the current permission and the specified permission.
Private Function UnionDemo() As Boolean

    Dim returnValue As Boolean = True

    Dim Sn1, Sn2 As String
    Dim SnIdPerm1, SnIdPerm2 As StrongNameIdentityPermission
    Dim SnIdPerm3 As IPermission

    Dim SnGen1 As New SnGenerator()
    Dim SnGen2 As New SnGenerator()

    SnGen1.ResetIndex()
    While SnGen1.CreateSn(SnIdPerm1, Sn1)
        If SnIdPerm1 Is Nothing Then
            GoTo ContinueWhile1
        End If
        Console.WriteLine("**********************************************************" + ControlChars.Lf)
        SnGen2.ResetIndex()

        While SnGen2.CreateSn(SnIdPerm2, Sn2)

            Try
                If SnIdPerm2 Is Nothing Then
                    GoTo ContinueWhile2
                End If
                Dim firstPermission As String = IIf(Sn1 = "" Or Sn1 Is Nothing, "null", Sn1)
                Dim secondPermission As String = IIf(Sn2 = "" Or Sn2 Is Nothing, "null", Sn2)
                SnIdPerm3 = CType(SnIdPerm1.Union(SnIdPerm2), StrongNameIdentityPermission)
                SnIdPerm3 = SnIdPerm1.Union(SnIdPerm2)

                If SnIdPerm3 Is Nothing Then
                    Console.WriteLine(("The union of " + firstPermission + IIf(firstPermission.Length < 10, "  ", ControlChars.Lf + ControlChars.Tab) + "and  " + secondPermission + " is null"))
                Else
                    Console.WriteLine(("The union of " + firstPermission + IIf(firstPermission.Length < 10, "  ", ControlChars.Lf + ControlChars.Tab) + "and  " + secondPermission + " = " + ControlChars.Lf + ControlChars.Tab + CType(SnIdPerm3, StrongNameIdentityPermission).Name.ToString()))
                End If
            Catch e As Exception
                Console.WriteLine(("An exception was thrown for union " + e.ToString()))
                returnValue = False
            End Try
ContinueWhile2:
        End While
ContinueWhile1:
    End While


    Return returnValue
End Function 'UnionDemo


[C#] 
// Union creates a new permission that is the union of the current permission and the specified permission.
        private bool UnionDemo()
        {

            bool returnValue = true;

            string sn1,sn2;
            StrongNameIdentityPermission snIdPerm1,snIdPerm2;
            IPermission snIdPerm3;

            SnGenerator snGen1 = new SnGenerator();
            SnGenerator snGen2 = new SnGenerator();

            snGen1.ResetIndex();
            while(snGen1.CreateSn(out snIdPerm1, out sn1)) 
            {
                if(snIdPerm1 == null) continue;
                
                Console.WriteLine("**********************************************************\n");
                snGen2.ResetIndex();

                    while(snGen2.CreateSn(out snIdPerm2, out sn2)) 
                    {

                        try
                        {
                            if(snIdPerm2 == null) continue;

                            string firstPermission = sn1 == "" | sn1 == null ? "null" : sn1 ;
                            string secondPermission = sn2 == "" | sn2 == null ? "null" : sn2;
                            snIdPerm3 = (StrongNameIdentityPermission)snIdPerm1.Union(snIdPerm2);
                            snIdPerm3 = snIdPerm1.Union(snIdPerm2);

                            if(snIdPerm3 == null) 
                            {
                                Console.WriteLine("The union of " + firstPermission + 
                                    ((firstPermission.Length < 10) ? "  " :  "\n\t") +
                                        "and  "  + secondPermission + " is null");
                            }
                            else
                            {
                                Console.WriteLine("The union of " + firstPermission + 
                                    ((firstPermission.Length < 10) ? "  " :  "\n\t") +
                                     "and  " + secondPermission + " = \n\t" + 
                                    ((StrongNameIdentityPermission)snIdPerm3).Name.ToString());
                            }
                        }
                        catch(Exception e) 
                        {
                            Console.WriteLine("An exception was thrown for union " + e);
                            returnValue=false;
                        }

                }
                
            }

            return returnValue;

        }

[C++] 
// Union creates a new permission that is the union of the current permission and the specified permission.
bool UnionDemo() {

   bool returnValue = true;

   String* sn1, *sn2;
   StrongNameIdentityPermission* snIdPerm1, *snIdPerm2;
   IPermission* snIdPerm3;

   SnGenerator* snGen1 = new SnGenerator();
   SnGenerator* snGen2 = new SnGenerator();

   snGen1->ResetIndex();
   while(snGen1->CreateSn(&snIdPerm1, &sn1)) {
      if (snIdPerm1 == 0) continue;

      Console::WriteLine(S"**********************************************************\n");
      snGen2->ResetIndex();

      while(snGen2->CreateSn(&snIdPerm2, &sn2)) {

         try {
            if (snIdPerm2 == 0) continue;

            String* firstPermission = sn1->Equals(S"") || sn1 == 0 ? S"null" : sn1 ;
            String* secondPermission = sn2->Equals(S"") || sn2 == 0 ? S"null" : sn2;
            snIdPerm3 = dynamic_cast<StrongNameIdentityPermission*>(snIdPerm1->Union(snIdPerm2));
            snIdPerm3 = snIdPerm1->Union(snIdPerm2);

            if (snIdPerm3 == 0) {
               Console::WriteLine(S"The union of {0}{1}and  {2} is null",
                  firstPermission, ((firstPermission->Length < 10) ? S"  " :  S"\n\t"),
                  secondPermission);
            } else {
               Console::WriteLine(S"The union of {0}{1}and  {2} = \n\t{3}",
                  firstPermission,
                  ((firstPermission->Length < 10) ? S"  " :  S"\n\t"),
                  secondPermission,
                  (dynamic_cast<StrongNameIdentityPermission*>(snIdPerm3))->Name);
            }
         } catch (Exception* e) {
            Console::WriteLine(S"An exception was thrown for union {0}", e);
            returnValue=false;
         }
      }
   }

   return returnValue;

}

[JScript] JScript のサンプルはありません。Visual Basic、C#、および C++ のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

必要条件

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ

参照

StrongNameIdentityPermission クラス | StrongNameIdentityPermission メンバ | System.Security.Permissions 名前空間