.NET 9 中的中断性变更

如果要将应用迁移到 .NET 9,则此处列出的中断性变更可能会影响到你。 变更按技术领域分组,例如 ASP.NET Core 或 Windows 窗体。

本文将每个中断性变更分类为二进制不兼容源不兼容,或者作为行为更改

  • 二进制文件不兼容 - 当针对新的运行时或组件运行时,现有二进制文件可能会遇到行为上的中断性变更(例如加载或执行失败),如果是这样,则需要重新编译。

  • 源代码不兼容 - 当使用新的 SDK 或组件重新编译,或以新的运行时为目标时,现有源代码可能需要更改源才能成功编译。

  • 行为更改 - 现有代码和二进制文件在运行时的行为可能会有所不同。 如果不需要新的行为,则需要更新和重新编译现有代码。

注意

本文是当前正在进行的工作。 这并不是 .NET 9 中的中断性变更的完整列表。 若要查询仍处于待发布状态的中断性变更,请查看 .NET 问题

ASP.NET Core

标题 更改类型 引入的版本
DefaultKeyResolution.ShouldGenerateNewKey 已更改含义 行为变更 预览版 3
开发环境中的 HostBuilder enables ValidateOnBuild/ValidateScopes 行为变更 预览版 7

集装箱

Title 更改类型 引入的版本
.NET 9 容器映像不再安装 zlib 行为变更 预览版 7

Core .NET 库

标题 更改类型 引入的版本
使用 CompressionLevel 添加 ZipArchiveEntry 时,会设置 ZIP 中央目录标头常规用途位标志 行为变更 预览版 5
已更改对非开放泛型的 UnsafeAccessor 支持 行为变更 预览版 6
API 已过时并带有自定义诊断 ID 源不兼容 预览版 16
BigInteger 最大长度 行为变更 预览版 6
不允许创建 System.Void 数组类型 行为变更 预览版 1
对于标记为 InlineArrayAttribute 的类型,Equals()GetHashCode() 默认抛出异常 行为变更 预览版 6
FromKeyedServicesAttribute 不再注入非键化参数 行为变更 RC 1
IncrementingPollingCounter 初始回调是异步回调 行为变更 RC 1
强制实施内联数组结构大小限制 行为变更 预览版 1
InMemoryDirectoryInfo 将 rootDir 添加到文件前面 行为变更 预览版 1
RuntimeHelpers.GetSubArray 返回不同类型 行为变更 预览版 1
支持空环境变量 行为变更 预览版 6
ZipArchiveEntry 名称和注释遵循 UTF8 标志 行为变更 RC 1

密码

标题 更改类型 引入的版本
SafeEvpPKeyHandle.DuplicateHandle 增加句柄的引用计数 行为变更 预览版 7
某些 X509Certificate2 和 X509Certificate 构造函数已过时 源不兼容 预览版 7

部署

标题 更改类型 引入的版本
弃用的桌面 Windows/macOS/Linux MonoVM 运行时包 源不兼容 预览版 7

JIT 编译器

标题 更改类型 引入的版本
浮点数到整数转换将要饱和 行为变更 预览版 4
删除了一些 SVE API 源不兼容 RC 2

网络

标题 更改类型 引入的版本
默认情况下,HttpClientFactory 日志记录会编修标头值 行为变更 RC 1
HttpListenerRequest.UserAgent 可为空 源不兼容 预览版 1

SDK 和 MSBuild

标题 更改类型 引入的版本
dotnet workload 命令输出更改 行为变更 预览版 1
不再记录存储库 installer 版本 行为变更 预览版 5
终端记录器为默认值 行为变更 预览版 1
对 .NET Standard 1.x 发出警告 源不兼容 预览版 6

序列化

标题 更改类型 引入的版本
BinaryFormatter 始终引发 行为变更 预览版 6

Windows 窗体

标题 更改类型 引入的版本
BindingSource.SortDescriptions 不返回 null 行为变更 预览版 1
对为 null 性批注的更改 源不兼容 预览版 1
ComponentDesigner.Initialize 引发 ArgumentNullException 行为变更 预览版 1
DataGridViewRowAccessibleObject.Name 起始行索引 行为变更 预览版 1
IMsoComponent 支持为选择加入 行为变更 预览版 2
如果 DataGridView 为 null,则无异常 行为变更 预览版 1
PictureBox 引发 HttpClient 异常 行为变更 预览版 6

WPF

标题 更改类型 引入的版本
GetXmlNamespaceMaps 类型更改 行为变更/源不兼容 预览版 3

另请参阅