Примечание
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
Пакеты, содержащие совместимые платформы, должны гарантировать, что код, скомпилированный против одного, может выполняться с другим. Ниже приведены примеры пар совместимых платформ:
- .NET Standard 2.0 и .NET 7
- .NET 6 и .NET 7
В обоих случаях пользователи могут разрабатывать с использованием .NET Standard 2.0 или .NET 6 и работать на .NET 7. Если двоичные файлы несовместимы между этими платформами, потребители могут в конечном итоге столкнуться с ошибками во время компиляции или во время выполнения.
Проверка пакета выявляет эти ошибки в процессе упаковки. Ниже приведен пример сценария:
Предположим, вы пишете игру, которая работает со строками. Необходимо обеспечивать поддержку как пользователям .NET Framework, так и .NET Core. Изначально ваш проект был ориентирован на .NET Standard 2.0, но теперь вы хотите использовать Span<T>
в .NET 6, чтобы избежать избыточных выделений памяти для строк. Для этого необходимо использовать несколько целевых платформ для .NET Standard 2.0 и .NET 6.
Вы написали следующий код:
#if NET6_0_OR_GREATER
public void DoStringManipulation(ReadOnlySpan<char> input)
{
// use spans to do string operations.
}
#else
public void DoStringManipulation(string input)
{
// Do some string operations.
}
#endif
Затем вы попытаетесь собрать проект (с помощью dotnet pack
или Visual Studio), и оно завершается с ошибкой:
D:\demo>dotnet pack
Microsoft (R) Build Engine version 17.0.0-preview-21460-01+8f208e609 for .NET
Copyright (C) Microsoft Corporation. All rights reserved.
Determining projects to restore...
All projects are up-to-date for restore.
You are using a preview version of .NET. See: https://aka.ms/dotnet-core-preview
You are using a preview version of .NET. See: https://aka.ms/dotnet-core-preview
PackageValidationThrough -> D:\demo\bin\Debug\netstandard2.0\PackageValidationThrough.dll
PackageValidationThrough -> D:\demo\bin\Debug\net6.0\PackageValidationThrough.dll
Successfully created package 'D:\demo\bin\Debug\PackageValidationThrough.1.0.0.nupkg'.
C:\Program Files\dotnet\sdk\6.0.100-rc.1.21463.6\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.Compatibility.Common.targets(32,5): error CP0002: Member 'A.B.DoStringManipulation(string)' exists on lib/netstandard2.0/PackageValidationThrough.dll but not on lib/net6.0/PackageValidationThrough.dll [D:\demo\PackageValidationThrough.csproj]
Вы понимаете, что вместо исключения DoStringManipulation(string)
для .NET 6 необходимо просто предоставить дополнительный DoStringManipulation(ReadOnlySpan<char>)
метод для .NET 6:
#if NET6_0_OR_GREATER
public void DoStringManipulation(ReadOnlySpan<char> input)
{
// use spans to do string operations.
}
#endif
public void DoStringManipulation(string input)
{
// Do some string operations.
}
Вы пробуете снова упаковать проект, и оно удается.
Строгий режим
Вы можете включить строгий режим для этого проверяющего элемента, задав EnableStrictModeForCompatibleFrameworksInPackage
свойство в файле проекта. Включение строгого режима изменяет некоторые правила и применяет другие правила при выявлении различий. Это полезно, если вы хотите, чтобы обе сравниваемые стороны были строго одинаковыми по площади поверхности и по свойствам. Дополнительные сведения см. в разделе "Строгий режим".