InternalsVisibleToAttribute(String) Конструктор
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Инициализирует новый экземпляр класса InternalsVisibleToAttribute с именем указанной сборки друга.
public:
InternalsVisibleToAttribute(System::String ^ assemblyName);
public InternalsVisibleToAttribute (string assemblyName);
new System.Runtime.CompilerServices.InternalsVisibleToAttribute : string -> System.Runtime.CompilerServices.InternalsVisibleToAttribute
Public Sub New (assemblyName As String)
Параметры
- assemblyName
- String
Имя дружественной сборки.
Примеры
подписанные сборки
В следующем примере атрибут InternalsVisibleToAttribute используется для создания метода internal
с именем AppendDirectorySeparator
в подписанной сборке, видимой для другой подписанной сборки. Он определяет класс FileUtilities
, включающий внутренний метод AppendDirectorySeparator
. Атрибут InternalsVisibleToAttribute применяется к сборке, содержащей класс FileUtilities
. Атрибут позволяет сборке с именем Friend1
получить доступ к этому внутреннему элементу.
//
// The source code should be saved in a file named Example1.cs. It
// can be compiled at the command line as follows:
//
// csc /t:library /keyfile:<snkfilename> Assembly1.cs
//
// The public key of the Friend1 file should be changed to the full
// public key stored in your strong-named key file.
//
using System;
using System.IO;
using System.Runtime.CompilerServices;
[assembly: InternalsVisibleTo("Friend1, PublicKey=002400000480000094" +
"0000000602000000240000525341310004000" +
"001000100bf8c25fcd44838d87e245ab35bf7" +
"3ba2615707feea295709559b3de903fb95a93" +
"3d2729967c3184a97d7b84c7547cd87e435b5" +
"6bdf8621bcb62b59c00c88bd83aa62c4fcdd4" +
"712da72eec2533dc00f8529c3a0bbb4103282" +
"f0d894d5f34e9f0103c473dce9f4b457a5dee" +
"fd8f920d8681ed6dfcb0a81e96bd9b176525a" +
"26e0b3")]
public class FileUtilities
{
internal static string AppendDirectorySeparator(string dir)
{
if (! dir.Trim().EndsWith(Path.DirectorySeparatorChar.ToString()))
return dir.Trim() + Path.DirectorySeparatorChar;
else
return dir;
}
}
'
' The source code should be saved in a file named Example1.cs. It
' can be compiled at the command line as follows:
'
' vbc Assembly1.vb /t:library /keyfile:<snkfilename>
'
' The public key of the Friend1 file should be changed to the full
' public key stored in your strong-named key file.
'
Imports System.IO
Imports System.Runtime.CompilerServices
<Assembly:InternalsVisibleTo("Friend1, PublicKey=002400000480000094" + _
"0000000602000000240000525341310004000" + _
"001000100bf8c25fcd44838d87e245ab35bf7" + _
"3ba2615707feea295709559b3de903fb95a93" + _
"3d2729967c3184a97d7b84c7547cd87e435b5" + _
"6bdf8621bcb62b59c00c88bd83aa62c4fcdd4" + _
"712da72eec2533dc00f8529c3a0bbb4103282" + _
"f0d894d5f34e9f0103c473dce9f4b457a5dee" + _
"fd8f920d8681ed6dfcb0a81e96bd9b176525a" + _
"26e0b3")>
Public Class FileUtilities
Friend Shared Function AppendDirectorySeparator(dir As String) As String
If Not dir.Trim().EndsWith(Path.DirectorySeparatorChar) Then
Return dir.Trim() + Path.DirectorySeparatorChar
Else
Return dir
End If
End Function
End Class
Если следующий пример компилируется в сборку с строгим именем Friend1
, он может успешно вызвать метод FileUtilities.AppendDirectorySeparator
, даже если этот метод является внутренним для сборки Assembly1
. Обратите внимание, что при компиляции в C# из командной строки необходимо использовать переключатель компилятора /out, чтобы убедиться, что имя дружественной сборки доступно при привязке компилятора к внешним ссылкам.
//
// The assembly that exposes its internal types to this assembly should be
// named Assembly1.dll.
//
// The public key of this assembly should correspond to the public key
// specified in the class constructor of the InternalsVisibleTo attribute in the
// Assembly1 assembly.
//
#using <Assembly1.dll> as_friend
using namespace System;
void main()
{
String^ dir = L"C:\\Program Files";
dir = FileUtilities::AppendDirectorySeparator(dir);
Console::WriteLine(dir);
}
// The example displays the following output:
// C:\Program Files\
//
// The source code should be saved in a file named Friend1.cs. It
// can be compiled at the command line as follows:
//
// csc /r:Assembly1.dll /keyfile:<snkfilename> /out:Friend1.dll Friend1.cs
//
// The public key of the Friend1 assembly should correspond to the public key
// specified in the class constructor of the InternalsVisibleTo attribute in the
// Assembly1 assembly.
//
using System;
public class Example
{
public static void Main()
{
string dir = @"C:\Program Files";
dir = FileUtilities.AppendDirectorySeparator(dir);
Console.WriteLine(dir);
}
}
// The example displays the following output:
// C:\Program Files\
'
' The source code should be saved in a file named Friend1.vb. It
' can be compiled at the command line as follows:
'
' vbc Friend1.vb /r:Assembly1.dll /keyfile:<snkfilename>
'
' The public key of the Friend1 assembly should correspond to the public key
' specified in the class constructor of the InternalsVisibleTo attribute in the
' Assembly1 assembly.
'
Module Example
Public Sub Main()
Dim dir As String = "C:\Program Files"
dir = FileUtilities.AppendDirectorySeparator(dir)
Console.WriteLine(dir)
End Sub
End Module
' The example displays the following output:
' C:\Program Files\
В следующем примере атрибут InternalsVisibleToAttribute используется для создания элемента internal
сборки без знака, видимой для другой сборки без знака. Атрибут гарантирует, что метод internal
StringLib.IsFirstLetterUpperCase
в сборке с именем UtilityLib
отображается в коде сборки с именем Friend2
. Ниже приведен исходный код для UtilityLib.dll:
using System;
using System.Runtime.CompilerServices;
[assembly: InternalsVisibleToAttribute("Friend2")]
namespace Utilities.StringUtilities
{
public class StringLib
{
internal static bool IsFirstLetterUpperCase(String s)
{
string first = s.Substring(0, 1);
return first == first.ToUpper();
}
}
}
Imports System.Runtime.CompilerServices
<assembly: InternalsVisibleTo("Friend2")>
Namespace Utilities.StringUtilities
Public Class StringLib
Friend Shared Function IsFirstLetterUpperCase(s As String) As Boolean
Dim first As String = s.Substring(0, 1)
Return first = first.ToUpper()
End Function
End Class
End Namespace
неподписанные сборки
В следующем примере представлен исходный код для сборки Friend2
. Обратите внимание, что при компиляции в C# из командной строки необходимо использовать переключатель компилятора /out, чтобы убедиться, что имя дружественной сборки доступно при привязке компилятора к внешним ссылкам.
#using <UtilityLib.dll> as_friend
using namespace System;
using namespace Utilities::StringUtilities;
void main()
{
String^ s = "The Sign of the Four";
Console::WriteLine(StringLib::IsFirstLetterUpperCase(s));
}
using System;
using Utilities.StringUtilities;
public class Example
{
public static void Main()
{
String s = "The Sign of the Four";
Console.WriteLine(StringLib.IsFirstLetterUpperCase(s));
}
}
Imports Utilities.StringUtilities
Module Example
Public Sub Main()
Dim s As String = "The Sign of the Four"
Console.WriteLine(StringLib.IsFirstLetterUpperCase(s))
End Sub
End Module
Комментарии
Конструктор InternalsVisibleToAttribute определяет другую сборку, которая является сборкой, которая имеет доступ к внутренним и частным защищенным типам и членам текущей сборки.
Текущая сборка и другая сборка должны быть без знака, или оба должны быть подписаны строгим именем. (Дополнительные сведения о сборках с строгими именами см. в статье Создание и использование сборок с строгими именами.) Если оба элемента не назначены, аргумент assemblyName
состоит из имени дружественной сборки, указанной без пути к каталогу или расширения файла. Если оба подписываются, assemblyName
состоит из имени дружественной сборки без пути к каталогу или расширения имени файла, а также полного открытого ключа (но не маркера открытого ключа). Другие компоненты строгого имени, например те, которые предоставляют сведения об архитектуре языка и региональных параметров, версии или процессоре, нельзя указать в аргументе assemblyName
.
Важный
Если вы используете компилятор C# для компиляции другую сборку, необходимо явно указать имя выходного файла (.exe или .dll) с помощью параметра компилятора /out. Это необходимо, так как компилятор еще не создал имя сборки, созданной в то время, когда она привязана к внешним ссылкам. Параметр компилятора /out необязателен для компилятора Visual Basic, а соответствующий параметр -out или -o -o компилятор не должен использоваться при компиляции дружественных сборок с помощью компилятора F#.
Вы можете использовать Sn.exe (средство строгого имени) для получения полного открытого ключа из файла с строгим именем (SNK). Для этого выполните следующие действия.
Извлеките открытый ключ из файла ключа с строгим именем в отдельный файл:
Sn -psnk_fileoutfile
Отображение полного открытого ключа в консоли:
Sn -tpoutfile
Скопируйте и вставьте полное значение открытого ключа в исходный код.
Дополнительные сведения об использовании атрибута InternalsVisibleToAttribute см. в следующих статьях:
дружественных сборок (C++) сборки "Друг"