.NET Core 3.0 中的新变化

.net core 3.0 标志着 .net core 平台的一个重要新版本。本文回顾了 .net core 的发展历程,并展示了它如何从最初仅支持 web 和数据工作负载的版本 1,发展到能够支持 web、桌面、机器学习、容器、物联网等的版本 3.0。

.NET Core 1.NET Core 的历史可以追溯到几年前,版本 1 于 2016 年推出,旨在构建首个开放源代码和跨平台(Windows、macOS 和 Linux)的 .NET。它的灵感来源于那些希望使用开放源代码框架的客户,以及需要在 Linux 服务器上运行 .NET 应用程序的其他客户。由于 .NET Core 是跨平台的,因此根据设计,可以通过命令行完成所有操作,而无需使用 IDE。为了应对全局安装的 .NET Framework 的兼容性挑战,它设计有并行支持,包括随附作为应用程序一部分的框架,这样应用程序就不会依赖于计算机上安装的任何框架。版本 1 随附了新的 ASP.NET、实体框架 (EF),主要针对 Web 应用程序。

.NET Core 2虽然版本 1 支持在新平台上运行 .NET,但它仅支持一组有限的 .NET API。为了解决这个问题,我们创建了 .NET Standard,它指定了任何 .NET 运行时必须实现的 API,这样就能在 .NET 平台和版本之间共享代码和二进制文件。在 .NET Standard 2.0 中,我们向 .NET Standard 规范添加了超过 20,000 个 API。.NET Core 版本 2 于 2017 年 6 月发布,并支持 .NET Standard 2.0,使其能够访问这些 API。我们还引入了 Windows 兼容性包,这是包含许多仅 Windows API(如 System.Drawing、System.DirectoryServices 等)的 NuGet 包。ASP.NET Core 2.0 引入了 .NET Core 1.0 中缺少的两个框架,即 Razor Pages 和 SignalR。Entity Framework Core 开始支持延迟加载,这是一项热门的实体框架功能。.NET Core 2 还在不断推动 .NET 成为最快的完整堆栈框架之一。TechEmpower 基准由一家独立公司运行,将 .NET Core 列为原始纯文本性能领域的第 7 名,并将其列为 Web 和数据性能 Fortunes 测试中的第 6 名,击败了 Java servlet 和 Node.js (bit.ly/2PEE1l1)。

.NET Core 3.0.NET Core 3.0 是 .NET Core 平台的下一主要版本。它新增了许多令人兴奋的功能,如支持使用 Windows 窗体 (WinForms)、Windows Presentation Foundation (WPF) 和实体框架 6 的 Windows 桌面应用程序。对于 Web 开发,它开始支持使用 C# 通过 Razor 组件(旧称为 Blazor)生成客户端 Web 应用程序。此外,它还支持 C# 8.0 和 .NET Standard 2.1。

我们正在 .NET Core 3.0 中添加对物联网 (IoT) 方案的支持。现在可以在 Raspberry Pi 和类似设备上对硬件插针(用于控制设备和读取传感器数据)进行编程,并在所有受支持的操作系统上(例如,使用 Raspberry Pi 或 Arduino)通过串行端口进行通信。我们在此版本中还添加了适用于 ARM64 的 IoT 设备支持,以补充现有的 ARM32 功能。

.NET Core 3.0 还将完全支持 ML.NET,这是为 .NET 开发人员生成的开放源代码机器学习框架。ML.NET 强力驱动 Azure 机器学习、Windows Defender 和 PowerPoint Design Ideas 等产品。使用 ML.NET,可以将许多常用机器学习方案添加到应用中,如情绪分析、建议、预测、图像分类等。若要了解详细信息,请访问 bit.ly/2OLRGRQ。

我们最近发布了 .NET Core 3.0 的首个预览版。若要详细了解 .NET Core 3.0 和试用预览版,请访问 aka.ms/netcore3preview1。

桌面(WinForms 和 WPF)以及开放源代码WinForms 和 WPF 是两个最常用的 .NET 应用程序类型,有数百万开发人员在使用。.NET Core 3.0 开始支持 WinForms 和 WPF,将 Windows 桌面开发引入了 .NET Core。.NET Core 一直以来都是开放源代码的,在 GitHub 中,这两个框架与剩余的 .NET Core 一样,也都是开放源代码的。客户将有史以来第一次能够见证这些框架的开放开发,甚至可以通过提问、修复 bug 或帮助在 GitHub 中实时开发新功能,从而提供帮助。WinUI XAML 库也将是开放源代码的。通过 XAML Islands,可以在 WinForms 和 WPF 应用程序中使用这些控件。

许多现有的 WinForms 和 WPF 应用程序都使用实体框架来访问数据,因此 .NET Core 也支持实体框架 6。

你可能想要知道,为什么要在 .NET Core 上构建桌面应用程序。很简单:这样才能受益于 .NET Core 中的所有增强功能。不仅可以在最新版框架上构建应用程序,而无需安装 .NET Core,还能将应用程序和 .NET Core 发布到一个 .EXE 中。.NET Core 在设计时考虑到了并行支持,因此可以在一台计算机上安装多个版本,并能将应用程序锁定到设计时定目标到的版本。此外,鉴于这种并行本质,可以改进 .NET Core 中的 API(包括 WinForms 和 WPF),而无需承担损坏应用程序的风险。

ASP.NET Core 3然而,.NET Core 3.0 并不都是与桌面相关的。还有许多令人兴奋的新功能是针对 Web 设计的。接下来将介绍我们正在开发的几项功能。

客户经常问的一个问题是,如何在 .NET Core 中获得 RPC 体验(就像在 .NET 远程和 Windows Communication Foundation 中一样)。我们正在参与 gRPC (grpc.io) 项目,以确保 gRPC 能够为 .NET 开发人员提供一流支持。

在今年早些时候,我们开始了一项试验,即使用 .NET(我们称之为 Blazor)进行客户端 Web 开发。借助 Blazor,可以编写直接在浏览器中的基于 WebAssembly 的 .NET 运行时内运行的 Web UI 组件,而无需编写一行 JavaScript。使用 Razor 语法创作组件,这些组件与代码一起被编译到常规 .NET 程序集中。然后,程序集和基于 WebAssembly 的 .NET 运行时被下载到浏览器中,仅使用开放式 Web 标准就能执行它们(无需任何插件或代码转换),如图 1 所示。

.NET Core 3.0 中的新变化 图 1:使用 Blazor 进行客户端 Web 开发

也可以使用 .NET Core 在服务器上运行相同组件,其中所有 UI 交互和 DOM 更新都是通过 SignalR 连接进行处理,如图 2 所示。执行后,组件跟踪 DOM 所需的更新,并通过 SignalR 连接将要应用的这些更新发送到浏览器。UI 事件使用同一连接发送到服务器。此模型的优点有多个:下载大小更小、代码集中在服务器上,以及受益于在 .NET Core 上运行组件的所有功能和性能优势。

.NET Core 3.0 中的新变化 图 2:使用 SignalR 在服务器上运行 UI Web 组件

对于 .NET Core 3.0,我们将把 Blazor 组件模型集成到 ASP.NET Core 中。我们将此集成组件模型称为“Razor 组件”。Razor 组件开启了以下新时代:使用 ASP.NET Core 的可组合 UI,以及使用 .NET 的完整堆栈 Web 开发。对于 .NET Core 3.0,Razor 组件最初作为独立可路由组件,或通过 Razor Pages 和视图使用的组件在服务器上运行。不过,相同组件也可以在 WebAssembly 上进行客户端运行。在开发 .NET Core 3.0 的同时,我们还将继续着手以下工作:支持使用基于解释器的 .NET 运行时在 WebAssembly 上运行 Razor 组件,预计将在后续版本中提供。之后,我们还计划向 WebAssembly 发布对 .NET 代码的完全预编译支持,这将显著提升运行时性能。

EF Core 3.0LINQ 是一项用户钟爱的 .NET 功能,可便于编写数据库查询,而无需离开所选的语言,同时还能利用丰富的类型信息来获取 IntelliSense 和编译时类型检查。不过,LINQ 也支持编写数量几乎不限的复杂查询,而这对于 LINQ 提供程序来说,一直都是一项巨大挑战。EF Core 部分解决了此问题,具体方法是支持选择可转换为 SQL 的查询部分,再执行内存中剩余的查询。在某些情况下,这样做是可取的,但在其他许多情况下,这可能会导致非常低效的查询直到应用程序投入生产才被发现。

百度文心百中 百度文心百中

百度大模型语义搜索体验中心

百度文心百中 22 查看详情 百度文心百中

在 EF Core 3.0 中,我们计划深入更改 LINQ 实现工作原理和测试方式,旨在提高它的可靠性(例如,避免破坏修补程序版本中的查询);让它能够将更多表达式正确转换为 SQL;在更多情况下生成高效查询;以及防止直到投入生产才被检测到的非常低效查询出现。

我们一直在致力于开发适用于 EF Core 的 Cosmos DB 提供程序,以便开发人员能够熟悉 EF 编程模型,从而轻松地将 Azure Cosmos DB 定目标为应用程序数据库。目标是利用 Cosmos DB 的一些优势,如全局分发、“始终开启”可用性、弹性可伸缩性和低延迟,甚至包括 .NET 开发人员可以更轻松地访问它。此提供程序将针对 Cosmos DB 中的 SQL API 启用大部分 EF Core 功能,如自动更改跟踪、LINQ 和值转换。

我们计划在 EF Core 3.0 中添加的其他功能包括,属性包实体(将数据存储在索引属性(而不是常规属性)中的实体);能够将数据库视图反向工程为查询类型;以及与新 C# 8.0 功能集成,如 IAsyncEnumerable 支持和可以为 null 的引用类型。

我们理解,对于许多使用旧版 EF 的现有应用程序来说,移植到 EF Core 的工作量巨大。正因为此,我们还移植了 EF 6,以便能够使用 .NET Core。

.NET Standard 2.1如果遵循 .NET Standard,可以创建适用于所有 .NET 实现的库,不仅仅局限于 .NET Core,还包括 Xamarin 和 Unity。在 .NET Standard 1.x 中,我们只对跨各种实现已常用的 API 进行了建模。在 .NET Standard 2.0 中,我们专注于简化将现有 .NET Framework 代码移植到 .NET Core 的过程,这样不仅带来了额外的 20,000 个 API,还带来了兼容性模式(可便于从基于 .NET Standard 的库引用 .NET Framework 库,而无需重新编译它们)。对于这两版标准,几乎没有任何新组件,因为所有 API 都是现有 .NET API。

在 .NET Standard 2.1 中,这一情况已有所改变:我们添加了约 3,000 个几乎全新的 API,它们作为 .NET Core 开放源代码开发的一部分引入。通过将它们添加到标准,我们将它们引入所有 .NET Standard 实现。

这些新 API 包括:

Span:在 .NET Core 2.1 中,我们添加了 Span,这是类似数组的类型,允许以统一方式表示托管和非托管内存,并支持在不复制的情况下进行切片。Span 是 .NET Core 2.1 中与性能最为相关的改进的核心。因为它允许以更高效的方式管理缓冲,所以可以有助于减少分配和复制。若要详细了解此类型,请务必阅读 Stephen Toub 关于 Span 的精彩文章 (msdn.com/magazine/mt814808)。ValueTask 和 ValueTask:在 .NET Core 2.1 中,基础内容中最重要的功能相关改进,可支持高性能方案 (bit.ly/2HfIXob),还能让 async/await 更高效。 ValueTask 已有,可便于在操作同步完成时返回结果,而无需分配新 Task。在 .NET Core 2.1 中,我们进一步改进了此功能,同时提高了它的可用性,让它有对应的非泛型 ValueTask,以便在必须以异步方式完成操作的情况下减少分配,这是 Socket 和 NetworkStream 等类型现在利用的功能。常规实用 API:由于 .NET Core 是开放源代码的,因此我们跨基类库添加了许多小功能,如用于合并哈希代码的 System.HashCode,或 System.String 上的新重载。.NET Core 中约有 800 名新成员,几乎所有这些成员都已添加到 .NET Standard 2.1 中。如需了解更多详情,请查看 .NET Standard 2.1 公告 (bit.ly/2RCW2fX)。

C# 8.0C# 8.0 是下一版 C#,它在几个主要方面改进了语言。可以为 null 的引用类型有助于防止 null 引用异常,并改进了 null 安全编码做法。可以选择启用下列功能:在将 null 分配到类型字符串(举个例子)的变量或参数时看到警告。若要可以为 null,必须使用“string?”可以为 null 的引用类型。

异步流对异步数据流执行的操作,就是 async/await 对单个异步结果执行的操作。新框架类型 IAsyncEnumerable 是 IEnumerable 的异步版本,同样也能执行 foreach 和 yield return:

public static async IAsyncEnumerable FilterAsync(  this IAsyncEnumerable source,  Func> predicate){  await foreach (T element in source)  {    if (await predicate(element)) yield return element;  }}

除了其他功能外,借助默认接口成员实现,接口可以添加新成员,而无需中断现有实现者。Switch 表达式可确保模式匹配更为简洁,不仅可以递归模式,还能将模式深入挖掘到测试值。如需了解 C# 8.0 的更多详情,请访问 aka.ms/csharp8。

.NET Framework 和 .NET Core 将如何发展?.NET Framework 是在超过 10 亿台计算机上安装的 .NET 实现,因此需要尽可能保持兼容性。因此,它的更新速度慢于 .NET Core。甚至安全修复和 bug 修复都可能会导致应用程序中断,因为应用程序依赖旧行为。我们将确保 .NET Framework 始终支持最新的网络协议、安全标准和 Windows 功能。

.NET Core 是开放源代码、跨平台且快速更新的 .NET 版本。鉴于这种并行本质,可以对它应用我们无法冒险对 .NET Framework 应用的更改。也就是说,随着时间推移,.NET Core 会增添新 API 和语言功能,而 .NET Framework 则不会。

如果现有 .NET Framework 应用程序,且无需利用任何 .NET Core 功能,就不应该有迁移到 .NET Core 的压力。.NET Framework 和 .NET Core 都将完全受支持;.NET Framework 始终是 Windows 的一部分。甚至在 Microsoft 内部,我们都有很多基于 .NET Framework 的大型产品线,并将一直基于 .NET Framework。但展望未来,.NET Core 和 .NET Framework 包含的功能将会有所不同。

总结.NET Core 3.0 预计将于 2019 年下半年发布。它将提供开放源代码版本的 WinForms 和 WPF,以用于 Windows 桌面开发。实体框架 6 也将包含在内。此外,ASP.NET Core、Entity Framework Core、.NET Standard 和 C# 都将进行重要更新。对于新 .NET 应用程序,应认真考虑使用此版本的 .NET Core。有关详细信息,请访问 aka.ms/netcore3preview1。

以上就是.NET Core 3.0 中的新变化的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/242889.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 02:19:52
下一篇 2025年11月4日 02:20:52

相关推荐

  • Flask-SocketIO与uWSGI多进程部署中的异步模式配置指南

    本文旨在解决flask-socketio与uwsgi结合部署时常见的异步模式配置错误。核心问题在于未正确指定socketio的异步驱动,导致与uwsgi的gevent环境冲突。通过设置`async_mode=’gevent_uwsgi’`并优化uwsgi的多进程配置为单进程g…

    2025年12月14日
    000
  • Django表单:基于用户信息自动填充并禁用字段

    本文档旨在解决Django表单中根据用户信息自动填充字段,并禁止用户修改该字段的需求。通过配置表单字段的`disabled`属性,以及在视图中正确处理用户数据,可以实现字段的自动填充和禁用,同时确保表单能够成功提交。本文将提供详细的代码示例和步骤,帮助开发者轻松实现这一功能。 解决方案 核心在于正确…

    2025年12月14日
    000
  • Python教程:高效匹配JSON与文本数据并提取关联信息

    本教程详细介绍了如何使用Python从非结构化文本文件(如TXT)中提取特定模式的数据(如设备名称),并将其与结构化JSON文件中的数据进行匹配。通过结合json模块和re模块的正则表达式功能,文章演示了如何高效地查找匹配项,并从JSON结构中提取相应的关联URL信息,为跨文件数据整合提供了实用的解…

    2025年12月14日
    000
  • 使用 Argparse 在子命令间灵活添加可选参数

    本文旨在解决在使用 `argparse` 创建带有子命令的命令行工具时,如何允许用户在命令行中的任意位置传递可选参数(例如 `-j` 或 `–json`)的问题。我们将探讨一种通过为每个解析器实例添加带唯一ID的参数,并在解析后合并结果来实现此目的的解决方案。 在使用 argparse …

    2025年12月14日
    000
  • NetworkX中图同构性判断与非同构图的本质差异解析

    本文深入探讨了networkx中图同构性的概念,阐释了`nx.is_isomorphic`方法的判断机制。针对用户关于“非同构图为何非同构”的疑问,文章指出非同构并非由单一原因造成,而是源于结构上无法建立一对一的顶点映射。教程将通过实例代码展示如何使用networkx判断图同构性,并探讨在非同构情况…

    2025年12月14日
    000
  • 允许子命令之间任意位置的可选参数

    本文介绍了如何在使用 `argparse` 创建带有子命令的工具时,允许用户在命令行中的任何位置传递可选参数(例如 `-j` 或 `–json`)。核心思路是将该可选参数添加到主解析器和所有子解析器,并使用不同的目标名称存储其值。最后,通过检查所有目标名称的值,确定最终的参数值。 在使用…

    2025年12月14日
    000
  • Django 测试中视图返回 400 错误:常见原因与调试策略

    本文旨在解决 django 测试中视图意外返回 400 状态码的问题,特别是涉及用户认证的场景。我们将深入探讨导致此类错误的核心原因,包括请求端点不匹配、请求数据格式或键名不正确(尤其是 json 请求处理),以及视图内部逻辑处理异常。通过系统化的调试方法和代码示例,帮助开发者快速定位并解决测试失败…

    2025年12月14日
    000
  • 使用 pycaw 稳定检测 Windows 音频播放状态

    本文详细介绍了如何使用 python 的 `pycaw` 库在 windows 系统上可靠地检测音频播放状态。针对常见的使用 `ctypes` 和 `comtypes` 导致程序崩溃的问题,文章提供了一种极简且稳定的解决方案,通过直接访问 `pycaw` 会话对象的 `state` 属性,避免了复杂…

    2025年12月14日
    000
  • Django:定时删除数据库中过期数据

    本文介绍了如何在 Django 框架中实现自动删除数据库中创建时间超过 15 天的数据。我们将探讨使用 Celery 及其周期性任务来完成此目标,避免使用信号可能存在的问题,并提供具体代码示例,帮助开发者轻松实现数据清理自动化。 在 Django 项目中,经常需要定期清理数据库中不再需要的数据,例如…

    2025年12月14日
    000
  • 解密 AES 加密的 JSON 文件(无 IV)教程

    本教程旨在帮助你解密使用 aes 加密的 json 文件,即使在缺少初始化向量(iv)的情况下也能找到解密方案。我们将分析提供的 javascript 代码,理解加密逻辑,并使用 python 实现解密过程,最终成功提取原始 json 数据。 ### 理解加密方案首先,我们需要理解游戏开发者使用的加…

    2025年12月14日
    000
  • Django 定时删除过期数据:使用 Celery 实现

    本文档旨在指导开发者如何在 Django 项目中实现自动删除过期数据的功能。通过集成 Celery 异步任务队列,我们可以创建一个定时任务,定期检查并删除数据库中创建时间超过指定期限(例如 15 天)的数据,从而保持数据库的整洁和性能。本文将提供详细的步骤和示例代码,帮助你快速上手。 在 Djang…

    2025年12月14日
    000
  • 使用 CircuitPython 控制三星电视:IR 信号发送指南

    本文旨在指导开发者如何使用 CircuitPython 通过红外 (IR) 信号控制三星电视。我们将探讨如何查找和使用 `adafruit_irremote` 库中的 `GenericTransmit` 类来构建自定义 IR 信号,并提供一个基于 IRLib2 代码的示例,帮助你了解三星电视的 IR…

    2025年12月14日
    000
  • 解决 Python-Gitlab 复制提交时文件重命名导致的问题

    本文档旨在解决在使用 Python-Gitlab 库进行代码仓库同步时,遇到的文件重命名导致提交失败的问题。通过分析 Gitlab API 的要求,并结合实际代码示例,提供了一种处理文件重命名操作的有效方法,确保代码仓库同步的完整性和准确性。 在使用 python-gitlab 库同步 Gitlab…

    2025年12月14日
    000
  • 使用 Python Gitlab API 复制 Commit:处理文件重命名问题

    本文档旨在解决在使用 Python Gitlab API 复制 commit 时,遇到的文件重命名问题。当源 commit 包含文件重命名操作时,直接使用 `python-gitlab` 库创建 commit 可能会失败。本文将提供一种解决方案,通过检测文件重命名操作并相应地设置 commit ac…

    2025年12月14日
    000
  • Django 数据库中自动删除过期数据:定时任务实现指南

    本文旨在指导开发者如何在 Django 项目中实现自动删除数据库中创建时间超过15天的数据。我们将探讨如何利用 Celery 等异步任务队列工具,设置定时任务来定期清理过期数据,并提供示例代码和注意事项,确保数据清理的可靠性和效率。 在 Django 项目中,自动删除数据库中创建时间超过一定期限(例…

    2025年12月14日
    000
  • PySpark CSV写入时保留字符串中换行符的策略

    在PySpark中将DataFrame写入CSV文件时,如果字符串列中包含实际的换行符(或),它们通常会被解释为行终止符,导致数据被错误地拆分成多行。本文将详细介绍如何通过自定义用户定义函数(UDF)将这些内部换行符转换为其字面量字符串表示(r和n),从而确保在CSV文件中完整保留原始字符串内容,避…

    2025年12月14日
    000
  • 解决 Docker 构建 Wagtail 项目时 libsass 编译失败的问题

    本文旨在帮助开发者解决在使用 Docker 构建 Wagtail 项目时,遇到的 `Could not build wheels for libsass` 错误。通过分析错误原因,并提供更换基础镜像的解决方案,帮助读者顺利完成项目构建。 在使用 Docker 构建 Wagtail 项目时,可能会遇到…

    2025年12月14日
    000
  • 解密 AES 加密的 JSON 文件:深入分析与实践

    本文旨在深入探讨如何解密使用 aes 加密的 json 文件,重点分析了在缺乏初始化向量(iv)的情况下,如何通过现有的密钥和密文进行解密。我们将详细解析提供的 javascript 解密代码,并结合 python 示例,一步步指导读者完成 aes 解密过程,同时讨论可能遇到的问题和解决方案。 ##…

    2025年12月14日
    000
  • Django表单联动:实现字段自动填充的客户端方案

    本文详细介绍了如何在Django Web应用中,利用客户端JavaScript/jQuery实现表单字段的实时联动自动填充。通过监听一个字段(如账户类型)的变化,根据预设的映射规则自动更新另一个字段(如最低开户金额)的值,从而提升用户体验,简化数据输入流程,并强调了客户端与服务器端协同验证的重要性。…

    2025年12月14日
    000
  • # 解密 AES 加密的 JSON 文件(无 IV)

    本文档旨在帮助开发者理解和实践 aes 加密 json 文件的解密过程,特别是在缺少初始化向量(iv)的情况下。我们将分析提供的 javascript 代码,并使用 python 实现解密,同时探讨可能遇到的问题和解决方案,包括数据填充、编码问题以及如何处理未知的 iv。通过本文,读者将能够掌握 a…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信