52

I want to know what exactly is the difference between CLR & CLI? From whatever I have read so far, it seems to indicate that CLI is a subset of CLR. But isn't everything in the CLR mandatory? What exactly may be left out of CLR to create a CLI?

Litisqe Kumar
  • 2,240
  • 4
  • 23
  • 38
Naveen
  • 69,046
  • 43
  • 164
  • 225

6 Answers6

76

The CLR is Microsoft's implementation of the CLI standard.

Serafina Brocious
  • 29,643
  • 11
  • 85
  • 111
  • 4
    It does that too, you just have to set the target architecture to 'liquid'. – Serafina Brocious Jan 26 '09 at 18:11
  • 1
    Thanks for the quick answer. So this means at least theoretically we can have a third party implementation of the CLI which can run on different OS and support .NET components similar to JVM? – Naveen Jan 26 '09 at 18:18
  • 1
    @Naveen - take a look at mono which is exactly that. – Kev Jan 26 '09 at 18:22
  • 1
    According to this http://stackoverflow.com/questions/9321803/does-mono-implement-clr-or-at-least-some-unmanaged-internalcall-or-nothing That claims that Mono implements the CLR. Is that wrong and is it more correct to say Mono implements the CLI, not the CLR? – barlop Jul 20 '14 at 14:11
  • this answer is not really correct... CLR is the implementation of the VES... see the answer below – adjan Jun 06 '17 at 13:40
52

CLR is the execution environment in which a .NET application is safely hosted/run.

You can see it as .NET's private Operating System that initiates and loads just before a .NET application starts.

The CLR takes care of certain essential requirements of any .NET application that otherwise would require lot of deliberate code to be written in order to implement; requirements that are holistic in nature and essential to any kind of application to run in a good, efficient and safe manner [e.g. Handle memory allocation and release it when not required, avoid dangling pointers, avoid type-casting errors etc. ]

CLI on the other hand is a specification/set of guidelines that explains how to implement an application execution environment and the nature of generated application code that allows for multiple high-level languages to be used on different computer platforms without being rewritten for specific architectures.

CLI is developed by Microsoft and standardized by ISO and ECMA.

The CLR is a practical implementation of CLI's VES [Virtual Execution System] section and forms one of the core components of the MS.NET platform

In a layman's language, CLI is a recipe while CLR is the cuisine :-)

Rahul Bhatnagar
  • 567
  • 4
  • 6
  • Note that this says the same thing as Cody Brocious's answer except with some explanation. It is a matter of opinion how much value the explanation provides. References to .Net might not be accurate; it is my understanding that .Net implements more than the CLI standard. – user34660 Nov 14 '17 at 19:30
16

The CLR (Common Language Runtime) is Microsoft's implementation of the VES (Virtual Execution System). The VES along with the CTS (Common Type System), the CLS (common language specification) and the metadata specification are all part of the CLI (Common Language Infrastructure) specification.

The VES is a standardized virtual machine specification that must be implemented in order to load and execute CIL (Common Intermediate Language) modules (dll and exe). A VES implementation also provide runtime services such as garbage collection and security.

ECMA C# and Common Language Infrastructure Standards

xtrem
  • 1,587
  • 11
  • 13
0

CLR is the .net execution environment where all kind of .net applications are run.For instance, when you write your code with C# or another language from the dot NET stack the compiler compiles and converts it into managed module. A managed module is IL (intermediate language) and metadata.Above all, the important point to remember is that whenever you compile your source code, the compiler translates it into managed module. To clarify, this is not a machine code that your processor will execute.In fact, IL is an intermediate language close to assembly language.Similarly, it is also famous as object orientated machine language.

Check this article about more detailed explanation:

http://alevryustemov.com/programming/common-language-runtime/

Alev Ryustemov
  • 143
  • 1
  • 8
-1

As answered, CLR is microsoft implementation. The component itself is called C++/CLI in Visual Studio installer but once it's installed, it shows up as CLR.

You can got to add remove programs >> Visual Studio 2009, modify installation and add or remove C++/CLI. It is listed like that as shown in screenshot below but again once installed, the project type is called CLR in visual studio.

enter image description here

zar
  • 9,241
  • 10
  • 74
  • 145
-2

CLR is the complete environment in which CLI ,CTS,CLS works in integration it also incluse garbage collection,memory management ,security,intemediate language for native code... CLI is a specification for the format of executable code, and the runtime environment that can execute that code.

maddy
  • 1