.NET Core 3.0 中的新变化

译者:楚人Leo

译文:http://www.cnblogs.com/leolion/p/10585834.html

原文:https://msdn.microsoft.com/en-us/magazine/mt848631.aspx


.NET Core 3.0 是 .NET Core 平台的下一主要版本。本文回顾 .NET Core 发展历史,并展示了它是如何从基本支持 Web 和数据工作负载的版本1,发展成为能够运行 Web、桌面、机器学习、容器、IoT 等的版本 3.0。

.NET Core 1.0

.NET Core 的历史可追溯到几年前,版本 1 是在 2016 年推出,旨在生成第一版开放源代码和跨平台(Windows、macOS 和 Linux)的 .NET。


灵感来源于只能使用开放源代码框架的客户,以及需要在 Linux 服务器上运行 .NET 应用程序的其他客户。由于 .NET Core 是跨平台的,因此根据设计,可使用命令行完成所有操作,而无需使用 IDE。


为了应对全局安装的 .NET Framework 的兼容性挑战,它设计有并行支持,包括随附作为应用程序一部分的框架,这样应用程序就不会依赖在计算机上安装的任何框架。版本 1 随附新版 ASP.NET、实体框架 (EF) 和主要定目标到的 Web 应用程序。

.NET Core 2.0

虽然版本 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 和类似设备上对硬件插针(用于控制设备和读取传感器数据)进行编程,并在所有受支持的 OS上(例如,使用 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/netcore3preview1https://devblogs.microsoft.com/dotnet/announcing-net-core-3-preview-1-and-open-sourcing-windows-desktop-frameworks/

桌面(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.0

不过,.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 所示。


640?wx_fmt=png

图 1:使用 Blazor 进行客户端 Web 开发


也可以使用 .NET Core 在服务器上运行相同组件,其中所有 UI 交互和 DOM 更新都是通过 SignalR 连接进行处理,如图 2 所示。执行后,组件跟踪 DOM 所需的更新,并通过 SignalR 连接将要应用的这些更新发送到浏览器。


UI 事件使用同一连接发送到服务器。此模型的优点有多个:下载大小更小、代码集中在服务器上,以及受益于在 .NET Core 上运行组件的所有功能和性能优势。


640?wx_fmt=png

图 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.0

LINQ 是一项用户钟爱的 .NET 功能,可便于编写数据库查询,而无需离开所选的语言,同时还能利用丰富的类型信息来获取 IntelliSense 和编译时类型检查。


不过,LINQ也支持编写数量几乎不限的复杂查询,而这对于LINQ提供程序来说,一直都是一项巨大挑战。


EF Core 部分解决了此问题,具体方法是支持选择可转换为 SQL 的查询部分,再执行内存中剩余的查询。在某些情况下,这样做是可取的,但在其他许多情况下,这可能会导致非常低效的查询直到应用程序投入生产才被发现。


在 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<T> 支持和可以为 null 的引用类型。


我们理解,对于许多使用旧版 EF 的现有应用程序来说,移植到EF Core 的工作量巨大。正因为此,我们还移植了 EF6,以便能够使用 .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<T>:在 .NET Core 2.1 中,我们添加了 Span<T>,这是类似数组的类型,允许以统一方式表示托管和非托管内存,并支持在不复制的情况下进行切片。Span<T> 是 .NET Core 2.1 中与性能最为相关的改进的核心。因为它允许以更高效的方式管理缓冲,所以可以有助于减少分配和复制。若要详细了解此类型,请务必阅读 Stephen Toub 关于 Span<T> 的精彩文章 (msdn.com/magazine/mt814808)。

  • ValueTask 和 ValueTask<T>:在 .NET Core 2.1 中,基础内容中最重要的功能相关改进,可支持高性能方案 (bit.ly/2HfIXob),还能让 async/await 更高效。 ValueTask<T> 已有,可便于在操作同步完成时返回结果,而无需分配新 Task<T>。在 .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.0

C#8.0 是下一版C#,它在几个主要方面改进了语言。可以为 null 的引用类型有助于防止 null 引用异常,并改进了 null 安全编码做法。


可以选择启用下列功能:在将 null 分配到类型字符串(举个例子)的变量或参数时看到警告。


若要可以为 null,必须使用“string?”可以为 null 的引用类型。


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


public static async IAsyncEnumerable<T> FilterAsync<T>(
 this IAsyncEnumerable<T> source,
 Func<T, Task<bool>> 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 的未来满怀期待,并将向 .NET Core 添加更多工作负载。建议大家试用 .NET Core 3.0预览版,并向我们发送反馈。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/272183.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

树莓派GPIO口的使用(外设相关开发WringPi库的使用,超声波、继电器)

树莓派的接口&#xff1a; 大而简单的类别&#xff1a;IO口&#xff0c;input和output是相对于主控芯片来说的&#xff0c;是根据MCU和外设之间的关系将IO口的功能分为output和input。当IO作为input使用时外设有&#xff1a;人体传感器、烟雾传感器、火焰传感器、振动传感器等…

volatile指令重排_有多少人面试栽到Volatile上?面试问题都总结到这儿了

Volatile关键字volatile 是Java虚拟机提供的 轻量级 的同步机制.何为 轻量级 呢&#xff0c;这要相对于 synchronized 来说。Volatile有如下三个特点。要搞清楚上面列举的名词 可见性 原子性 指令重排 的含义我们需要首先弄清楚JMM(Java内存模型是怎么回事)JMM规定了内存主要划…

Dubbo核心概念

节点角色规范 节点角色规格Provider提供者公开远程服务Consumer消费者致电远程服务Registry注册表负责服务发现和配置Monitor监视器计算服务调用的数量和耗时Container容器管理服务的生命周期 服务关系 Container负责启动&#xff0c;加载和运行服务Provider。ProviderRegiste…

良心推荐11款可以称得上“神器”的Windows工具集合

1、最快文件搜索工具 Everything&#xff1a;当之无愧的最强本地文件搜索神器&#xff0c;搜索任何关键词基本是秒速出现&#xff0c;比Windows自带的搜索快了太多&#xff0c;电脑文件比较多的人必备&#xff01; 2、专业软件卸载器 Revo Uninstaller Pro&#xff1a;Windows电…

LD3320语音识别模块二次开发及与树莓派间的通讯

实物图如下&#xff1a; 一般这种模块的资料厂家都会给&#xff0c;需要的话可以私信我发邮箱&#xff0c;下面介绍该模块的各种参数。型号&#xff1a;YS-LDV7名称&#xff1a;一体化语音识别模块规格&#xff1a;43*29.7MM供电电压&#xff1a;5V &#xff08;内部工作电压…

多生产者_你是生产者还是消费者?这决定了你的层次。

不知道你有没有注意到&#xff0c;每天乘坐地铁上下班的时候&#xff0c;大部分人都在刷剧、看视频、打游戏等等&#xff0c;总之都属于玩乐。用生产和消费的关系来看的话&#xff0c;其实这一大部分人都属于消费者&#xff0c;“时间和注意力”是他们用于交换的筹码&#xff1…

eclipse Android 开发基础 Activity 窗体 界面

eclipse Android 开发基础 新建工程 新建布局layout,new Android Activity就相当于窗体Form。 新建Activity自动生成src下同名的java代码。 public class Tform2activity extends Activity {Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(saved…

8 种常被忽视的 SQL 错误用法

来源&#xff1a;http://t.cn/R6UMaA11、LIMIT 语句2、隐式转换3、关联更新、删除4、混合排序5、EXISTS语句6、条件下推7、提前缩小范围8、中间结果集下推总结sql语句的执行顺序&#xff1a;FROM <left_table>ON <join_condition><join_type> JOIN <right…

变频器按启动没反应_起重机软启动柜晶闸管损坏维修几大故障

缺相保护功能&#xff1a;工作时&#xff0c;软起动器随时检测三相线电流的变化&#xff0c;一旦发生断流&#xff0c;即可作出缺相保护反应。过热保护功能&#xff1a;通过软起动器内部热继电器检测晶闸管散热器的温度&#xff0c;一旦散热器温度超过允许值后自动关断晶闸管&a…

Redis 的各项功能解决了哪些问题?

作者丨blackheart先看一下Redis是一个什么东西官方简介解释到&#xff1a;Redis是一个基于BSD开源的项目&#xff0c;是一个把结构化的数据放在内存中的一个存储系统&#xff0c;你可以把它作为数据库&#xff0c;缓存和消息中间件来使用。同时支持strings&#xff0c;lists&am…

RocketMQ集成SpringBoot

RocketMQ集成SpringBoot RocketMQ总体架构 RocketMQ基本特性

ASP.NET Core 2.2+Quartz.Net 实现Web定时任务

作者&#xff1a;Julian_酱链接&#xff1a;http://www.cnblogs.com/mi12205599/p/10361763.html作为一枚后端程序狗&#xff0c;项目实践常遇到定时任务的工作&#xff0c;最容易想到的的思路就是利用Windows计划任务/wndows service程序/Crontab程序等主机方法在主机上部署定…

RocketMQ核心概念

生产者Producer和消费者Consumer NameServer作用 Broker和Topic

交叉编译、软硬链接

什么是交叉编译&#xff1f;交叉编译是一个行为&#xff0c;是在一个平台上生成另一个平台上的可执行代码。 本地编译&#xff1a;本地编译可以理解为&#xff0c;在当前编译平台下&#xff0c;编译出来的程序只能放到当前平台下运行。平时我们常见的软件开发&#xff0c;都是…

Linus下安装maven

下载maven安装包 wget http://mirror.bit.edu.cn/apache/maven/binaries/apache-maven-3.2.2-bin.tar.gz 解压 tar -zxvf apache-maven-3.2.2-bin.tar.gz 配置maven环境变量 查看maven解压后安装包目录 vi /etc/profile 进入最底部&#xff0c;按insert,添加环境变量&#x…

linux内核开发基础(linux内核源码、树莓派源码编译、SD卡挂载)

首先下载树莓派linux内核源码&#xff1a; 下载网址&#xff1a;https://github.com/raspberrypi/linux在树莓派使用指令&#xff1a;uname -r查看当前树莓派的版本号&#xff0c;然后选择对应的linux内核版本号进行下载。 将linux内核源码从共享文件夹拷贝到SYSTEM文件夹&am…

Linux实时查看进程命令top笔记

top命令是Linux下常用的性能分析工具&#xff0c;能够实时显示Linux系统中各个进程的资源占用状况&#xff0c;类似于Windows系统的任务管理器功能。 top命令的语法格式&#xff1a; top [-] [d] [p] [q] [c] [C] [S] [s] [n] 常用参数说明 d 指定每两次屏幕信息刷新之间的时间…

文件系统(文件系统目录结构、磁盘分区、虚拟文件系统)、linux内核结构框图

什么是文件系统&#xff1f; 常规认知就是根目录下那些文件&#xff0c;但其实并不是那样。文件系统是操作系统用于明确存储设备&#xff08;常见的是磁盘&#xff0c;也有基于NAND Flash的固态硬盘&#xff09;或分区上的文件的方法和数据结构&#xff1b;即在存储设备上组织…

Linux进程终止命令kill或kill all​笔记

在linux命令下&#xff0c;如果需要终止某个进程&#xff0c;可以使用kill或者killall等命令来实现。终止命令的原理都是向linux内核发送一个系统操作的信号以及某个进程的ID&#xff0c;然后系统内核会根据指定的进程ID进行相应的处理。 kill命令典型的用法&#xff1a;首先使…