We're excited to announce the RTM releases of .NET Framework 4.6 and Visual Studio 2015 today. You can read about the new features or leave that for later and try them out now. The quickest way to get started is to install the free Visual Studio 2015 Community version.
With the .NET Framework 4.6, you'll enjoy better performance with the new 64-bit "RyuJIT" JIT and high DPI support for WPF and Windows Forms. ASP.NET provides HTTP/2 support when running on Windows 10 and has more async task-returning APIs. There are also major updates in Visual Studio 2015 for .NET developers, many of which are built on top of the new Roslyn compiler framework. The .NET languages -- C# 6, F# 4, VB 14 -- have been updated, too.
We're also announcing updates to .NET Core and ASP.NET 5, both recently released as beta 5 and included in Visual Studio 2015. The .NET tools for Windows 10 UWP app development, including .NET Native, will be shipping shortly, on 7/29. We will have a lot to share about .NET UWP apps and the .NET Native technology at that time.
You can download and try out the releases now:
As a team, we're really excited to share everything we've been working on:
- .NET Framework 4.6
- ASP.NET 4.6
- Entity Framework
- .NET Languages
- Visual Studio Improvements for .NET Developers
- .NET Core and ASP.NET 5
You can check out the earlier RC and Preview releases to see how the release has developed over the last year. In fact, it's only been 14 months since we released the .NET Framework 4.5.2.
.NET Framework 4.6
There are many great features in the .NET Framework 4.6. Some of these features, like RyuJIT and the latest GC updates, can provide improvements by just installing the .NET Framework 4.6. Give it a try!
You can learn more about the release by looking at What's New in the .NET Framework, the .NET Framework 4.6 release changelist and an .NET Framework API diff between the .NET Framework 4.6 and 4.5.2 releases. Check out the ASP.NET Team post to learn more about ASP.NET updates.
The .NET Framework 4.6 is part of Windows 10 and can be installed on Windows 7 and Windows 8. You can target the .NET Framework 4.6 in Visual Studio 2012 or later, by installing the the .NET Framework 4.6 Targeting Pack. It comes with Visual Studio 2015.
Windows Presentation Foundation
The team has made key improvements to WPF in this release:
Transparent Child Window support
WPF now supports transparent child windows in Windows 8.1 and above. This enables you to create and compose non rectangular and transparent child windows in your top level Windows. You can enable this by setting the UsesPerPixelTransparency property to true in HwndSourceParameters.
High DPI Improvements
High DPI support in WPF is now better. Changes have been made to layout rounding to reduce instances of clipping in controls with borders. By default, this feature is enabled if your Target Framework is .NET Framework 4.6 (".NETFramework,Version=v4.6") or higher. Applications that target earlier versions of the framework can opt in into the new behavior by adding the following setting to an app.config file. The setting only takes effect when the application is running on the .NET Framework 4.6.
WPF windows straddling multiple monitors with different DPI settings (Multi-DPI setup) are now rendered correctly, without blacked out regions. You can opt out of this behavior by adding the following line to the section in the app.config file:
Support for automatically loading the right cursor based on DPI setting has been added to System.Windows.Input.Cursor. This enables you to provide a multi-image .cur file to the WPF platform and configure it to automatically pick up the right cursor based on the current DPI of the active display.
Touch is better
The team adopted the double-tap threshold used by UWP applications, which is considered to be an industry-quality implementation. WPF now uses this same implementation on Windows 8.1 and above.
Touch events are now more reliable. This Connect issue requesting touch event improvements has been fixed in this release.
Windows Forms Updates for High DPI
Windows Forms High DPI support has been updated to include more controls, which is a project that started in the .NET Framework 4.5.2.
The following controls have High DPI support in the .NET Framework 4.6: ComboBox, Cursor, DataGridView, DataGridViewColumn, DataGridViewComboBoxColumn, DomainUpDown, NumericUpDown, ToolStripComboBox, ToolStripMenuItem and ToolStripSplitButton.
You can see a few examples of Windows Forms High DPI improvements.
This is an opt-in feature. To enable it, set the EnableWindowsFormsHighDpiAutoResizing element to true in the app.config file:
RyuJIT
RyuJIT is the next generation Just-In-Time (JIT) compiler for .NET. It uses a high-performance JIT architecture, focused on high throughput JIT compilation. It is much faster than the existing JIT64 64-bit JIT that has been used for the last 10 years (introduced in 2005 .NET 2.0 release). There was always a big gap in throughput between the 32- and 64-bit JITs. That gap has been closed, making it easier to exclusively target 64-bit architectures or migrate workloads from 32- to 64-bit.
RyuJIT is enabled for 64-bit processes running on top of the .NET Framework 4.6. Your app will run in a 64-bit process if it is compiled as 64-bit or AnyCPU, and run on a 64-bit operating system. RyuJIT is similarly integrated into .NET Core, as the 64-bit JIT.
We've used a transparent process over the last two years with RyuJIT. You've been able to read RyuJIT blog posts, try out several RyuJIT CTPs and (suprise!) can now read and contribute to the RyuJIT source code. Thanks to everyone who helped improve RyuJIT along the way to RTM. We fixed a lot of publicly-reported bugs and performance issues based on those CTP releases. It's been a pleasure for Microsoft engineers to adopt a more public development process with RyuJIT.
The project was initially targeted to improve high-scale 64-bit cloud workloads, although it has much broader applicability. We do expect to add 32-bit support in a future release.
SIMD
The 64-bit CLR introduces support for Single Instruction Multiple Data (SIMD) Vectors. These new types are in the System.Numerics namespace, and are recognized as intrinsics by the JIT, which generates code utilizing the capabilities of SSE2 and AVX2 hardware, depending on the machine.
The new types include fixed-size Vectors with 2 to 4 single precision floating point elements that are suitable for use in applications with explicit N-dimensional algorithms and data types (e.g. points and colors), as well as Vector
This will perform 4 adds in parallel on SSE2, or 8 on AVX2. (Of course, details about ensuring that the arrays are all the same size, and a multiple of Vector.Count have been omitted.)
The Vector
These new types are available via the System.Numerics.Vectors NuGet package, and will automatically be accelerated when run on the 64-bit .NET Framework runtime. SIMD is also supported on the 64-bit .NET Core.
Garbage Collector Updates
The garbage collector has important improvements that reduce latency and improve memory utilization. The GC update has already been deployed to large Microsoft cloud workloads, such as Office 365 and Bing. We've seen impressive improvements in the performance of those services. They've simply deployed the update, without needing any code changes.
The GC now handles pinned objects in a more optimized way. It is now possible for the GC to compact more memory around pinned objects. This change can provide a suprisingly impactful improvement for large-scale workloads with significant use of pinning.
Promotion of generation 1 objects to generation 2 has been updated to use memory more efficiently. The GC attempts to use free space in a given generation before allocating a new memory segment. A new algorithm has been adopted that uses a free space region to allocate an object that more closely matches the object size.
The Garbage Collector has a new mode that avoids garbage collection while certain memory-related conditions are met. This new mode is important for low-latency workloads that cannot afford interuptions. It enables you to specify that a certain amount of memory must be available before entering a No GC Region. While in the region the GC will not collect, which means that it will not interupt your workload during that time. The GC will start collecting if a collection is explicitly requested (e.g. GC.Collect) or if the initially specified memory size is exhausted.
The new mode exposes multiple points of configuration, including allowing you to specify the memory available for the small and large object heaps separately, for use within the No GC region.
Windows Communication Foundation
SSL
WCF now supports SSL version TLS 1.1 and TLS 1.2, in addition to SSL 3.0 and TLS 1.0, when using NetTcp with transport security and client authentication. It is now possible to select which protocol to use, or to disable old less secure protocols. This can be done either by setting the System.ServiceModel.TcpTransportSecurity.SslProtocols property or by updating a configuration file, as shown below.
Send messages using different HTTP connections
WCF now allows users to ensure certain messages are sent using different underlying HTTP connections. There are two ways to achieve this.
- Connection Group name prefix: Users can specify a string that WCF will use as a prefix for the connection group name. Two messages with different prefixes are sent using different underlying HTTP connections. You set the prefix by adding a key/value pair message's System.ServiceModel.Channels.Message.Properties property. The key is "HttpTransportConnectionGroupNamePrefix"; the value is the desired prefix.
Using different channel factories: Users can also enable a feature that will ensure messages sent using channels created by different channel factories will use different underlying HTTP connections. To enable this feature users must set the following appSetting to true:
Windows Workflow
The workflow team added a new setting that specifies the number of seconds a workflow service will hold on to an out-of-order operation request when there is an outstanding “non-protocol” bookmark before timing out the request. A “non-protocol” bookmark is a bookmark that is not related to outstanding Receive activities. Some activities create non-protocol bookmarks within their implementation, so it may not be obvious that a non-protocol bookmark exists. These include State and Pick. So if you have a workflow service implemented with a state machine or containing a Pick activity, you will most likely have non-protocol bookmarks.
You can add the setting in the appSettings section of an app.config file.
The default value is 60 seconds. If the value is set to 0, then the out-of-order requests are immediately rejected with a fault with text that looks like this:
Operation 'Request3|{http://tempuri.org/}IService' on service instance with identifier '2b0667b6-09c8-4093-9d02-f6c67d534292' cannot be performed at this time. Please ensure that the operations are performed in the correct order and that the binding in use provides ordered delivery guarantees.
This is the same message that is received if an out-of-order operation message is received and there are no non-protocol bookmarks.
If the value of FilterResumeTimeoutInSeconds is non-zero and there are non-protocol bookmarks and the timeout expires, the operation fails with a timeout message.
ADO.NET improvements
ADO .NET now supports the Always Encrypted feature available in SQL Server 2016. With Always Encrypted, SQL Server can perform operations on encrypted data, and best of all the encryption key resides with the application inside the customer’s trusted environment and not on the server. Always Encrypted secures customer data so DBAs do not have access to plain text data. Encryption and decryption of data happens transparently at the driver level, minimizing changes that have to be made to existing applications. You can learn more about this feature on the SQL Security Blog.
Async
The new System.Threading.AsyncLocal class allows you to represent ambient data that is local to a given asynchronous control flow, such as an async method. It can be used to persist data across threads. You can also define a callback method that is notified whenever the ambient data changes either because the AsyncLocal.Value property was explicitly changed, or because the thread encountered a context transition. You can see an example of this new type in use.
System.Threading.Tasks.Task and System.Threading.Tasks.Task objects now inherit the culture and UI culture of the calling thread, for apps that target the .NET Framework 4.6. The behavior of apps that target previous versions of the .NET Framework is unaffected. For more information, see the "Culture and task-based asynchronous operations” section of the System.Globalization.CultureInfo class topic.
Three convenience methods, CompletedTask, FromCancelled, and FromException, have been added to Task to return completed tasks in a particular state.
The NamedPipeClientStream class now supports asynchronous communication with its new ConnectAsync method.
Networking Enhancements
System.Net.Sockets
Windows 10 includes a new high-scalability networking algorithm that makes better use of machine resources by reusing local ports for outbound TCP connections. The .NET Framework 4.6 supports the new algorithm, enabling .NET apps to take advantage of the new behavior. In previous versions of Windows, there was an artificial concurrent connection limit (typically 16384), which could limit the scalability of a service by causing port exhaustion when under load.
In the .NET Framework 4.6, the System.Net.Sockets.SocketOptionName.ReuseUnicastPort enumeration value and the System.Net.ServicePointManager.ReusePort property, have been added to enable port reuse.
By default, the System.Net.ServicePointManager.ReusePort property is false unless the HWRPortResueOnSocketBind value of the HKLM\SOFTWARE\Microsoft.NETFramework\v4.0.30319 registry key is set to 0x1. To enable local port reuse on HTTP connections, set the System.Net.ServicePointManager.ReusePort property to true. This causes all outgoing TCP socket connections from System.Net.Http.HttpClient and System.Net.HttpWebRequest to use a new Windows 10 socket option, SO_REUSE_UNICASTPORT, that enables local port reuse.
Developers writing a sockets-only application can specify the System.Net.Sockets.SocketOptionName.ReuseUnicastPort option when calling a method such as System.Net.Sockets.Socket.SetSocketOption so that outbound sockets reuse local ports during binding.
System.Uri
A new property, System.Uri.IdnHost, has been added to the System.Uri class to better support international domain names and PunyCode.
CLR Assembly Loader Performance
The assembly loader now uses memory more efficiency by unloading IL assemblies after a corresponding NGEN image is loaded. This change is a major benefit for virtual memory for large 32-bit apps (such as Visual Studio) and also saves physical memory.
Cryptography Updates
The team is updating the System.Security.Cryptography APIs to support the Windows CNG cryptography APIs. To date, the .NET Framework has use an earlier version of Windows Cryptography APIs as the basis of the System.Security.Cryptography implementation. We have had requests to support the CNG API, since it supports modern cryptography algorithms, which are important for certain categories of apps.
The team made the following improvements:
- RSA Encryption: Added support for OAEP padding using the SHA-2 hash family.
- RSA Signing: Added support for PSS padding
- RSA usability: Improved API surface area.
- RSA usability: Added X509Certificate2.GetRSAPublicKey() and X509Certificate2.GetRSAPrivateKey(), they return null for non-RSA certificates, use a CNG based implementation when possible (which can use the new encryption and signing padding modes), or a CAPI based implementation when required (certain hardware RSA implementations (like smartcards)).
Unix Time
You can now more easily convert date and time values to or from .NET Framework types and Unix time. This can be necessary, for example, when converting time values between a JavaScript client and .NET server. The following APIs have been added to the DateTimeOffset structure:
- static DateTimeOffset FromUnixTimeSeconds(long seconds)
- static DateTimeOffset FromUnixTimeMilliseconds(long milliseconds)
- long DateTimeOffset.ToUnixTimeSeconds()
- long DateTimeOffset.ToUnixTimeMilliseconds()
EventSource now supports the Event Log
You now can use System.Diagnostics.Tracing.EventSource to log administrative or operational messages to the event log, in addition to any existing ETW sessions created on the machine. This is also called "ETW Channel support". In the past, you had to use the Microsoft.Diagnostics.Tracing.EventSource NuGet package for this functionality. The functionality is now built into the .NET Framework 4.6.
Both the NuGet package and the .NET Framework 4.6 have been updated with the following features:
- DynamicEvents - Allows events defined 'on the fly' by without creating a event method.
- RichPayloads - Allows specially attributed classes and arrays as well as primitive types to be passed as a payload.
- ActivityTracking - Causes Start and Stop events to tag events between them with ID that represents all currently active activities.
Compatibility Switches
AppContext is a new compatibility feature that enables library writers to provide a uniform opt-out mechanism for new functionality for their users. It established a loosley-coupled contract between components in order to communicate an opt-out request. This capability is typically important when a change is made to existing functionality. Conversely, there is already an implicit opt-in for new functionality.
With AppContext, libraries define and expose compatibility switches, while code that depends on them can set those switches, to affect the library behavior. By default libraries provide the new functionality and only alter it (e.g. provide the old behavior) if the switch is set.
An application (or a library) can declare the value (always boolean) of a switch that a dependent library defines. The switch is always implicity false
. Setting the switch to true
enables the switch. Explicity setting the switch to false
provides the new behavior.
AppContext.SetSwitch("Switch.AmazingLib.ThrowOnException”, true)
The library must check if a consumer has declared the value of the switch and then appropriately act on it.
It's beneficial to use a consistent format for switches, since they are a formal contract exposed by libraries. The following are two obvious formats.
- Switch.namespace.switchname
- Switch.library.switchname
This same infrastructure is used by the .NET Framework internally, to enable developers to opt out of updates to existing functionality.
Other Base Class Library changes
- A number of collection objects, such as System.Collections.Generic.Queue and System.Collections.Generic.Stack, now implement System.Collections.Generic.IReadOnlyCollection.
- The System.Globalization.CultureInfo.CurrentCulture and System.Globalization.CultureInfo.CurrentUICulture properties are now read-write rather than read-only. If you assign a new System.Globalization.CultureInfo object to these properties, the current thread culture defined by the Thread.CurrentThread.CurrentCulture property and the current UI thread culture defined by the Thread.CurrentThread,CurrentUICulture properties also change.
- The System.Numerics namespace now includes a number of SIMD-enabled types for scientific computing, such as System.Numerics.Matrix3x2, System.Numerics.Matrix4x4, System.Numerics.Plane, System.Numerics.Quaternion, System.Numerics.Vector2, System.Numerics.Vector3, and Vector4T:System.Numerics.Vector4.
Reference Source
The .NET Framework reference source has been updated for the .NET Framework 4.6. You can see the latest source at the .NET Framework Reference Source Website, which is also used for .NET Framework source debugging.
The .NET Framework referencesource repo on GitHub has also been updated with the latest update. This repo is primarily in place so that the Mono Project can adopt .NET Framework source in Mono.
ASP.NET 4.6
The ASP.NET team has made many updates to ASP.NET 4.6. You can learn more by reading the ASP.NET 4.6 RTM blog post or watch ASP.NET team member Pranav Rastogi describe the update. The release includes updates for the following components.
- ASP.NET Web Forms 4.6
- ASP.NET MVC 5.2.3
- ASP.NET Web Pages 3.2.3
- ASP.NET Web API 5.2.3
- ASP.NET SignalR 2.1.2
Async Model Binding for Web Forms
In the .NET Framework 4.5, Model Binding support was added to Web Forms. In the .NET Framework 4.6, we are adding support for Async Model Binding which allow you write Asynchronous Model Binding actions. The following code snippet shows a Web Forms page using Async Model Binding actions.
Identity and Authentication Updates
The ASP.NET 4.6 templates now use Open Id Connect middleware to authenticate to Azure Active Directory (Azure AD) which makes the programming model to authenticate with Azure AD much easier. Additionally, the templates will provide sample code for two-factor authentication and social logins with ASP.NET Identity 2.2.1 if you choose the ‘Individual User Accounts’ option when starting a new project.
HTTP/2 Support (Windows 10)
HTTP/2 support has been added to ASP.NET in the .NET Framework 4.6. New features were required in Windows, in IIS and in ASP.NET to enable HTTP/2 given that networking functionality exists at multiple layers. You must be running on Windows 10 to use HTTP/2 with ASP.NET. HTTP/2 has not yet been added to ASP.NET 5.
HTTP/2 is a new version of the HTTP protocol that provides much better connection utilization (fewer round-trips between client and server), resulting in lower latency web page loading for users. Web pages (as opposed to services) benefit the most from HTTP/2, since the protocol optimizes for multiple artifacts being requested as part of a single request.
The browser and the webserver (IIS on Windows) do all the work. You don't have to do any heavy-lifting for your users.
Most of the major browsers support HTTP/2, so it's likely that your users will benefit from HTTP/2 support.
Support for Token Binding Protocol
Microsoft and Google have been collaborating on a new approach to authentication, called the Token Binding Protocol. The premise of the protocol is that authentication tokens (in your browser cache) can be stolen and used by criminals to access otherwise secure resources (e.g. your bank account) without the requirement of your password or any other priviliged knowledge. The new protocol aims to mitigate this problem.
The Token Binding Protocol will be implemented in Windows 10, as a browser feature. ASP.NET apps will participate in the protocol, such that authentication tokens are validated to be legitimate. The client and the server implementations establish the end-to-end protection specified by the protocol.
Entity Framework
There are two versions of Entity Framework currently under development.
- EF 6.1.3 is recommended for production workloads. It contains fixes for high priority issues that were reported on EF 6.1.2.
- EF 7 introduces some significant changes and improvements over EF 6.x. In particular, it provides an implementation for .NET Core, including support for Linux, OS X and Windows. You can use it in ASP.NET 5 and UWP apps. Like EF 6.x, it is also supported on the .NET Framework. It is not yet supported in production workloads.
.NET Languages
The .NET languages team is releasing final updates to C# 6, F# 4.0 and VB 14 today. This includes final compiler implementations, and, for C# and VB, final language feature sets. The latest versions of the languages were actually feature complete at RC.
Roslyn v1
The team is also releasing the v1 version of Roslyn, after working on it for ~ 6 years. Roslyn was considered an ambitious project from the beginning. It aimed to replace the black box native C++ based C# and VB compilers with .NET implementations (written in both C# and VB) that exposed a rich set of language, compiler and other APIs. The Roslyn v1 product that you can use today in Visual Studio 2015 delivers on that vision and has enabled great new development experiences in Visual Studio.
For a historical grin, you can check out the earlier blog post, Introducing the Microsoft “Roslyn” CTP. It's fun to look back at more humble beginnings.
To learn more about Roslyn, check out the Roslyn repo and the Roslyn Overview.
C# 6 and VB 14
C# and VB are both part of the Roslyn compiler. You can see a comparison of Languages features in C# 6 and VB 14 to learn which feature is supported by which language.
The following language features are a subset of the new capabilities you can use in either language. Some of the other new language features are unique to one language or the other or existed already in one and were added to the other this release.
String interpolation: An intuitive String.Format-like syntax for composing strings from templates with inline expressions.
C#
var s = $"{p.Name} is {p.Age} year{{s}} old";
VB
Dim s = $"{p.Name} is {p.Age} year{{s}} old"
The Null-Conditional operator (?.): A streamlined syntax for conditionally accessing a member or invoking a method on a value if it's non-null and returning null if the object is null instead of throwing a NullReferenceException.
C#
int length = customers?.Length ?? 0; // 0 if customers is null
VB
Dim length As Integer=If(customers?.Length, 0) ' 0 if customers is null
The NameOf operator: A rename-safe way to refer to the name of a code element such as in PropertyChanged events and ArgumentExceptions.
C#
if (x == null) thrownew ArgumentNullException(nameof(x));
VB
If x IsNothingThenThrowNew ArgumentNullException(NameOf(x))
Read-only Auto-Properties: A concise syntax for declaring properties which may only be assigned in their initializers or inside of a constructor.
C#
publicclassCustomer
{publicstringFirst { get; } = "Jane";publicstringLast { get; } = "Doe";
}
VB
PublicClassCustomerPublicReadOnlyPropertyFirstAs String="Jane"PublicReadOnlyPropertyLastAs String="Doe"End Class
Static imports: New in C# 6! Enables a concise syntax for calling static methods without type qualification. This is handy for frequent calls to members of utility classes like System.Console
and System.Math
.
C#
usingstatic System.Console;usingstatic System.Math;usingstatic System.DayOfWeek;classProgram
{staticvoidMain()
{
WriteLine(Sqrt(3 * 3 + 4 * 4));
WriteLine(Friday - Monday);
}
}
This feature is new in C# 6 but already existed in previous versions of VB.
Imports System.ConsoleImports System.MathImports System.DateOfWeekModuleProgramSubMain()
WriteLine(Sqrt(3*3+4*4))
WriteLine(Friday - Monday) End SubEnd Module
Multiline string literals: New in VB 14! You can now include newline characters in string literals. This makes it easier than ever to include multiline content in your VB programs without having to manually concatenate vbCrLf
into strings.
VB
Dim s = "Write your haiku with
No vbCrLfIn VB14"
This feature is new in VB 14 but already existed in previous versions of C#.
var s = @"Write your haiku withNo \r\n escapesIn C# v1";
F# 4.0
F# 4.0 introduces a number of new language and runtime capabilities. Just a few are described below; see the F# team blog posts from the Preview and RC releases for a more complete list, or review the VS 2015 release notes.
Constructors as first-class function values Constructors can now be treated as first-class function values, similar to curried functions or other .NET methods. This eliminates the need to create small lambdas for the sole purpose of calling a constructor.
// old approachlet makeStringscharslens=
List.zip chars lens|> List.map (fun (char, len) ->new System.String(char, len))// new approachlet makeStrings' charslens=
List.zip chars lens|> List.map System.String // use ctor as function
makeStrings' ['a';'b';'c'][1;2;3]// ["a"; "bb"; "ccc"]
Simplified mutable values The mutable
keyword can now be used in all cases to create a mutable value. Scenarios where ref
values were previously required will be handled automatically by the compiler.
// old approach - need a `ref` valuelet sumSquaresn=let total = ref0
{ 1 .. n } |> Seq.iter (funi->
total := !total + i*i
)
!total// new approach - `mutable` just workslet sumSquares' n=letmutable total=0
{ 1 .. n } |> Seq.iter (funi->
total <- total + i*i
)
total
Implicit quotation of method arguments Method arguments now support the [
attribute, which enables access to both the passed argument value and a quotation of its callsite expression.
type Test =
static member EchoExpression([<ReflectedDefinition(true)>] x : Expr<_>) =let expression, value = (* decompose AST of x *)
printfn "%s evaluates to %O" expression valuelet x, y, z = 42, 89.0, 92.5
Test.EchoExpression(x) // "x evaluates to 42"
Test.EchExpression(Math.Max(y, z)) // "Math.Max(y, z) evaluates to 92.5"
Normalized collections API The List
, Array
, and Seq
modules have been expanded and fully normalized, with dedicated implementations of every API across all collection types. This represents the addition of 104 new APIs.
Visual Studio Improvements for .NET
Visual Studio 2015 includes major improvements for .NET.
Visual Studio Community
You can use the free Visual Studio 2015 Community edition. It is very similar to Visual Studio Pro and free for students, open source developers and many individual developers. It supports Visual Studio plugins like Xamarin or Resharper.
EnC - Lambda and Async Task support
Edit and Continue (EnC) is a popular productivity feature. It enables you to edit your code while you are debugging it. This is useful for a lot of reasons, particularly if your code needs to interact with state that isn't directly part of an API (e.g. processing JSON files) and can be most easily explored at runtime.
You can now use EnC with lambdas, async methods, LINQ and other language features. Given today's coding patterns, that's a huge jump forward for EnC usability. Check out Supported Edits in Edit & Continue (EnC) to see the complete set of EnC operations supported by EnC in Visual Studio 2015.
Here’s an example of some code that EnC didn’t support before. It is an async lambda that includes a LINQ statement. You can see how it was fixed up in the debugger, in the image below, to correctly query the string[] with "EnC" instead of "Enc" and change the message in the string[].
public MainWindow()
{
InitializeComponent();
Loaded += async (o, e) => {await Task.Delay(1000);
_strings = newstring[] { "EnC now supports more features!", "Thanks to Roslyn!"};
label.Content = (from str in _stringswhere str.StartsWith("Enc")select str).FirstOrDefault();
};
}
F# Script Debugging
F# scripts and F# Interactive are now integrated with the Visual Studio debugger. You can now take advantage of the rich Visual Studio debugging tools while working interactively.
WPF - Live Visual Tree
Visual Studio includes a new viewer and editor for the XAML Visual Tree - Live! - while debugging a WPF app. It enables you to navigate the visual tree as it exists at any point in the life cycle of your app. You can edit properties on the tree, for example button text, which are then displayed in the running app. You cannot change the composition of the tree.
You can also select visual components in the running app. These selections will update the Live Visual Tree in Visual Studio, enabling you to focus in on the parts of your app that might need investigation or updates.
The Live Visual Tree is also connected to the XAML source editing experience. As you select XAML nodes in the Live Visual Tree, the selected textual XAML in the IDE changes to match. You always know which text matches, making it easy to find the line of XAML to look at or change.
The following screenshot demonstrates the Live Visual Tree and an app that has a button selected with the new feature.
Application Timeline Tool
The Application Timeline tool, which is in "Start Diagnostic Tools Without Debugging…", shows you how much time your application spends in preparing UI frames and in servicing network and disk requests, and it does so in the context of scenarios such as Application Load. This scenario centric view of system resource consumption, enables you to inspect, diagnose, and improve the performance of your WPF applications. In addition, this tool along with the CPU Usage and Memory Usage tools are now available on Windows 7 as well.
Debugger Improvements
Visual Studio 2015 addresses many requests that you have made for improving your debugging life, such as lambda debugging, Edit and Continue (EnC) improvements, child-process debugging, as well as revamping core experiences such as powerful breakpoint configuration and introduces a new Exceptions Settings tool window.
We also pushed the state of the art by integrating performance tooling into the debugger with PerfTips and the all new Diagnostic Tools window which includes the redesigned IntelliTrace for historical debugging and the Memory Usage tool.
Xamarin Starter Included in Visual Studio 2015
Xamarin is a great way to start building iOS and Android apps in C# or F# within Visual Studio. Xamarin Starter Edition is now included as a free optional feature within Visual Studio 2015. Many .NET developers are using Xamarin to increase the reach of their apps and development effort to iOS and Android.
To install Xamarin with Visual Studio 2015, select the Custom installation option. Select the displayed checkbox below.
You can use Xamarin Starter edition as long as you want, build apps, test on devices and simulators and publish to app stores. It is limited to apps that are 128k of byte code or less. You can start a Xamarin Business trial to try out the richer experience. You can always return to Xamarin Starter Edition after that.
Xamarin.Forms for Windows
Xamarin.Forms support for the Windows platform has been updated to support Windows 8.1, and Windows Phone 8.1 apps. This means that you can build and ship Xamarin.Forms apps that target all of the major mobile platforms from a single code base.
Code Completion for Xamarin.Forms XAML
Declarative UI development in Visual Studio gets even more powerful with code completion for Xamarin.Forms. You can easily explore Xamarin.Forms user interface APIs, quickly build complex screens, and avoid typos and other common mistakes while creating UIs in XAML.
Xamarin + Visual C++ Debugger Integration
You can reference and debug native C++ libraries in a Xamarin.Android app. Just choose the Microsoft debugger in the project's property pages. Then, you can step through those libraries by using all of the debug features you know and love, including expression evaluation, watch window, and auto window.
.NET Core
.NET Core is a new version of .NET for modern device and cloud workloads. It is a general purpose and modular implemention that can be ported and used in many different environments for a variety of workloads. Microsoft is in the process of porting .NET Core to Linux and OS X.
The community is busy porting .NET Core to Free BSD and has recently started an ARM Linux port as well. The community is also quite active in the Linux x64 and OS X ports as well. The community engagement on the .NET Core project has been simply amazing, beyond our most dramatic expectations. Awesome work folks!
.NET Core supports the following workloads: ASP.NET 5, Windows 10 UWP and Console apps. We expect that other .NET Core workloads will appear in the future, from Microsoft and the community. We'd also love to see other companies build on top of .NET Core.
.NET Core is really three things: a cross-platform runtime implementation, a cross-platform framework library implementation and a standard API shape that can be satisfied by multiple .NET implementations (e.g. .NET Framework, .NET Core, Xamarin, Unity).
Today, you can use .NET Core within Visual Studio 2015, by using ASP.NET 5. The .NET tools for UWP, which also use .NET Core, ship on 7/29.
The .NET Core site is a great place to learn more about the product and to find out how to use it.
.NET Core FX
Today, the .NET Core Framework can be used in ASP.NET 5, Windows 10 UWP and .NET Core console apps. The .NET Core API started as the API for Windows 8 Store Apps. It has since grown, both in terms of APIs exposed and to also include other scenarios such as ASP.NET 5. Now, when we add new APIs to .NET Core, they are available for multiple app types. This approach makes better use of our engineering time and provides you with a consistent API right away.
The .NET Core Framework API, as a standard API shape, is also supported on the .NET Framework 4.5+. This means that you can write and share the same code for device, cloud and desktop apps without needing to use portable libraries, shared projects or other code sharing techniques. .NET has always offered low-level code portability as a fundamental tenet, and now has a uniform API that can be used in multiple app types.
All of the .NET Core libraries are distributed as NuGet packages. You can acquire the packages easily within Visual Studio or with one of the NuGet clients directly.
ASP.NET 5
ASP.NET 5 is the latest version of several ASP.NET technologies, include MVC and Web API. It supports running on both the .NET Framework and .NET Core, so by extension, supports running on Windows, Linux, OS X and any other .NET Core platforms. The ASP.NET Home repo is a great place to start learning about ASP.NET 5. You'll also find samples and getting started instructions in the same place.
The team recently shipped ASP.NET 5 beta 5, including a beta 5 of .NET Core. This is the version that is included in Visual Studio 2015. The team is shipping a beta 6 version later this month. You'll be able to install updated versions of ASP.NET 5 for use within Visual Studio 2015, as well as in other environments, such as VS Code and other OmniSharp-enabled text editors.
.NET Open Source
The RTM version of the .NET Framework and .NET Core now contain changes from people outside of the core .NET team in Microsoft but by passionate and highly skilled developers working with us in the coreclr and corefx repos on GitHub. The Roslyn compiler is the same, with the roslyn repo. Thanks for those contributions! We've had several customers ask us about our process for accepting product changes from community members. Also many companies (including Microsoft) have policies around open source software in their applications and these customers want to understand if they should now apply their open source policies to the .NET Framework, .NET Core and Roslyn.
The quick answer is that Microsoft continues to approach .NET Framework, .NET Core and Roslyn as high-quality commercial products, applies the same rigorous engineering practices to these products as we have traditionally used and make them available to you under the same license terms as we always have done in the past. We like to say that we've moved the location of our source control (to GitHub) and nothing else. As a result, you should continue to treat the versions of the .NET Framework, .NET Core and Roslyn, as distributed by Microsoft, as commercial products.
The longer answer is that .NET engineers (from Microsoft and also some highly skilled community members) perform a critical code review process to all contributios on the .NET Core and Roslyn GitHub repos regardless of if they have come from someone working on the .NET Team in Microsoft or someone outside the core team via a GitHub Pull Request. Each code reviewer has to be satisfied before they sign off, usually with a "LGTM" (looks good to me) or "LGTM, modulo my feedback" (I'll be happy after you've applied my feedback). A core committer (in this case also a Microsoft employee) has to be satisfied with the final state of the code and of the code review process, before merging it into the repo. The code review process can take a few hours or weeks, dependent on the change. Here are a few code reviews examples, so that you can see how the process works in practice: 1210, 2344, 3974. We also employ automated scans over the changes to find problems that visual code reviews have missed. We have found a small set of issues this way and fixed them.
All of the contributions to .NET Core, from both Microsoft and community members, are governed by the .NET Foundation Contributor License Agreement, which provides Microsoft (or any other party) the right to use them. When Microsoft distributes the .NET Framework, .NET Core and Roslyn, it is Microsoft commercial software, based on our traditional rigorous engineering process but with the added benefit of an open source and transparent code review process. The version distributed by Microsoft is based by the license terms you downloaded and accepted with that version (i.e. the EULA) and that version is supported, per Microsoft support agreements. If you build .NET Core or Roslyn from the source, then you are using the code under it's open source license and it is an open source component, not supported by Microsoft so any open source policies in your company would apply to it.
Summary
Today's releases of the .NET Framework 4.6 and Visual Studio 2015, and all the associated languages and components, provide major improvements to your development experience and the reliability and performance of your .NET apps. Please try out the new releases and tell us what you think.
A few of us on the team were reflecting on the release. There are some big milestones that are worth calling out, beyond having shipped a new version of the .NET Framework. These milestones do a good job of demonstrating Microsoft's investment in and commitment to .NET. Note that the .NET Native project is absent, since it isn't shipping today, but later this month.
- Roslyn shipped! Roslyn v1 was a 6 year language compiler project. It's now fully integrated into Visual Studio and is open source. It runs on the .NET Framework, .NET Core and Mono.
- RyuJIT shipped! RyuJIT v1 was a 5 year JIT compiler project. It's fully integrated into the .NET Framework and .NET Core and is also open source.
We've been talking publicly about these two releases for a long time, and have shared many updates along the way. Please join us in celebrating the v1 of these two projects. Don't think for a minute, however, that we are done our work on either project. The teams are already working on their next updates.
Thanks to everyone who gave us feedback on our various milestone releases for the .NET Framework, .NET Core, Roslyn, ASP.NET 5, Visual Studio and other releases. We very much appreciate it.