What is .NET Core? Birth of the .NET Framework

What is .NET Core? Released in 2001, the .NET framework made it easier for developers to create applications on the internet. However, the need for faster and more simple deployment (among others) drove the need to develop a more modular system. Its .NET Core, released in June 2016, is a modular and smaller implementation of .NET that is designed to be cross-platform and open source, and it’s optimized for cloud-specific workloads. In this post, we’ll look at the evolution of the .NET framework and family and the developments that have paved the way for .NET Core.

What is .NET Core? Birth of the .NET Framework

To answer the question: What is .NET Core? we need to go back to 1996. If we dial back some 20 years to that year 1996, here’s what was happening in tech. Java had just been announced a few months before. The internet was five years old. With initial server side development and active pages with CGI, JavaScript was experimenting what dynamic pages on the client meant. It was also the time of Intel 486 processor-based PCs with 4Mb of RAM and 400Mb in the hard drive.

At the time, Microsoft was just starting the first browser war on the Windows desktop, Apple was waiting for the return of Steve Jobs and Linux, like the web, was just five years old. Microsoft was focused on a developer experience based mostly on Visual Basic 6.0, and was looking for the successor of COM technology. They also purchased a Java Virtual Machine from a little company called Colusa in order to have a technology that could keep up with Java’s promising features.

In 2001, Microsoft released the .NET Framework in version 1.0. It served as a framework for using multiple languages, from legacy Visual Basic to the new (at the time) C#, to develop on mainly two application models: desktop and web. These applications implemented the “drag & drop” development philosophy that was desirable at the time.
dotnet010001
Since then, the .NET Framework has evolved and grown, and many new versions have been released. By 2012, it was time for something a little more innovative.

What is .NET Core? Meeting future requirements

Since the .NET Framework was released, a lot of things have happened in the IT world that have shaped the need for a new development framework.
dotnet010002

  • The Microsoft ecosystem. The Windows family of operating systems has it market share, most notably in the enterprise market. However, internet companies are born with Linux, and for the desktop, MacOS is adopted for its simplicity. Microsoft is a developer’s company and it wants to bring its tools to other platforms.
  • Open Source. These days, requirements, experience, comparison, and inspiration all come from the community. The community of users and developers make an important contribution of feedback in terms of ideas and for code.
  • Mono. The first open source implementation of the standard Common Language Infrastructure specifications – ECMA – and ISO has become a common framework for some important application models such as Unity and Xamarin.
  • New Architecture. Intel x64 architecture dominates the cloud, server, and desktop market. With the advent of smartphones and tablets, ARM architecture has become dominant with millions of processors and devices sold. The Internet of Things event has increased the phenomenon by putting ARM processors on many connected devices, connecting billions of devices to the Internet.
  • Languages and Tools. In recent years, new or revamped languages have inspired new ways to code or to manage coding. First and foremost, the JavaScript ecosystem that started as a little language written more than 20 years ago and used to animate HTML pages has become one of the most widely adopted languages worldwide. All the tools that have been born around it (NPM, V8, Node.js) have become the de-facto standard in writing server applications.
  • New deployment models. Twenty years ago, we were investing in statically and strongly typed, object-oriented languages to guarantee code and application quality. This is no longer valid, as applications have increased their complexity. Today, we talk about Application Lifecycle Management as a guarantee for code quality. Source Code Management, Continuous Integration, Continuous Delivery, Automated testing, Containerization, Docker, and Microservices are all first requirements when developing a solution. Therefore, we need a tool that can simplify this approach.
  • Command Line. As its name implies, Windows has always been a graphical user interface for simplifying the approach to ordinary tasks that should be executed quickly and easily. Unix and Linux have always inspired the adoption of the command line as the most powerful and flexible way to handle DevOps tasks.
  • Breaking changes. Microsoft is experienced in supporting retro-compatibility with legacy applications. However, legacy can prevent pushing performance and new functionalities to extremes. This is what we need today.
  • Cloud. For us at Cloud Academy, the most inspiring scenario is the possibility of developing services to be executed in the cloud. The cloud brings all these topics together: Performance, portability, openness, architectures, languages, operations. For Microsoft, the cloud represents the center of its new strategy for being a cloud-first company.

A new member of the .NET Family

.NET Core means many things. .NET Full (and to be more precise, the current version that is .NET 2015, or 4.6.2) is Windows specific, and only a subset of it is portable. In this way, “core” emphasizes what is core and portable between the platforms.

“Core” needed to be different from .NET so that it could meet the needs of different platforms. There are some breaking changes that do not allow bringing code from .NET without modifications. And, there are possibilities that you can’t go back. And, we can’t bring a legacy Windows concept on Linux or Mac.

As a member of the .NET family, .NET Core can also embrace Mono, as Microsoft has acquired Xamarin. It is quite unlikely that Microsoft would move that code base from Mono to .NET.

What is .NET core and what does it mean to be part of the .NET family?

Being a .NET Framework means implementing:

  • Common Language Runtime (CLR): Services common for all language implementers (Type System, language features like inheritance, generics, interfaces, and overloading for object-oriented programming). Also, Async Programming, Threading, Structured Exception Handling, Attributes, Garbage Collection, Delegates).
  • Intermediate Language (IL): The generated code from each language compiler.
  • Common Language Specifications (CLS): Rules for interoperability among languages.
  • Base Class Library: A set of types (System.Object, System.Int32, System.String, System.IO.*, …) common to the .NET family.
  • Framework: The implementation of all of these elements.

.NET Core is another .NET framework with other members like .NET 2015 and Mono with Xamarin (4.6.1.5).
dotnet010003
So, what is .NET Core? It’s a modular and smaller implementation of .NET that is designed to be cross-platform and open source to meet the next 10 years of software development. It is optimized for cloud-specific workloads and implements these specific application models:

  • Console applications (worker roles)
  • NET Core (web roles)

There is also a Universal Windows Platform for store applications and devices. This scenario is still under development and we’ll see its potential in the near future.

.NET Standard

One issue that .NET Core is trying to solve is libraries. The three mentioned stacks are three separate stacks, which creates several problems:

  • The two new implementations are codebase fork.
  • If a new implementation is needed, you would most likely need to reimplement them on each platform.
  • With different ship cycles (e.g., Windows for .NET Framework) they will align at different times.

There are also issues for developers:

  • Key APIs are not present on all platforms.
  • Different implementations on each platform.
  • Need to target a small common denominator to reuse code.
  • Need to master 3 base class libraries.

To address these issues, Microsoft came up with a single library solution.
dotnet010004
Starting from the current experience with Portable Class Libraries which are used to solve portability issues among Windows, Silverlight, and Windows Phone apps, the common functionalities have been selected and classified. It has been implemented in a set of reference assemblies that are binary compatible with all platforms. This means that they need to be implemented once for the defined standard. The standard can evolve over time and different platforms can implement different standards.
dotnet010005
All reference libraries are downloadable as nugget packages, identified by a moniker that is an alias to the target platform and the version supported (ex. «netstandard1.6»). This mechanism can support either a standard scenario that is necessary for portability and vertical scenarios where we need to refer to a particular platform that has some specifically required functionalities. The referenced libraries are installed side by side into the application project so it can be compiled and packaged.

The application is complete, but it cannot be executed because the full implementation is missing.
dotnet010006
In fact, the full implementation is inside the framework that is installed on the specific machine where the application is run. Every released framework adheres to some platform and standard. In case of “netstandard1.x”, every framework that implements it can run any application built with the platform independently from the Operating System.
dotnet010007
Every supported platform is now listed and identified with a Runtime Identifier – RID. Inside the .NET Core project you can target specific platforms so that the build system can understand at compile time whether all functionalities are supported for the required platforms.

Breaking Changes and project migration

If you’re already a .NET developer, here is a list of major breaking changes that have been introduced. This is important to know if you’re evaluating costs for a possible migration:

  • No AppDomains (Infrastructure exists but it is no longer usable in terms of API. There is a new AppContext object and AssemblyLoadContext to dynamically load assemblies.)
  • No Remoting
  • No Binary Serialization
  • No Code Access Security (CAS)
  • No Global Assembly Cache
  • Anything Windows-specific (registry, ACLs, perf counters, etc.)
  • All assemblies are deployed privately
  • An assembly for each namespace (no more mscorelib.dll)

In .NET Core, the following application models are no longer supported:

  • WPF
  • Winforms
  • WebForms

To be continued…

In future posts, we will dive into more details (running the dotnet.exe CLI, introducing ASP.NET Core apps) to help you understand whether .NET Core is right for you.

For now, we can say that .NET Core has inherited all the good aspects that .NET has implemented in the last 20 years. And, it has been rewritten to be updated with all the modern challenges that the cloud now requires. You can implement applications in a mature, evolved, high-performance environment for statically typed, strongly typed languages like C#. With this language, we can target Windows and Linux for building cloud workloads, and we can develop on Windows, Linux, and Mac OS.

If you want to learn more about Microsoft’s cloud and technology offerings, visit our Training Library.

Avatar

Written by

Marco Parenzan

Marco Parenzan is a Research Lead for Microsoft Azure in Cloud Academy. He has been awarded three times as a Microsoft MVP on Microsoft Azure. He is a speaker in major community events in Italy about Azure and .NET development and he is a community lead for 1nn0va, an official Microsoft community in Pordenone, Italy. He has written a book on Azure in 2016. He loves IoT and retrogaming.


Related Posts

Nisar Ahmad
Nisar Ahmad
— November 12, 2019

Kubernetes Services: AWS vs. Azure vs. Google Cloud

Kubernetes is a popular open-source container orchestration platform that allows us to deploy and manage multi-container applications at scale. Businesses are rapidly adopting this revolutionary technology to modernize their applications. Cloud service providers — such as Amazon Web Ser...

Read more
  • AWS
  • Azure
  • Google Cloud
  • Kubernetes
Alisha Reyes
Alisha Reyes
— November 6, 2019

New on Cloud Academy: AZ-900 Exam Update; MS-100 Exam Prep; PRINCE2 Foundation; Azure, Kubernetes, and Google Hands-on Labs; and Much More

This month, our Content Team really kicked it into overdrive with tons of new content. If you're Team Azure, then you'll be amazed at the number of Azure Courses and Hands-on Labs we published this month alone!  At any time, you can find all of our new releases by going to our Training ...

Read more
  • AZ-900
  • Azure
  • Google Cloud Platform
  • Kubernetes
  • MS-100
  • New content
  • PRINCE2
  • Product Feature
Joe Nemer
Joe Nemer
— October 30, 2019

How to Get Hands-on Experience on AWS, Azure, and GCP: Lab Challenges

Meaningful cloud skills require more than book knowledge. Hands-on experience is required to translate knowledge into real-world results. We see this time and time again in studies about how kids and adults best learn — doing the actual learning task is key. Hands-on Labs and Lab Challe...

Read more
  • AWS Labs
  • Azure
  • Google Cloud Platform
  • Hands-on Labs
Avatar
Cloud Academy Team
— October 23, 2019

Which Certifications Should I Get?

As we mentioned in an earlier post, the old AWS slogan, “Cloud is the new normal” is indeed a reality today. Really, cloud has been the new normal for a while now and getting credentials has become an increasingly effective way to quickly showcase your abilities to recruiters and compan...

Read more
  • AWS
  • Azure
  • Certifications
  • Cloud Computing
  • Google Cloud Platform
Alisha Reyes
Alisha Reyes
— October 1, 2019

New on Cloud Academy: ITIL® 4, Microsoft 365 Tenant, Jenkins, TOGAF® 9.1, and more

At Cloud Academy, we're always striving to make improvements to our training platform. Based on your feedback, we released some new features to help make it easier for you to continue studying. These new features allow you to: Remove content from “Continue Studying” section Disc...

Read more
  • AWS
  • Azure
  • Google Cloud Platform
  • ITIL® 4
  • Jenkins
  • Microsoft 365 Tenant
  • New content
  • Product Feature
  • Python programming
  • TOGAF® 9.1
Avatar
Jeremy Cook
— September 17, 2019

Cloud Migration Risks & Benefits

If you’re like most businesses, you already have at least one workload running in the cloud. However, that doesn’t mean that cloud migration is right for everyone. While cloud environments are generally scalable, reliable, and highly available, those won’t be the only considerations dri...

Read more
  • AWS
  • Azure
  • Cloud Migration
Joe Nemer
Joe Nemer
— September 6, 2019

Google Cloud Functions vs. AWS Lambda: The Fight for Serverless Cloud Domination

Serverless computing: What is it and why is it important? A quick background The general concept of serverless computing was introduced to the market by Amazon Web Services (AWS) around 2014 with the release of AWS Lambda. As we know, cloud computing has made it possible for users to ...

Read more
  • AWS
  • Azure
  • Google Cloud Platform
Alisha Reyes
Alisha Reyes
— August 30, 2019

New on Cloud Academy: CISSP, AWS, Azure, & DevOps Labs, Python for Beginners, and more…

As Hurricane Dorian intensifies, it looks like Floridians across the entire state might have to hunker down for another big one. If you've gone through a hurricane, you know that preparing for one is no joke. You'll need a survival kit with plenty of water, flashlights, batteries, and n...

Read more
  • AWS
  • Azure
  • Google Cloud Platform
  • New content
  • Product Feature
  • Python programming
Alisha Reyes
Alisha Reyes
— August 22, 2019

How to Unlock Complimentary Access to Cloud Academy

Are you looking to get trained or certified on AWS, Azure, Google Cloud Platform, DevOps, Cloud Security, Python, Java, or another technical skill? Then you'll want to mark your calendars for August 23, 2019. Starting Friday at 12:00 a.m. PDT (3:00 a.m. EDT), Cloud Academy is offering c...

Read more
  • AWS
  • Azure
  • cloud academy content
  • complimentary access
  • GCP
  • on the house
Avatar
Andrew Larkin
— August 13, 2019

Content Roadmap: AZ-500, ITIL 4, MS-100, Google Cloud Associate Engineer, and More

Last month, Cloud Academy joined forces with QA, the UK’s largest B2B skills provider, and it put us in an excellent position to solve a massive skills gap problem. As a result of this collaboration, you will see our training library grow with additions from QA’s massive catalog of 500+...

Read more
  • AWS
  • Azure
  • content roadmap
  • Google Cloud Platform
Avatar
Andrew Larkin
— August 7, 2019

Disadvantages of Cloud Computing

If you want to deliver digital services of any kind, you’ll need to estimate all types of resources, not the least of which are CPU, memory, storage, and network connectivity. Which resources you choose for your delivery —  cloud-based or local — is up to you. But you’ll definitely want...

Read more
  • AWS
  • Azure
  • Cloud Computing
  • Google Cloud Platform
Orion Withrow
Orion Withrow
— July 24, 2019

How to Effectively Use Azure Management Groups, Subscriptions, and Resource Groups

When used individually, Azure Management Groups, Subscriptions, and Resource Groups are very powerful. But when used together, they can establish the entire organizational structure of Azure. In this article, I will explain Azure Resource Manager, Management Groups, Subscriptions an...

Read more
  • Azure
  • azure management groups
  • azure resource groups
  • azure subscriptions