.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

相关推荐

  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 如何用HTML/JS实现Windows 10设置界面鼠标移动探照灯效果?

    Win10设置界面中的鼠标移动探照灯效果实现指南 想要在前端开发中实现类似于Windows 10设置界面的鼠标移动探照灯效果,有两种解决方案:CSS 和 HTML/JS 组合。 CSS 实现 不幸的是,仅使用CSS无法完全实现该效果。 立即学习“前端免费学习笔记(深入)”; HTML/JS 实现 要…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 如何用前端技术实现Windows 10 设置界面鼠标移动时的探照灯效果?

    探索在前端中实现 Windows 10 设置界面鼠标移动时的探照灯效果 在前端开发中,鼠标悬停在元素上时需要呈现类似于 Windows 10 设置界面所展示的探照灯效果,这其中涉及到了元素外围显示光圈效果的技术实现。 CSS 实现 虽然 CSS 无法直接实现探照灯效果,但可以通过以下技巧营造出类似效…

    2025年12月24日
    000
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信