本文共 2080 字,大约阅读时间需要 6 分钟。
,其中提供了一系列新特性,包括对.NET Core 2.1的新原生类型Span\u0026lt;T\u0026gt;
的支持、新关键字Match!
等。
类型Span
意在实现底层代码指针操作的安全性和可预测性,这可使得很多情况下不必再分配内存,进而改进了内存使用的效率和性能。为实现此,Span
会为已在内存某处存储的数据提供一种虚拟视图。例如,对于一个具有10000个元素的数组,我们完全可以创建一个包括其前1000个元素的切片,并将该切片传递给函数,不需要对这些元素做拷贝。代码如下:
\ let nativeMemory = Marshal.AllocHGlobal(100);\ let nativeSpan = new Span\u0026lt;byte\u0026gt;(nativeMemory.ToPointer(), 100)\ let nativeSpanSlice = new Span\u0026lt;byte\u0026gt;(nativeMemory.ToPointer(), 10)\ let mem = NativePtr.stackalloc\u0026lt;byte\u0026gt;(100)\ let mem2 = mem |\u0026gt; NativePtr.toVoidPtr\ let stackSpan = Span\u0026lt;byte\u0026gt;(mem2, 100)\\\
类型Span
实际上包括了一系列的子特性,例如voidptr
类型、NativePtr.ofVoidPtr
和NativePtr.toVoidPtr
函数,以及其它一些支持F# 4.5的Span
与C# 7.3对等的特性。特性对应表如下所示:
\C# F#\out int arg arg: byref\u0026lt;int\u0026gt;\out int arg arg: outref\u0026lt;int\u0026gt;\in int arg arg: inref\u0026lt;int\u0026gt;\ref readonly int Inferred or arg: inref\u0026lt;int\u0026gt;\ref expr \u0026amp;expr\\\
为确保代码的公平性,F#对使用Span
强加了一系列应用于所有类byref
结构的限制:
let
限定的值,其引用不能超出其定义范围;\\tbyref
结构体不能作为类或正常结构体的实例或静态成员;\\tbyref
结构体不能作为通用类型参数使用;\\tbyref
结构体不能被任何闭包结构体捕获。\关键字Match!
是开发人员期待已久的一个特性,它用于在中简化匹配语法。F# 4.1中,在做匹配前,需要使用let!
作为一个中间步骤:
\let funcWithString (s: string) =\ async {\ let! r = asyncFunction s\ match r with\ | Some bananaString -\u0026gt; printfn \"It's banana!\"\ | None -\u0026gt; printfn \"%s\" s\ }\\\
而在F# 4.5中,只需如下编写:
\\\let funcWithString (s: string) =\ async { \ match! asyncFunction s with\ | Some bananaString -\u0026gt; printfn \"It's banana!\"\ | None -\u0026gt; printfn \"%s\" s\}\\\
F# 4.5还提供了下列特性:
\\yield
时,不再需要做向上造型(upcast)。例如:\\let x2 : obj list = [ yield \"a\" :\u0026gt; obj ] // F# 4.5版本之前。\let x3 : obj list = [ yield \"a\" ] // F# 4.5版本。\\\
public
使用。\\t据Carter介绍,目前发布的F# 4.5非常稳定,它将会加入到即将发布的Visual Studio 2017 update 15.8中。此外,该预览版可以从和处手工获取。
\\查看英文原文:
转载地址:http://watpo.baihongyu.com/