IanG on Tap

Ian Griffiths in Weblog Form (RSS 2.0)

Blog Navigation

April (2018)

(1 item)

August (2014)

(1 item)

July (2014)

(5 items)

April (2014)

(1 item)

March (2014)

(1 item)

January (2014)

(2 items)

November (2013)

(2 items)

July (2013)

(4 items)

April (2013)

(1 item)

February (2013)

(6 items)

September (2011)

(2 items)

November (2010)

(4 items)

September (2010)

(1 item)

August (2010)

(4 items)

July (2010)

(2 items)

September (2009)

(1 item)

June (2009)

(1 item)

April (2009)

(1 item)

November (2008)

(1 item)

October (2008)

(1 item)

September (2008)

(1 item)

July (2008)

(1 item)

June (2008)

(1 item)

May (2008)

(2 items)

April (2008)

(2 items)

March (2008)

(5 items)

January (2008)

(3 items)

December (2007)

(1 item)

November (2007)

(1 item)

October (2007)

(1 item)

September (2007)

(3 items)

August (2007)

(1 item)

July (2007)

(1 item)

June (2007)

(2 items)

May (2007)

(8 items)

April (2007)

(2 items)

March (2007)

(7 items)

February (2007)

(2 items)

January (2007)

(2 items)

November (2006)

(1 item)

October (2006)

(2 items)

September (2006)

(1 item)

June (2006)

(2 items)

May (2006)

(4 items)

April (2006)

(1 item)

March (2006)

(5 items)

January (2006)

(1 item)

December (2005)

(3 items)

November (2005)

(2 items)

October (2005)

(2 items)

September (2005)

(8 items)

August (2005)

(7 items)

June (2005)

(3 items)

May (2005)

(7 items)

April (2005)

(6 items)

March (2005)

(1 item)

February (2005)

(2 items)

January (2005)

(5 items)

December (2004)

(5 items)

November (2004)

(7 items)

October (2004)

(3 items)

September (2004)

(7 items)

August (2004)

(16 items)

July (2004)

(10 items)

June (2004)

(27 items)

May (2004)

(15 items)

April (2004)

(15 items)

March (2004)

(13 items)

February (2004)

(16 items)

January (2004)

(15 items)

Blog Home

RSS 2.0

Writing

Programming C# 5.0

Programming WPF

Other Sites

Interact Software

End in Sight for Side-by-Side CLR Versions

Tuesday 15 June, 2004, 03:35 PM

In a recent post on Wesner Moise's blog, you'll find the following rather remarkable snippet:

"In a break from the present scheme, Longhorn will no longer support multiple CLRs. Every managed application will be forced to use the latest version of the CLR on the system."

This is a rather substantial change from how things work today. However, it's not really all that surprising - after all, it's how Windows has worked for years. You can't have 5 different versions of kernel32.dll installed.

So does this mean that Microsoft have decided that the whole strongly-versioned assembly reference thing was a bad idea, and that we may as well give up and resign ourselves to DLL hell? No - this change in approach to versioning is intended just for the CLR itself, and it's more a statement that the platform versioning is different because it has to be. Current versions of the .NET Framework sit on top of the underlying Windows platform, but once the distinction between CLR and platform blurs with Longhorn, it will no longer make sense to talk about having two different .NET Framework versions hosted on top of the same Windows version. (No more than it would make sense to try and run multiple copies of kernel32.dll.)

It requires a massive commitment to backwards compatibility for this to be workable. And Microsoft have consistently demonstrated how seriously they take that commitment over the last couple of decades.

For the rest of us, the existing versioning semantics for non-platform components will continue to apply - we will not have to try and deliver the same level of backwards compatibility that Windows does.

Also, note that the scope of this "one version only" idea looks likely to be fairly narrow. Individual libraries shipped as part of the .NET Framework libraries are likely to carry on supporting independent versioning. It seems that only the core parts of the platform are going to be one version per machine.

Copyright © 2002-2025, Interact Software Ltd. Content by Ian Griffiths. Please direct all Web site inquiries to webmaster@interact-sw.co.uk