Content deleted Content added
m fix reason in hatnote |
Jerryobject (talk | contribs) Template:Infobox programming language, WP:REFerence WP:CITations: parameters: reorder, needless underscores > spaces, respaces, update-standardizes, conform to master templates. WP:LINKs: update-standardizes, needless WP:PIPEs > WP:NOPIPEs. |
||
Line 9:
| paradigm = [[Programming paradigm#Multi-paradigm|Multi-paradigm]]: [[functional programming|functional]], [[imperative programming|imperative]], [[object-oriented programming|object-oriented]], [[agent-oriented programming|agent-oriented]], [[metaprogramming]], [[Reflection (computer programming)|reflective]], [[concurrent programming|concurrent]]
| family = [[ML (programming language)|ML]]
| released = {{Start date and age|2005}}, version 1.0▼
| designer = [[Don Syme]], [[Microsoft Research]]
| developer = [[Microsoft]], [[F Sharp Software Foundation|The F# Software Foundation]]
▲| released = {{Start date and age|2005}}, version 1.0
|
|
| latest preview version =
| latest preview date =
Line 19:
| implementations =
| dialects =
| influenced by = [[C Sharp (programming language)|C#]], [[Erlang (programming language)|Erlang]], [[
| influenced = [[C Sharp (programming language)|C#]],<ref>for async</ref> [[Elm (programming language)|Elm]], [[F* (programming language)|F*]], [[LiveScript (programming language)|LiveScript]]
| programming language =
| operating system = [[Cross-platform]]: [[.NET Core|.NET]], [[.NET
| license = [[MIT License]]<ref>{{cite web|url=https://github.com/fsharp/fsharp/blob/master/License.txt|title=F# Software Foundation's License|website=[[GitHub]]|date=14 October 2021}}</ref><ref>{{cite web|url=https://github.com/Microsoft/visualfsharp/blob/master/License.txt|title=Microsoft's F# License|website=[[GitHub]]|date=16 October 2021}}</ref>
| website = {{URL|https://fsharp.org/}}
Line 29:
| file ext = .fs, .fsi, .fsx, .fsscript
}}
'''F#''' (pronounced '''F sharp''') is a functional-first, [[General-purpose programming language|general-purpose]], [[Strong and weak typing|strongly typed]], [[Programming paradigm#Multi-paradigm|multi-paradigm]] [[programming language]] that encompasses [[functional programming|functional]], [[imperative programming|imperative]], and [[object-oriented programming]] methods. It is most often used as a cross-platform [[Common Language Infrastructure]] (CLI) language on [[.NET Core|.NET]], but can also generate [[JavaScript]]<ref name="js">{{cite web |url=
F# is developed by the [[F Sharp Software Foundation|F# Software Foundation]],<ref name="fsharporg">{{cite web |url=
F# is a member of the [[ML (programming language)|ML]] language family and originated as a [[.NET Framework]] implementation of a core of the programming language [[OCaml]].<ref name="historyMSR"
[[Python (programming language)|Python]], [[
==History==
Line 63:
| [http://fsharp.org/specs/language-spec/index.html#f-30 November 2012]
| August 2012<ref>{{cite web|last=Zander|first=Jason|title=Visual Studio 2012 and .NET Framework 4.5 released to the web|url=http://blogs.msdn.com/b/jasonz/archive/2012/08/15/visual-studio-2012-and-net-framework-4-5-released-to-the-web.aspx|publisher=Microsoft|access-date=September 7, 2014}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]];<br
|[[.NET Framework|.NET]] 2.0 - 4.5, [[Mono (software)|Mono]]
|-
Line 69:
| [http://fsharp.org/specs/language-spec/index.html#f-31 November 2013]
| October 2013<ref>{{cite web|title=Visual Studio 2013 released to web|url=http://blogs.msdn.com/b/visualstudio/archive/2013/10/17/visual-studio-2013-released-to-web.aspx|publisher=Microsoft|access-date=September 7, 2014}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]];<br
|[[.NET Framework|.NET]] 2.0 - 4.5, [[Mono (software)|Mono]]
|-
Line 75:
| [http://fsharp.org/specs/language-spec/index.html#f-40 January 2016]
| July 2015<ref>{{cite web|title=Announcing the RTM of Visual F# 4.0|url=http://blogs.msdn.com/b/dotnet/archive/2015/07/20/announcing-the-rtm-of-visual-f-4-0.aspx|publisher=Microsoft|access-date=September 15, 2015}}</ref>
|<!-- [[Linux]], [[macOS]], [[Microsoft Windows|Windows]];<br
|<!-- [[.NET Framework|.NET]] 2.0 - 4.5, [[Mono (software)|Mono]] -->
|-
Line 82:
|March 2017<ref>{{Cite news|url=https://blogs.msdn.microsoft.com/dotnet/2017/03/07/announcing-f-4-1-and-the-visual-f-tools-for-visual-studio-2017-2/|title=Announcing F# 4.1 and the Visual F# Tools for Visual Studio 2017|access-date=2017-03-08|language=en-US}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
|[[.NET Framework|.NET]] 3.5 - 4.6.2, [[.NET Core]], [[Mono (software)|Mono]]
|-
Line 89:
|August 2018<ref>{{cite web|title=Announcing F# 4.5|date=14 August 2018|url=https://blogs.msdn.microsoft.com/dotnet/2018/08/14/announcing-f-4-5/|publisher=Microsoft|access-date=August 14, 2018}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Framework|.NET]] 4.5 - 4.7.2,<ref>{{Cite web|url=https://www.nuget.org/packages/FSharp.Core/4.5.0|title=FSharp.Core 4.5.0}}</ref> [[.NET Core]] SDK 2.1.400<ref>{{cite web|title=Download .NET Core 2.1 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/download/dotnet/2.1|publisher=Microsoft|access-date=May 13, 2021}}</ref>
|-
Line 96:
|March 2019<ref>{{cite web|title=Announcing F# 4.6|date=29 March 2019|url=https://devblogs.microsoft.com/dotnet/announcing-f-4-6/|publisher=Microsoft|access-date=March 29, 2019}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Framework|.NET]] 4.5 - 4.7.2,<ref>{{Cite web|url=https://www.nuget.org/packages/FSharp.Core/4.6.0|title=FSharp.Core 4.6.0}}</ref> [[.NET Core]] SDK 2.2.300<ref>{{cite web|title=Download .NET Core 2.2 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/download/dotnet/2.2|publisher=Microsoft|access-date=May 13, 2021}}</ref>
|-
Line 103:
|September 2019<ref>{{cite web|title=Announcing F# 4.7|date=23 September 2019|url=https://devblogs.microsoft.com/dotnet/announcing-f-4-7/|publisher=Microsoft|access-date=September 23, 2019}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Framework|.NET]] 4.5 - 4.8,<ref>{{Cite web|url=https://www.nuget.org/packages/FSharp.Core/4.7.0|title=FSharp.Core 4.7.0}}</ref> [[.NET Core]] SDK 3.0.100<ref>{{cite web|title=Download .NET Core 3.0 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/download/dotnet/3.0|publisher=Microsoft|access-date=May 13, 2021}}</ref>
|-
|F# 5.0
|
|November 2020<ref name="blogs.msdn.microsoft.com2">{{Cite web|url=https://devblogs.microsoft.com/dotnet/announcing-f-5/|title
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Core|.NET]] SDK 5.0.100<ref>{{cite web|title=Download .NET 5.0 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/download/dotnet/5.0|publisher=Microsoft|access-date=May 13, 2021}}</ref>
|-
|F# 6.0
|
|November 2021<ref>{{Cite web|url=https://devblogs.microsoft.com/dotnet/fsharp-6-is-officially-here/|title
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Core|.NET]] SDK 6.0.100<ref>{{cite web|title=Download .NET 6.0 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/download/dotnet/6.0|publisher=Microsoft|access-date=November 14, 2021}}</ref>
Line 123:
|F# 7.0
|
|November 2022<ref>{{Cite web|url=https://devblogs.microsoft.com/dotnet/announcing-fsharp-7/|title
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]],
[[JavaScript]],<ref name="js"
| [[.NET Core|.NET]] SDK 7.0.100<ref>{{cite web|title=Download .NET 7.0 (Linux, macOS, and Windows)|url=https://dotnet.microsoft.com/en-us/download/dotnet/7.0|publisher=Microsoft|access-date=November 8, 2022}}</ref>
Line 137:
F# was first included in Visual Studio in the [[Visual_Studio#2010 | 2010 edition]], at the same level as [[Visual Basic (.NET) | 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]],<ref name="historyMSR">{{cite web |url=
Andrew Kennedy contributed to the design of [[units of measure]].<ref name="historyMSR"
{| class="wikitable"
Line 220:
* Support for 'fixed'
|-
!F# 4.5<ref name="blogs.msdn.microsoft.com2"
|
* Versioning alignment of binary, package, and language
Line 239:
* Anonymous record types
|-
!F# 4.7<ref name="blogs.msdn.microsoft.com.4.7">{{Cite web|url=https://devblogs.microsoft.com/dotnet/announcing-f-4-7/|title
|
* Implicit yields
Line 247:
* Open static classes
|-
!F# 5.0<ref name="blogs.msdn.microsoft.com.5.0">{{Cite web|url=https://devblogs.microsoft.com/dotnet/announcing-f-5/|title
|
* FSharp.Core now targets netstandard2.0 only
Line 264:
* Improved compiler analysis for library authors
|-
!F# 6.0<ref>{{Cite web|url=https://docs.microsoft.com/en-us/dotnet/fsharp/whats-new/fsharp-6|title
|
* Tasks
Line 287:
* Informational warnings for rarely used symbolic operators
|-
!F# 7.0<ref>{{Cite web|url=https://devblogs.microsoft.com/dotnet/announcing-fsharp-7/|title
|
* Static abstract members support in interfaces
Line 329:
F# is an expression-based language using [[eager evaluation]] and also in some instances [[lazy evaluation]]. Every statement in F#,
including <code>if</code> expressions, <code>try</code> expressions and loops, is a composable expression with a static type.<ref name="overview"
<syntaxhighlight lang="fsharp">
let x = 3 + 4
Line 335:
binds the value <code>7</code> to the name <code>x</code>.
New types are defined using the <code>type</code> keyword. For functional programming, F# provides ''tuple'', ''record'', ''discriminated union'', ''list'', ''option'', and ''result'' types.<ref name="overview"
A ''record'' is a type where the data members are named. Here is an example of record definition:
Line 343:
Age : int }
</syntaxhighlight>
Records can be created as {{code|lang=fsharp|code=let r = { Name="AB"; Age=42
A [[tagged union|discriminated union]] type is a [[type-safe]] version of [[union (computer science)|C unions]]. For example,
Line 355:
The ''list'' type is an immutable [[linked list]] represented either using a {{code|lang=fsharp|code=head::tail}} notation (<code>::</code> is the [[cons]] operator) or a shorthand as {{code|lang=fsharp|code=[item1; item2; item3]}}. An empty list is written <code>[]</code>. The ''option'' type is a discriminated union type with choices <code>Some(x)</code> or <code>None</code>. F# types may be [[generic programming|generic]], implemented as generic .NET types.
F# supports [[lambda calculus|lambda functions]] and [[closure (computing)|closure]]s.<ref name="overview"
F# provides ''{{visible anchor|sequence expressions}}''<ref name="seq"/> that define a sequence <code>seq { ... }</code>, list <code>[ ... ]</code> or array <code>[| ... |]</code> through code that generates values. For example,
Line 365:
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 [[Generator (computer programming)|generators]] – values are generated on-demand (i.e., are [[lazy evaluation|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.<ref name="activePatterns"
F# supports a general syntax for defining compositional computations called ''{{visible anchor|computation expressions}}''. Sequence expressions, asynchronous computations and queries are particular kinds of computation expressions. Computation expressions are an implementation of the [[monad (functional programming)|monad]] pattern.<ref name="seq">{{cite web |url=
===Imperative programming===
Line 385:
===Object-oriented programming===
Like other [[Common Language Infrastructure]] (CLI) languages, F# can use CLI types through object-oriented programming.<ref name="overview"
* Dot-notation, e.g., {{code|lang=fsharp|code=x.Name}}
* Object expressions, e.g., {{ code|lang=fsharp| code={ new obj() with member x.ToString() = "hello" }
* Object construction, e.g., {{code|lang=fsharp|code=new Form()}}
* Type tests, e.g., {{code|lang=fsharp|code=x :? string}}
Line 397:
Support for object-oriented programming in patterns includes
* Type tests, e.g., {{code|lang=fsharp|code=:? string as s}}
* Active patterns, which can be defined over object types<ref name="activePatterns">{{cite web |url=
F# object type definitions can be class, struct, interface, enum, or delegate type definitions, corresponding to the definition forms found in [[C Sharp (programming language)|C#]]. For example, here is a class with a constructor taking a name and age, and declaring two properties.
Line 408:
===Asynchronous programming===
F# supports [[asynchronous programming]] through ''asynchronous workflows''.<ref name="aw"
<syntaxhighlight lang="fsharp">
let asynctask =
Line 419:
The <code>let!</code> 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 while the result needed for this one doesn't become available.
The async block may be invoked using the <code>Async.RunSynchronously</code> function. Multiple async blocks can be executed in parallel using the <code>Async.Parallel</code> function that takes a list of <code>async</code> objects (in the example, <code>asynctask</code> is an async object) and creates another async object to run the tasks in the lists in parallel. The resultant object is invoked using <code>Async.RunSynchronously</code>.<ref name="aw">{{cite web |url=
[[Inversion of control]] in F# follows this pattern.<ref name="aw"
===Parallel programming===
Parallel programming is supported partly through the <code>Async.Parallel</code>, <code>Async.Start</code> and other operations that run asynchronous blocks in parallel.
Parallel programming is also supported through the <code>Array.Parallel</code> functional programming operators in the F# standard library, direct use of the <code>System.Threading.Tasks</code> 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 [[Graphics processing unit|GPU]]<ref name="gpgpu"
===Units of measure===
The F# type system supports [[Units of measurement|units of measure]] checking for numbers.<ref name="units-msdn">{{cite web |url=
===Metaprogramming===
F# allows some forms of syntax customizing via [[metaprogramming]] to support embedding custom [[___domain-specific language]]s within the F# language, particularly through computation expressions.<ref name="overview"
F# includes a feature for run-time meta-programming called quotations.<ref name="quotations">{{cite web |url=
===Information-rich programming===
F# 3.0 introduced a form of compile-time meta-programming through statically extensible type generation called F# type providers.<ref name="typeproviders">{{cite web |url=
In F# 3.0 the F# quotation and computation expression features are combined to implement [[LINQ]] queries.<ref name="queries">{{cite web |url=
<syntaxhighlight lang="fsharp">
// Use the OData type provider to create types that can be used to access the Northwind database.
Line 451:
</syntaxhighlight>
The combination of type providers, queries and strongly typed functional programming is known as ''information rich programming''.<ref name="irp">{{cite web |url=
===Agent programming===
Line 466:
==Development tools==
* [[Microsoft Visual Studio|Visual Studio]], with the Visual F# tools from [[Microsoft]] installed, can be used to create, run and debug F# projects. The Visual F# tools include a Visual Studio-hosted [[read–eval–print loop]] (REPL) interactive console that can execute F# code as it is written.
* [[Visual Studio Code]] contains full support for F# via the [http://ionide.io/ Ionide extension].
* F# can be developed with any text editor. Specific support exists in editors such as [[Emacs]].
Line 479:
The [https://safe-stack.github.io/ SAFE Stack] is an end-to-end F# stack to develop web applications. It uses [[ASP.NET Core]] on the server side and [https://fable.io Fable] on the client side.<ref>{{Cite web|url=http://fable.io/|title=Fable: JavaScript you can be proud of!|website=fable.io|access-date=2017-12-09}}</ref>
An alternative end-to-end F# option is the [[WebSharper]] framework.<ref name="websharper">{{cite web |url=
===Cross-platform app development===
Line 486:
=== Analytical programming ===
Among others, F# is used for quantitative finance programming,<ref>{{cite web |url=
In the 2010s, F# has been positioned as an optimized alternative to [[C Sharp (programming language)|C#]]. F#'s scripting ability and inter-language compatibility with all Microsoft products have made it popular among developers.<ref>{{cite web |url=
===Scripting===
F# can be used as a scripting language, mainly for desktop [[read–eval–print loop]] (REPL) scripting.<ref>{{cite web |url=
==Open-source community==
The F# [[Open-source model|open-source]] community includes the F# Software Foundation<ref name="fsharporg"
* [https://fable.io/ Fable], an F# to Javascript transpiler based on [https://babeljs.io Babel].
Line 647:
* {{citation |first=Tomas |last=Petricek |title=Real World Functional Programming With Examples in F# and C# |year=2009 |publisher=[[Manning Publications]]}}
* {{citation |first1=Michael |last1=Hansen|first2=Hans |last2=Rischel |title=Functional Programming Using F# |year=2013 |publisher=[[Cambridge University Press]]}}
* {{citation |first1=Johan|last1=Astborg |title=
* {{citation |first1=Mikael|last1=Lundin |title=
==External links==
Line 654:
* {{Official website|https://fsharp.org/}} The F# Software Foundation
* [https://fsharp.github.io The F# Open Source Group at GitHub]
* [https://fsharp.net/ The Visual F# Developer Center] {{Webarchive|url=https://web.archive.org/web/20081119161341/http://www.fsharp.net/ |date=2008-11-19
* [https://web.archive.org/web/20140703090417/http://tsunami.io/ Tsunami, an embeddable desktop F# IDE]
* [https://web.archive.org/web/20130921130415/http://tsunami.io/cloud_tsunami.html Cloud Tsunami, an embeddable Silverlight F# IDE]
Line 661:
* [https://learn.microsoft.com/en-us/archive/blogs/fsharpteam/ The Visual F# team blog]
* [https://www.microsoft.com/en-us/research/project/f-at-microsoft-research/ The original Microsoft Research website for F#]
* [http://feedproxy.google.com/planet_fsharp Planet F#] {{Webarchive|url=https://web.archive.org/web/20090213202656/http://feedproxy.google.com/planet_fsharp |date=2009-02-13
* [https://web.archive.org/web/20110715231625/http://www.ctocorner.com/fsharp/book/default.aspx The F# Survival Guide, Dec 2009 (Web-based book)]
* [http://fsharp.org/specs/language-spec/ The F# Language Specification]
* [http://www.developerfusion.com/article/122079/intro-to-f/ An introduction to F# programming] {{Webarchive|url=https://web.archive.org/web/20110713133206/http://www.developerfusion.com/article/122079/intro-to-f/ |date=2011-07-13
* [http://opcoast.com/demos/fsharp/index.html A tutorial showing the ''process'' of reaching a functional design; includes test and parallel coding]
|