F Sharp (programming language)

Last updated
F#
F Sharp logo.svg
Paradigms Multi-paradigm: functional, imperative, object-oriented, agent-oriented, metaprogramming, reflective, concurrent
Family ML: Caml: OCaml
Designed by Don Syme, Microsoft Research
Developer Microsoft, The F# Software Foundation
First appeared2005;19 years ago (2005), version 1.0
Stable release
8.0.0 / 14 November 2023;6 months ago (2023-11-14)
Typing discipline Static, strong, inferred
OS Cross-platform: .NET framework, Mono
License MIT [1] [2]
Filename extensions .fs, .fsi, .fsx, .fsscript
Website fsharp.org
Influenced by
C#, Erlang, Haskell, [3] ML, OCaml, [4] [5] Python, Scala
Influenced
C#, [6] Elm, F*, LiveScript

F# (pronounced F sharp) is a general-purpose, high-level, strongly typed, multi-paradigm programming language that encompasses functional, imperative, and object-oriented programming methods. It is most often used as a cross-platform Common Language Infrastructure (CLI) language on .NET, but can also generate JavaScript [7] and graphics processing unit (GPU) code. [8]

Contents

F# is developed by the F# Software Foundation, [9] Microsoft and open contributors. An open source, cross-platform compiler for F# is available from the F# Software Foundation. [10] F# is a fully supported language in Visual Studio [11] and JetBrains Rider. [12] Plug-ins supporting F# exist for many widely used editors including Visual Studio Code, Vim, and Emacs.

F# is a member of the ML language family and originated as a .NET Framework implementation of a core of the programming language OCaml. [4] [5] It has also been influenced by C#, Python, Haskell, [3] Scala and Erlang.

History

Versions

F#
version
Language specificationDate Platforms Runtime
1.xMay 2005 [13] Windows .NET 1.0 - 3.5
2.0 August 2010 April 2010 [14] Linux, macOS, Windows .NET 2.0 - 4.0, Mono
3.0 November 2012 August 2012 [15] Linux, macOS, Windows;
JavaScript, [7] GPU [8]
.NET 2.0 - 4.5, Mono
3.1 November 2013 October 2013 [16] Linux, macOS, Windows;
JavaScript, [7] GPU [8]
.NET 2.0 - 4.5, Mono
4.0 January 2016 July 2015 [17]
4.1 May 2018 March 2017 [18] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET 3.5 - 4.6.2, .NET, Mono
4.5August 2018 [19] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET 4.5 - 4.7.2, [20] .NET Core SDK 2.1.400 [21]
4.6March 2019 [22] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET 4.5 - 4.7.2, [23] .NET Core SDK 2.2.300 [24]
4.7September 2019 [25] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET 4.5 - 4.8, [26] .NET Core SDK 3.0.100 [27]
5.0November 2020 [28] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET SDK 5.0.100 [29]
6.0November 2021 [30] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET SDK 6.0.100 [31]
7.0November 2022 [32] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET SDK 7.0.100 [33]
8.0November 2023 [34] Linux, macOS, Windows,

JavaScript, [7] GPU [8]

.NET SDK 8.0.100 [35]

Language evolution

F# uses an open development and engineering process. The language evolution process is managed by Don Syme from Microsoft Research as the benevolent dictator for life (BDFL) for the language design, together with the F# Software Foundation. Earlier versions of the F# language were designed by Microsoft and Microsoft Research using a closed development process.

F# was first included in Visual Studio in the 2010 edition, at the same level as Visual Basic and C# (albeit as an option), and has remained in subsequent editions, thus making the language widely available and well-supported.

F# originates from Microsoft Research, Cambridge, UK. The language was originally designed and implemented by Don Syme, [4] according to whom in the fsharp team, they say the F is for "Fun". [36] Andrew Kennedy contributed to the design of units of measure. [4] The Visual F# Tools for Visual Studio are developed by Microsoft. [4] The F# Software Foundation developed the F# open-source compiler and tools, incorporating the open-source compiler implementation provided by the Microsoft Visual F# Tools team. [9]

Summary of versions
Features added
F# 1.0
  • Functional programming
  • Discriminated unions
  • Records
  • Tuples
  • Pattern matching
  • Type abbreviations
  • Object-oriented programming
  • Structs
  • Signature files
  • Scripting files
  • Imperative programming
  • Modules (no functors)
  • Nested modules
  • .NET Interoperability
F# 2.0
  • Active patterns
  • Units of measure
  • Sequence expressions
  • Asynchronous programming
  • Agent programming
  • Extension members
  • Named arguments
  • Optional arguments
  • Array slicing
  • Quotations
  • Native interoperability
  • Computation expressions
F# 3.0 [37]
  • Type providers
  • LINQ query expressions
  • CLIMutable attribute
  • Triple-quoted strings
  • Auto-properties
  • Provided units-of-measure
F# 3.1 [38]
  • Named union type fields
  • Extensions to array slicing
  • Type inference enhancements
F# 4.0 [39]
  • Printf on unitized values
  • Extension property initializers
  • Non-null provided types
  • Primary constructors as functions
  • Static parameters for provided methods
  • Printf interpolation
  • Extended #if grammar
  • Tailcall attribute
  • Multiple interface instantiations
  • Optional type args
  • Params dictionaries
F# 4.1 [40]
  • Struct tuples which inter-operate with C# tuples
  • Struct annotations for Records
  • Struct annotations for Single-case Discriminated Unions
  • Underscores in numeric literals
  • Caller info argument attributes
  • Result type and some basic Result functions
  • Mutually referential types and modules within the same file
  • Implicit "Module" syntax on modules with shared name as type
  • Byref returns, supporting consuming C# ref-returning methods
  • Error message improvements
  • Support for 'fixed'
F# 4.5 [28]
  • Versioning alignment of binary, package, and language
  • Support for 'Span<T>' and related types
  • Ability to produce 'byref' returns
  • The 'voidptr' type
  • The 'inref<'T>' and 'outref<'T>' types to represent readonly and write-only 'byref's
  • 'IsByRefLike' structs
  • 'IsReadOnly' structs
  • Extension method support for 'byref<'T>'/'inref<'T>'/'outref<'T>'
  • 'match!' keyword in computation expressions
  • Relaxed upcast with 'yield' in F# seq/list/array expressions
  • Relaxed indentation with list and array expressions
  • Enumeration cases emitted as public
F# 4.6
  • Anonymous record types
F# 4.7 [41]
  • Implicit yields
  • No more required double underscore
  • Indentation relaxations for parameters passed to constructors and static methods
  • 'nameof' function
  • Open static classes
F# 5.0 [42]
  • FSharp.Core now targets netstandard2.0 only
  • Package references in F# scripts
  • Support for Jupyter, nteract, and VSCode Notebooks
  • String Interpolation
  • Support for nameof
  • Open Type declarations
  • Enhanced Slicing
  • F# quotations improvements
  • Applicative Computation Expressions
  • Improved stack traces in F# async and other computation expressions
  • Improved .NET interop
  • Improved Map and Set performance in FSharp.Core
  • Improved compiler performance
  • Improved compiler analysis for library authors
F# 6.0 [43]
  • Tasks
  • Simpler indexing
  • Augments to "active patterns"
  • Overloaded custom operations in computation expressions
  • “as” patterns
  • Indentation syntax revisions
  • Additional implicit conversions
  • Additional implicit upcast conversions
  • Implicit integer conversions
  • First-class support for .NET-style implicit conversions
  • Optional warnings for implicit conversions
  • Formatting for binary numbers
  • Discards on use bindings
  • InlineIfLambda optimizer directive
  • Resumable code
  • Additional collection functions
  • Map has Keys and Values
  • Additional intrinsics for NativePtr
  • Additional numeric types with unit annotations
  • Informational warnings for rarely used symbolic operators
F# 7.0 [44]
  • Static abstract members support in interfaces
  • Making working with SRTPs (statically resolved type parameters) easier
  • Required properties checking
  • Init scope and init-only properties
  • Reference assemblies support
  • F# self-contained deployments & Native AOT
  • Added support for N-d arrays up to rank 32.
  • Result module functions parity with Option.
  • Fixes in resumable state machines codegen for the tasks builds.
  • Better codegen for compiler-generated side-effect-free property getters
  • ARM64 platform-specific compiler and ARM64 target support in F# compiler. Dependency manager #r caching support
  • Parallel type-checking and project-checking support (experimental, can be enabled via VS setting, or by tooling authors)
  • Miscellaneous bugfixes and improvements.


F# 8.0 [45]
  • _.Property shorthand for (fun x -> x.Property)
  • Nested record field copy and update
  • while! (while bang) feature [46]
  • Extended string interpolation syntax
  • Use and compose string literals for printf and related functions
  • Arithmetic operators in literals
  • Type constraint intersection syntax
  • Extended fixed binding
  • Easier [<Extension>] method definition
  • Static members in interfaces
  • Static let in discriminated unions, records, structs, and types without primary constructors
  • try-with withing seq{}, [], and [
] collection expressions
  • Recursive calls and yield! within exception handler
  • Tail call attribute
  • [<Struct>] unions can now have > 49 cases
  • Strict indentation rules
  • New diagnostics from the compiler
  • Switches for compiler parallelization

  • Language overview

    Functional programming

    F# is a strongly typed functional-first language with a large number of capabilities that are normally found only in functional programming languages, while supporting object-oriented features available in C#. Together, these features allow F# programs to be written in a completely functional style and also allow functional and object-oriented styles to be mixed.

    Examples of functional features are:

    F# is an expression-based language using eager evaluation and also in some instances lazy evaluation. Every statement in F#, including if expressions, try expressions and loops, is a composable expression with a static type. [49] Functions and expressions that do not return any value have a return type of unit. F# uses the let keyword for binding values to a name. [49] For example:

    letx=3+4

    binds the value 7 to the name x.

    New types are defined using the type keyword. For functional programming, F# provides tuple, record, discriminated union, list, option, and result types. [49] A tuple represents a set of n values, where n ≥ 0. The value n is called the arity of the tuple. A 3-tuple would be represented as (A, B, C), where A, B, and C are values of possibly different types. A tuple can be used to store values only when the number of values is known at design-time and stays constant during execution.

    A record is a type where the data members are named. Here is an example of record definition:

    typeR={Name:stringAge:int}

    Records can be created as letr={Name="AB";Age=42}. The with keyword is used to create a copy of a record, as in {rwithName="CD"}, which creates a new record by copying r and changing the value of the Name field (assuming the record created in the last example was named r).

    A discriminated union type is a type-safe version of C unions. For example,

    typeA=|UnionCaseXofstring|UnionCaseYofint

    Values of the union type can correspond to either union case. The types of the values carried by each union case is included in the definition of each case.

    The list type is an immutable linked list represented either using a head::tail notation (:: is the cons operator) or a shorthand as [item1;item2;item3]. An empty list is written []. The option type is a discriminated union type with choices Some(x) or None. F# types may be generic, implemented as generic .NET types.

    F# supports lambda functions and closures. [49] All functions in F# are first class values and are immutable. [49] Functions can be curried. Being first-class values, functions can be passed as arguments to other functions. Like other functional programming languages, F# allows function composition using the >> and << operators.

    F# provides sequence expressions [50] that define a sequence seq { ... }, list [ ... ] or array [| ... |] through code that generates values. For example,

    seq{forbin0..25doifb<15thenyieldb*b}

    forms a sequence of squares of numbers from 0 to 14 by filtering out numbers from the range of numbers from 0 to 25. Sequences are generators – values are generated on-demand (i.e., are lazily evaluated) – while lists and arrays are evaluated eagerly.

    F# uses pattern matching to bind values to names. Pattern matching is also used when accessing discriminated unions – the union is value matched against pattern rules and a rule is selected when a match succeeds. F# also supports active patterns as a form of extensible pattern matching. [51] It is used, for example, when multiple ways of matching on a type exist. [49]

    F# supports a general syntax for defining compositional computations called computation expressions. Sequence expressions, asynchronous computations and queries are particular kinds of computation expressions. Computation expressions are an implementation of the monad pattern. [50]

    Imperative programming

    F# support for imperative programming includes

    Values and record fields can also be labelled as mutable. For example:

    // Define 'x' with initial value '1'letmutablex=1// Change the value of 'x' to '3'x<-3

    Also, F# supports access to all CLI types and objects such as those defined in the System.Collections.Generic namespace defining imperative data structures.

    Object-oriented programming

    Like other Common Language Infrastructure (CLI) languages, F# can use CLI types through object-oriented programming. [49] F# support for object-oriented programming in expressions includes:

    Support for object-oriented programming in patterns includes

    F# object type definitions can be class, struct, interface, enum, or delegate type definitions, corresponding to the definition forms found in C#. For example, here is a class with a constructor taking a name and age, and declaring two properties.

    /// A simple object type definitiontypePerson(name:string,age:int)=memberx.Name=namememberx.Age=age

    Asynchronous programming

    F# supports asynchronous programming through asynchronous workflows. [52] An asynchronous workflow is defined as a sequence of commands inside an async{ ... }, as in

    letasynctask=async{letreq=WebRequest.Create(url)let!response=req.GetResponseAsync()usestream=response.GetResponseStream()usestreamreader=newSystem.IO.StreamReader(stream)returnstreamreader.ReadToEnd()}

    The let! indicates that the expression on the right (getting the response) should be done asynchronously but the flow should only continue when the result is available. In other words, from the point of view of the code block, it's as if getting the response is a blocking call, whereas from the point of view of the system, the thread won't be blocked and may be used to process other flows until the result needed for this one becomes available.

    The async block may be invoked using the Async.RunSynchronously function. Multiple async blocks can be executed in parallel using the Async.Parallel function that takes a list of async objects (in the example, asynctask is an async object) and creates another async object to run the tasks in the lists in parallel. The resultant object is invoked using Async.RunSynchronously. [52]

    Inversion of control in F# follows this pattern. [52]

    Since version 6.0, F# supports creating, consuming and returning .NET tasks directly. [53]

    openSystem.Net.HttpletfetchUrlAsync(url:string)=// string -> Task<string>task{useclient=newHttpClient()let!response=client.GetAsync(url)let!content=response.Content.ReadAsStringAsync()do!Task.Delay500returncontent}// UsageletfetchPrint()=lettask=task{let!data=fetchUrlAsync"https://example.com"printfn$"{data}"}task.Wait()

    Parallel programming

    Parallel programming is supported partly through the Async.Parallel, Async.Start and other operations that run asynchronous blocks in parallel.

    Parallel programming is also supported through the Array.Parallel functional programming operators in the F# standard library, direct use of the System.Threading.Tasks task programming model, the direct use of .NET thread pool and .NET threads and through dynamic translation of F# code to alternative parallel execution engines such as GPU [8] code.

    Units of measure

    The F# type system supports units of measure checking for numbers. [54]

    In F#, you can assign units of measure, such as meters or kilograms, to floating point, unsigned integer [55] and signed integer values. This allows the compiler to check that arithmetic involving these values is dimensionally consistent, helping to prevent common programming mistakes by ensuring that, for instance, lengths aren't mistakenly added to times.

    The units of measure feature integrates with F# type inference to require minimal type annotations in user code. [56]


    [<Measure>]typem// meter[<Measure>]types// secondletdistance=100.0<m>// float<m>lettime=5.0<s>// float<s>letspeed=distance/time// float<m/s>[<Measure>]typekg// kilogram[<Measure>]typeN=(kg*m)/(s^2)// Newtons[<Measure>]typePa=N/(m^2)// Pascals [<Measure>]typedaysletbetter_age=3u<days>// uint<days>

    The F# static type checker provides this functionality at compile time, but units are erased from the compiled code. Consequently, it is not possible to determine a value's unit at runtime.

    Metaprogramming

    F# allows some forms of syntax customizing via metaprogramming to support embedding custom domain-specific languages within the F# language, particularly through computation expressions. [49]

    F# includes a feature for run-time meta-programming called quotations. [57] A quotation expression evaluates to an abstract syntax tree representation of the F# expressions. Similarly, definitions labelled with the [<ReflectedDefinition>] attribute can also be accessed in their quotation form. F# quotations are used for various purposes including to compile F# code into JavaScript [7] and GPU [8] code. Quotations represent their F# code expressions as data for use by other parts of the program while requiring it to be syntactically correct F# code.

    Information-rich programming

    F# 3.0 introduced a form of compile-time meta-programming through statically extensible type generation called F# type providers. [58] F# type providers allow the F# compiler and tools to be extended with components that provide type information to the compiler on-demand at compile time. F# type providers have been used to give strongly typed access to connected information sources in a scalable way, including to the Freebase knowledge graph. [59]

    In F# 3.0 the F# quotation and computation expression features are combined to implement LINQ queries. [60] For example:

    // Use the OData type provider to create types that can be used to access the Northwind database.openMicrosoft.FSharp.Data.TypeProviderstypeNorthwind=ODataService<"http://services.odata.org/Northwind/Northwind.svc">letdb=Northwind.GetDataContext()// A query expression.letquery1=query{forcustomerindb.Customersdoselectcustomer}

    The combination of type providers, queries and strongly typed functional programming is known as information rich programming. [61]

    Agent programming

    F# supports a variation of the actor programming model through the in-memory implementation of lightweight asynchronous agents. For example, the following code defines an agent and posts 2 messages:

    typeMessage=|Enqueueofstring|DequeueofAsyncReplyChannel<Option<string>>// Provides concurrent access to a list of stringsletlistManager=MailboxProcessor.Start(funinbox->letrecmessageLooplist=async{let!msg=inbox.Receive()matchmsgwith|Enqueueitem->return!messageLoop(item::list)|DequeuereplyChannel->matchlistwith|[]->replyChannel.ReplyNonereturn!messageLooplist|head::tail->replyChannel.Reply(Somehead)return!messageLooptail}// Start the loop with an empty listmessageLoop[])// Usage async{// Enqueue some stringslistManager.Post(Enqueue"Hello")listManager.Post(Enqueue"World")// Dequeue and process the stringslet!str=listManager.PostAndAsyncReply(Dequeue)str|>Option.iter(printfn"Dequeued: %s")}|>Async.Start

    Development tools

    Comparison of integrated development environments

    Application areas

    F# is a general-purpose programming language.

    Web programming

    The SAFE Stack is an end-to-end F# stack to develop web applications. It uses ASP.NET Core on the server side and Fable on the client side. [65]

    An alternative end-to-end F# option is the WebSharper framework. [66]

    Cross-platform app development

    F# can be used together with the Visual Studio Tools for Xamarin to develop apps for iOS and Android. The Fabulous library provides a more comfortable functional interface.

    Analytical programming

    Among others, F# is used for quantitative finance programming, [67] energy trading and portfolio optimization, [68] machine learning, [69] business intelligence [70] and social gaming on Facebook. [71]

    In the 2010s, F# has been positioned as an optimized alternative to C#. F#'s scripting ability and inter-language compatibility with all Microsoft products have made it popular among developers. [72]

    Scripting

    F# can be used as a scripting language, mainly for desktop read–eval–print loop (REPL) scripting. [73]

    Open-source community

    The F# open-source community includes the F# Software Foundation [9] and the F# Open Source Group at GitHub. [10] Popular open-source F# projects include:

    Compatibility

    F# features a legacy "ML compatibility mode" that can directly compile programs written in a large subset of OCaml roughly, with no functors, objects, polymorphic variants, or other additions.

    Examples

    A few small samples follow:

    // This is a comment for a sample hello world program.printfn"Hello World!"

    A record type definition. Records are immutable by default and are compared by structural equality.

    typePerson={FirstName:stringLastName:stringAge:int}// Creating an instance of the recordletperson={FirstName="John";LastName="Doe";Age=30}


    A Person class with a constructor taking a name and age and two immutable properties.

    /// This is a documentation comment for a type definition.typePerson(name:string,age:int)=memberx.Name=namememberx.Age=age/// class instantiationletmrSmith=Person("Smith",42)

    A simple example that is often used to demonstrate the syntax of functional languages is the factorial function for non-negative 32-bit integers, here shown in F#:

    /// Using pattern matching expressionletrecfactorialn=matchnwith|0->1|_->n*factorial(n-1)/// For a single-argument functions there is syntactic sugar (pattern matching function):letrecfactorial=function|0->1|n->n*factorial(n-1)/// Using fold and range operatorletfactorialn=[1..n]|>Seq.fold(*)1

    Iteration examples:

    /// Iteration using a 'for' loopletprintListlst=forxinlstdoprintfn$"{x}"/// Iteration using a higher-order functionletprintList2lst=List.iter(printfn"%d")lst/// Iteration using a recursive function and pattern matchingletrecprintList3lst=matchlstwith|[]->()|h::t->printfn"%d"hprintList3t

    Fibonacci examples:

    /// Fibonacci Number formula[<TailCall>]letfibn=letrecgnf0f1=matchnwith|0->f0|1->f1|_->g(n-1)f1(f0+f1)gn01/// Another approach - a lazy infinite sequence of Fibonacci numbersletfibSeq=Seq.unfold(fun(a,b)->Some(a+b,(b,a+b)))(0,1)// Print even fibs[1..10]|>List.mapfib|>List.filter(funn->(n%2)=0)|>printList// Same thing, using a list expression[foriin1..10doletr=fibiifr%2=0thenyieldr]|>printList

    A sample Windows Forms program:

    // Open the Windows Forms libraryopenSystem.Windows.Forms// Create a window and set a few propertiesletform=newForm(Visible=true,TopMost=true,Text="Welcome to F#")// Create a label to show some text in the formletlabel=letx=3+(4*5)newLabel(Text=$"{x}")// Add the label to the formform.Controls.Add(label)// Finally, run the form[<System.STAThread>]Application.Run(form)

    Asynchronous parallel programming sample (parallel CPU and I/O tasks):

    /// A simple prime number detectorletisPrime(n:int)=letbound=int(sqrt(floatn))seq{2..bound}|>Seq.forall(funx->n%x<>0)// We are using async workflowsletprimeAsyncn=async{return(n,isPrimen)}/// Return primes between m and n using multiple threadsletprimesmn=seq{m..n}|>Seq.mapprimeAsync|>Async.Parallel|>Async.RunSynchronously|>Array.filtersnd|>Array.mapfst// Run a testprimes10000001002000|>Array.iter(printfn"%d")

    See also

    Notes

    1. "F# Software Foundation's License". GitHub . 14 October 2021.
    2. "Microsoft's F# License". GitHub . 16 October 2021.
    3. 1 2 Syme, Granicz & Cisternino (2007:2)
    4. 1 2 3 4 5 "F# Historical Acknowledgements". Microsoft .
    5. 1 2 Syme, Don (2006). "Leveraging .NET Meta-programming Components from F#". [F#] is rooted in the Core ML design, and in particular has a core language largely compatible with that of OCaml
    6. for async
    7. 1 2 3 4 5 6 7 8 9 10 11 12 The F# Software Foundation. "Using F# for Web Applications" . Retrieved 2020-07-30.
    8. 1 2 3 4 5 6 7 8 9 10 11 12 13 The F# Software Foundation. "Using F# for GPU Programming". Archived from the original on 2019-12-25. Retrieved 2019-12-25.
    9. 1 2 3 The F# Software Foundation. "The F# Software Foundation" . Retrieved 2012-11-24.
    10. 1 2 The F# Software Foundation. "F# Compiler (open source edition) @ github" . Retrieved 2012-11-24.
    11. "Develop with Visual F# in Visual Studio" . Retrieved 2020-07-30.
    12. "F#" . Retrieved 2020-07-30.
    13. Syme, Don. "F# 1.0.8 released". Microsoft. Retrieved September 7, 2014.
    14. Syme, Don. "F# 2.0 released as part of Visual Studio 2010". Microsoft. Retrieved September 7, 2014.
    15. Zander, Jason. "Visual Studio 2012 and .NET Framework 4.5 released to the web". Microsoft. Retrieved September 7, 2014.
    16. "Visual Studio 2013 released to web". Microsoft. Retrieved September 7, 2014.
    17. "Announcing the RTM of Visual F# 4.0". Microsoft. Retrieved September 15, 2015.
    18. "Announcing F# 4.1 and the Visual F# Tools for Visual Studio 2017" . Retrieved 2017-03-08.
    19. "Announcing F# 4.5". Microsoft. 14 August 2018. Retrieved August 14, 2018.
    20. "FSharp.Core 4.5.0".
    21. "Download .NET Core 2.1 (Linux, macOS, and Windows)". Microsoft. Retrieved May 13, 2021.
    22. "Announcing F# 4.6". Microsoft. 29 March 2019. Retrieved March 29, 2019.
    23. "FSharp.Core 4.6.0".
    24. "Download .NET Core 2.2 (Linux, macOS, and Windows)". Microsoft. Retrieved May 13, 2021.
    25. "Announcing F# 4.7". Microsoft. 23 September 2019. Retrieved September 23, 2019.
    26. "FSharp.Core 4.7.0".
    27. "Download .NET Core 3.0 (Linux, macOS, and Windows)". Microsoft. Retrieved May 13, 2021.
    28. 1 2 "Announcing F# 5". November 10, 2020.
    29. "Download .NET 5.0 (Linux, macOS, and Windows)". Microsoft. Retrieved May 13, 2021.
    30. "F# 6 is officially here!". November 9, 2021.
    31. "Download .NET 6.0 (Linux, macOS, and Windows)". Microsoft. Retrieved November 14, 2021.
    32. "Announcing F# 7". November 8, 2022.
    33. "Download .NET 7.0 (Linux, macOS, and Windows)". Microsoft. Retrieved November 8, 2022.
    34. "Announcing F# 8". November 14, 2023.
    35. "Download .NET 8.0 (Linux, macOS, and Windows)". Microsoft. Retrieved November 14, 2023.
    36. Edwards, Kathryn (23 December 2008). "The A-Z of programming languages: F#". Network World . IDG. Archived from the original on 13 November 2018. Retrieved 8 August 2016.
    37. McNamara, Brian. "More About F# 3.0 Language Features". Microsoft. Retrieved September 7, 2014.
    38. McNamara, Brian. "Announcing a pre-release of F# 3.1". Microsoft. Retrieved September 7, 2014.
    39. "Announcing the RTM of Visual F# 4.0" . Retrieved 2017-03-08.
    40. "Announcing F# 4.1 and the Visual F# Tools for Visual Studio 2017" . Retrieved 2017-03-08.
    41. "Announcing F# 4.7". 23 September 2019.
    42. "Announcing F# 5". 10 November 2020.
    43. "What's new in F# 6 - F# Guide". 10 March 2023.
    44. "Announcing F# 7". 8 November 2022.
    45. "Announcing F# 8". 14 November 2023.
    46. "Simplifying F# computations with the new 'while!' keyword'". 20 September 2023.
    47. "F Sharp Programming/Computation Expressions - Wikibooks, open books for an open world". en.wikibooks.org. Retrieved 2022-01-21.
    48. kexugit (8 July 2011). "Tail calls in F#". docs.microsoft.com. Retrieved 2022-04-22.
    49. 1 2 3 4 5 6 7 8 "F# Language Overview" (PDF). Retrieved 2007-12-14.
    50. 1 2 "Some Details on F# Computation Expressions" . Retrieved 2007-12-14.
    51. 1 2 "Pattern Matching in F# Part 2 : Active Patterns". Archived from the original on 2012-12-09. Retrieved 2012-11-24.
    52. 1 2 3 "Introducing F# Asynchronous Workflows" . Retrieved 2007-12-14.
    53. "Task Expressions". 19 April 2022. Retrieved 2023-01-15.
    54. "Units of Measure (F#)" . Retrieved 2012-11-24.
    55. "Extend Units of Measure to Include More Numeric Types". GitHub .
    56. "Units of Measure in F#: Part One, Introducing Units" . Retrieved 2012-11-24.
    57. "Code Quotations (F#)" . Retrieved 2012-11-24.
    58. "Type Providers" . Retrieved 2012-11-24.
    59. "New Tech Report from Microsoft Research: Strongly-Typed Language Support for Internet-Scale Information Sources" . Retrieved 2012-11-24.
    60. "Query Expressions (F#)" . Retrieved 2012-11-24.
    61. "F# 3.0 – LINQ + Type Providers= Information Rich Programming" . Retrieved 2012-11-24.
    62. Alexander Kurakin (15 March 2019). "Rider 2019.1 Kicks off its Early Access Program!".
    63. "Use F# on Windows". F# Software Foundation. Retrieved 2018-08-07.
    64. "Features – Rider". JetBrains. Retrieved 2018-08-07.
    65. "Fable: JavaScript you can be proud of!". fable.io. Retrieved 2017-12-09.
    66. Intellifactory. "WebSharper home" . Retrieved 2012-11-24.
    67. "Microsoft Case Studies:Microsoft Visual Studio 2012 - Financial Services Firm". Microsoft . Retrieved 2012-11-25.
    68. "F# for Energy Trading and Portfolio Optimization" . Retrieved 2012-11-25.
    69. "Microsoft Case Study: Grange Insurance". Microsoft . Retrieved 2012-11-25.
    70. Trelford, Phil (2007). "Learning with F#". Proceedings of the 4th ACM SIGPLAN workshop on Commercial users of functional programming - CUFP '07. pp. 1–2. doi:10.1145/1362702.1362709. ISBN   9781450378444. S2CID   24018363 . Retrieved 2012-11-25.
    71. "F# Job in Facebook Social Gaming" . Retrieved 2012-11-25.
    72. "F# Developer Testimonials" . Retrieved May 25, 2021.
    73. "Scripting in F#". 12 September 2008. Retrieved 2020-01-17.

    Related Research Articles

    <span class="mw-page-title-main">JavaScript</span> High-level programming language

    JavaScript, often abbreviated as JS, is a programming language and core technology of the Web, alongside HTML and CSS. 99% of websites use JavaScript on the client side for webpage behavior.

    OCaml is a general-purpose, high-level, multi-paradigm programming language which extends the Caml dialect of ML with object-oriented features. OCaml was created in 1996 by Xavier Leroy, Jérôme Vouillon, Damien Doligez, Didier Rémy, Ascánder Suárez, and others.

    <span class="mw-page-title-main">Visual Basic (.NET)</span> Object-oriented computer programming language

    Visual Basic (VB), originally called Visual Basic .NET (VB.NET), is a multi-paradigm, object-oriented programming language, implemented on .NET, Mono, and the .NET Framework. Microsoft launched VB.NET in 2002 as the successor to its original Visual Basic language, the last version of which was Visual Basic 6.0. Although the ".NET" portion of the name was dropped in 2005, this article uses "Visual Basic [.NET]" to refer to all Visual Basic languages released since 2002, in order to distinguish between them and the classic Visual Basic. Along with C# and F#, it is one of the three main languages targeting the .NET ecosystem. Microsoft updated its VB language strategy on 6 February 2023, stating that VB is a stable language now and Microsoft will keep maintaining it.

    This article compares two programming languages: C# with Java. While the focus of this article is mainly the languages and their features, such a comparison will necessarily also consider some features of platforms and libraries. For a more detailed comparison of the platforms, see Comparison of the Java and .NET platforms.

    In computer programming, an entry point is the place in a program where the execution of a program begins, and where the program has access to command line arguments.

    In computer science, future, promise, delay, and deferred refer to constructs used for synchronizing program execution in some concurrent programming languages. They describe an object that acts as a proxy for a result that is initially unknown, usually because the computation of its value is not yet complete.

    <span class="mw-page-title-main">C Sharp (programming language)</span> Programming language

    C# is a general-purpose high-level programming language supporting multiple paradigms. C# encompasses static typing, strong typing, lexically scoped, imperative, declarative, functional, generic, object-oriented (class-based), and component-oriented programming disciplines.

    <span class="mw-page-title-main">Python syntax and semantics</span> Set of rules defining correctly structured programs

    The syntax of the Python programming language is the set of rules that defines how a Python program will be written and interpreted. The Python language has many similarities to Perl, C, and Java. However, there are some definite differences between the languages. It supports multiple programming paradigms, including structured, object-oriented programming, and functional programming, and boasts a dynamic type system and automatic memory management.

    In computer programming, an anonymous function is a function definition that is not bound to an identifier. Anonymous functions are often arguments being passed to higher-order functions or used for constructing the result of a higher-order function that needs to return a function. If the function is only used once, or a limited number of times, an anonymous function may be syntactically lighter than using a named function. Anonymous functions are ubiquitous in functional programming languages and other languages with first-class functions, where they fulfil the same role for the function type as literals do for other data types.

    TypeScript is a free and open-source high-level programming language developed by Microsoft that adds static typing with optional type annotations to JavaScript. It is designed for the development of large applications and transpiles to JavaScript. Because TypeScript is a superset of JavaScript, all JavaScript programs are syntactically valid TypeScript, but they can fail to type-check for safety reasons.

    This article describes the syntax of the C# programming language. The features described are compatible with .NET Framework and Mono.

    In multithreaded computer programming, asynchronous method invocation (AMI), also known as asynchronous method calls or the asynchronous pattern is a design pattern in which the call site is not blocked while waiting for the called code to finish. Instead, the calling thread is notified when the reply arrives. Polling for a reply is an undesired option.

    <span class="mw-page-title-main">Rust (programming language)</span> General-purpose programming language

    Rust is a multi-paradigm, general-purpose programming language that emphasizes performance, type safety, and concurrency. It enforces memory safety—meaning that all references point to valid memory—without a garbage collector. To simultaneously enforce memory safety and prevent data races, its "borrow checker" tracks the object lifetime of all references in a program during compilation.

    Nemerle is a general-purpose, high-level, statically typed programming language designed for platforms using the Common Language Infrastructure (.NET/Mono). It offers functional, object-oriented, aspect-oriented, reflective and imperative features. It has a simple C#-like syntax and a powerful metaprogramming system.

    Windows Runtime (WinRT) is a platform-agnostic component and application architecture first introduced in Windows 8 and Windows Server 2012 in 2012. It is implemented in C++ and officially supports development in C++, Rust/WinRT, Python/WinRT, JavaScript-TypeScript, and the managed code languages C# and Visual Basic (.NET) (VB.NET).

    Join-patterns provides a way to write concurrent, parallel and distributed computer programs by message passing. Compared to the use of threads and locks, this is a high level programming model using communication constructs model to abstract the complexity of concurrent environment and to allow scalability. Its focus is on the execution of a chord between messages atomically consumed from a group of channels.

    Elixir is a functional, concurrent, high-level general-purpose programming language that runs on the BEAM virtual machine, which is also used to implement the Erlang programming language. Elixir builds on top of Erlang and shares the same abstractions for building distributed, fault-tolerant applications. Elixir also provides tooling and an extensible design. The latter is supported by compile-time metaprogramming with macros and polymorphism via protocols.

    In computer programming, the async/await pattern is a syntactic feature of many programming languages that allows an asynchronous, non-blocking function to be structured in a way similar to an ordinary synchronous function. It is semantically related to the concept of a coroutine and is often implemented using similar techniques, and is primarily intended to provide opportunities for the program to execute other code while waiting for a long-running, asynchronous task to complete, usually represented by promises or similar data structures. The feature is found in C#, C++, Python, F#, Hack, Julia, Dart, Kotlin, Rust, Nim, JavaScript, Swift and Zig.

    Swift is a high-level general-purpose, multi-paradigm, compiled programming language created by Chris Lattner in 2010 for Apple Inc. and maintained by the open-source community. Swift compiles to machine code, as it is an LLVM-based compiler. Swift was first released in June 2014, and the Swift toolchain has shipped in Xcode since version 6, released in 2014.

    <span class="mw-page-title-main">Nim (programming language)</span> Programming language

    Nim is a general-purpose, multi-paradigm, statically typed, compiled high-level systems programming language, designed and developed by a team around Andreas Rumpf. Nim is designed to be "efficient, expressive, and elegant", supporting metaprogramming, functional, message passing, procedural, and object-oriented programming styles by providing several features such as compile time code generation, algebraic data types, a foreign function interface (FFI) with C, C++, Objective-C, and JavaScript, and supporting compiling to those same languages as intermediate representations.

    References