.NET Framework - .NET Framework

.NET Framework
.NET Logo.svg
Zásobník komponent .NET Framework
Zásobník komponent .NET Framework
VývojářiMicrosoft
První vydání14. února 2002; Před 18 lety (2002-02-14)
Konečné vydání
4.8.0 Sestavení 3928 / 25. července 2019; Před 16 měsíci (2019-07-25)[1]
Operační systémWindows 98 nebo později, Windows NT 4.0 nebo později
TypSoftwarový rámec
LicenceSmíšený; vidět § Licencování
webová stránkawww. Microsoft.com/síť Upravte to na Wikidata

.NET Framework (vyslovuje se jako „tečkovaná síť ") je softwarový rámec vyvinutý uživatelem Microsoft který běží primárně na Microsoft Windows. Zahrnuje velkou třídní knihovna volala Knihovna rámcových tříd (FCL) a poskytuje jazyková interoperabilita (každý jazyk může používat kód napsaný v jiných jazycích) napříč několika programovací jazyky. Programy napsané pro .NET Framework se spouštějí v a software prostředí (na rozdíl od a Hardware prostředí) s názvem Common Language Runtime (CLR). CLR je aplikační virtuální stroj který poskytuje služby, jako je bezpečnost, správa paměti, a zpracování výjimek. Počítačový kód napsaný pomocí .NET Framework se jako takový nazývá „spravovaný kód ". FCL a CLR společně tvoří .NET Framework.

FCL poskytuje uživatelské rozhraní, přístup k datům, připojení k databázi, kryptografie, webová aplikace vývoj, číselné algoritmy, a síťová komunikace. Programátoři vyrábějí software kombinací svých zdrojový kód s .NET Framework a dalšími knihovnami. Rámec je určen k použití ve většině nových aplikací vytvořených pro platformu Windows. Microsoft také vyrábí integrované vývojové prostředí pro .NET software s názvem Vizuální studio.

.NET Framework začal jako proprietární software, ačkoli firma pracovala standardizovat softwarový zásobník téměř okamžitě, ještě před jeho prvním vydáním. Navzdory snahám o standardizaci vývojáři, zejména ti v bezplatný open source software komunity vyjádřily znepokojení nad vybranými podmínkami a vyhlídkami na jakoukoli bezplatnou a otevřenou implementaci, zejména pokud jde o softwarové patenty. Od té doby společnost Microsoft změnila vývoj .NET, aby více sledovala současný model komunitního softwarového projektu, včetně vydání aktualizace svého patentu, která slibuje řešení těchto problémů.[2]

V dubnu 2019 společnost Microsoft vydala .NET Framework 4.8, poslední verzi rámce jako proprietární nabídku. Od té doby byly vydány pouze měsíční opravy chyb zabezpečení a spolehlivosti této verze. Žádné další změny této verze nejsou plánovány.[3]

V listopadu 2020 společnost Microsoft vydala .SÍŤ 5.0, open-source framework, který nahrazuje funkčnost .NET Framework. Poskytuje nativní podporu pro více platforem včetně Linux a Operační Systém Mac, a řeší problémy patentu související s .NET Framework.[4]

Dějiny

Microsoft začal vyvíjet .NET Framework na konci 90. let, původně pod názvem Windows Generation Services (NGWS), jako součást Strategie .NET. Koncem roku 2000 byly vydány první beta verze .NET 1.0.

V srpnu 2000 Microsoft, a Intel pracoval na standardizaci Společná jazyková infrastruktura (CLI) a C#. V prosinci 2001 byly obě ratifikovány Ecma International (ECMA).[5][6] Mezinárodní organizace pro normalizaci (ISO) následoval v dubnu 2003. Aktuální verzí norem ISO jsou ISO / IEC 23271: 2012 a ISO / IEC 23270: 2006.[7][8]

Zatímco Microsoft a jeho partneři vlastní patenty pro CLI a C #, ECMA a ISO vyžadují, aby všechny patenty nezbytné pro implementaci byly dostupné pod „přiměřené a nediskriminační podmínky ". Společnosti se dohodly na splnění těchto podmínek a na zpřístupnění patentů bez licenčních poplatků. To však neplatilo pro část .NET Framework, na kterou se nevztahují standardy ECMA-ISO, která zahrnovala Windows Forms, ADO.NET, a ASP.NET. Patenty, které společnost Microsoft drží v těchto oblastech, mohly odradit implementace plného rámce od jiných společností než Microsoft.[9]

Dne 3. Října 2007 společnost Microsoft oznámila, že zdrojový kód pro knihovny .NET Framework 3.5 mělo být dostupné pod Licence Microsoft Reference Source (Ms-RSL[A]).[10] Úložiště zdrojového kódu bylo k dispozici online 16. ledna 2008 a zahrnovalo BCL, ASP.NET, ADO.NET, Windows Forms, WPF a XML. Scott Guthrie společnosti Microsoft slíbil, že se přidávají knihovny LINQ, WCF a WF.[11]

The .NET Compact Framework a .NET Micro Framework varianty .NET Framework poskytovaly podporu pro další platformy Microsoft, jako např Windows Mobile, Windows CE a další vložená zařízení s omezeným zdrojem. Silverlight poskytl podporu pro internetové prohlížeče prostřednictvím zásuvných modulů.

Logo Microsoft .NET Framework v4.5

12. listopadu 2014 společnost Microsoft oznámila .NET Core, ve snaze zahrnout podporu pro různé platformy pro .NET, včetně Linux a macOS, zdroj pro implementaci .NET Core CoreCLR, zdroj pro „celý […] knihovní zásobník“ pro .NET Core a přijetí konvenčního („bazaru“) model vývoje open-source pod útěchou správcovství .NET Foundation. Miguel de Icaza popisuje .NET Core jako „přepracovanou verzi .NET, která je založena na zjednodušené verzi knihoven tříd“,[12] a Microsoft Immo Landwerth vysvětlili, že .NET Core bude „základem všech budoucích platforem .NET“. V době oznámení bylo počáteční vydání projektu .NET Core naočkováno podmnožinou zdrojového kódu knihoven a shodovalo se s opětovným vydáním existujícího referenčního zdroje .NET společnosti Microsoft mimo omezení Ms-RSL. Landwerth uznal nevýhody dříve vybrané sdílené licence s vysvětlením, že to dělalo kódové označení Rotor „nespouštěč“ jako komunitní open source projekt, protože nesplňoval kritéria Open Source Initiative (OSI) schválená licence.[13][14][15]

V listopadu 2014 společnost Microsoft také vytvořila aktualizaci svých patentových grantů, která dále rozšiřuje rozsah nad rámec jejích dřívějších závazků. Předchozí projekty jako Mono existoval v legálním šedá oblast protože dřívější granty společnosti Microsoft se vztahovaly pouze na technologii v „zahrnutých specifikacích“, včetně striktně 4. vydání ECMA-334 a ECMA-335. Nový patentový příslib však neklade žádný strop na specifikační verzi a rozšiřuje se dokonce na všechny runtime technologie .NET dokumentované na MSDN, které nebyly formálně specifikovány skupinou ECMA, pokud se projekt rozhodne je implementovat. To umožňuje Mono a dalším projektům udržovat paritu funkcí s moderními funkcemi .NET, které byly zavedeny od vydání 4. vydání, aniž by při implementaci těchto funkcí hrozilo riziko soudních sporů o patent. Nový grant zachovává omezení, že jakákoli implementace musí udržovat minimální soulad s povinnými částmi specifikace CLI.[16]

Dne 31. března 2016 společnost Microsoft oznámila na Microsoft Build že budou úplně relikvie Mono pod Licence MIT dokonce i ve scénářích, kdy byla dříve nutná komerční licence.[17] Společnost Microsoft také doplnila svůj předchozí patentový příslib pro společnost Mono tím, že nebude uplatňovat žádné „příslušné patenty“ proti stranám, které „používají, prodávají, nabízejí k prodeji, dovážejí nebo distribuují Mono“.[18][19] Bylo oznámeno, že projekt Mono byl přidán do .NET Foundation. Tento vývoj následoval po akvizici společnosti Xamarin, která začala v únoru 2016 a byla dokončena 18. března 2016.[20]

Tisková zpráva společnosti Microsoft zdůrazňuje, že závazek napříč platformami nyní umožňuje plně otevřený a moderní server .NET na straně serveru. Společnost Microsoft vydala 4. prosince 2018 zdrojový kód pro WPF, Windows Forms a WinUI.[21]

Architektura

Vizuální přehled Common Language Infrastructure (CLI)

Společná jazyková infrastruktura

Common Language Infrastructure (CLI) provides a language-neutral platform for application development and execution. Implementací základních aspektů .NET Framework v rámci CLI nebudou tyto funkce svázány s jedním jazykem, ale budou k dispozici v mnoha jazycích podporovaných frameworkem.

Common Language Runtime

.NET Framework obsahuje modul Common Language Runtime (CLR). Slouží jako spouštěcí modul .NET Framework a nabízí mnoho služeb, jako je správa paměti, bezpečnost typu, zpracování výjimek, odvoz odpadu, bezpečnost a správa vláken. Všechny programy napsané pro .NET Framework provádí CLR.

Programy napsané pro .NET Framework jsou kompilovány do Společný kód mezilehlého jazyka (CIL), na rozdíl od přímého kompilace do strojový kód. Během provádění specifická pro architekturu kompilátor just-in-time (JIT) otočí Kód CIL do strojového kódu.

S přesunem společnosti Microsoft na .NET Core, CLI Virtuální spouštěcí systém Implementace (VES) je známá jako CoreCLR místo CLR.

Shromáždění

Zkompilovaný CIL kód je uložen v Sestavy CLI. Jak je stanoveno ve specifikaci, sestavy jsou uloženy v Přenosný spustitelný soubor (PE), běžný na platformě Windows pro všechny dynamická knihovna (DLL) a spustitelný EXE soubory. Každá sestava se skládá z jednoho nebo více souborů, z nichž jeden musí obsahovat manifest nesoucí metadata pro montáž. Úplný název sestavení (nezaměňujte s názvem souboru na disku) obsahuje jeho jednoduchý textový název, číslo verze, jazykovou verzi a veřejný klíč žeton. Sestavy jsou považovány za rovnocenné, pokud sdílejí stejný úplný název.

Soukromý klíč může také použít tvůrce sestavení pro silné pojmenování. Token veřejného klíče identifikuje, se kterým soukromým klíčem je sestavení podepsáno. Pouze tvůrce páru klíčů (obvykle osoba podepisující sestavení) může podepisovat sestavení, která mají stejný silný název jako předchozí verze sestavení, protože tvůrce vlastní soukromý klíč. Pro přidání sestavení je nutné silné pojmenování Globální mezipaměť shromáždění.

Počínaje Visual Studio 2015 umožňuje technologie .NET Native compilation kompilaci kódu .NET z Univerzální aplikace platformy Windows přímo do strojového kódu spíše než do kódu CIL, ale aplikace musí být napsána v C # nebo Visual Basic.NET.[22]

Knihovna tříd

.NET Framework zahrnuje implementaci základního CLI Standardní knihovny. Knihovna tříd .NET Framework (FCL) je uspořádána v hierarchii jmenné prostory. Většina vestavěných aplikační programovací rozhraní (API) jsou součástí obou Systém.* nebo Microsoft. * jmenné prostory. Tyto knihovny tříd implementují mnoho běžných funkcí, jako je čtení a zápis souborů, grafické vykreslování, interakce s databází a manipulace s dokumenty XML. Knihovny tříd jsou k dispozici pro všechny Jazyky kompatibilní s CLI. FCL implementuje CLI Knihovna základní třídy (BCL) a další knihovny tříd - některé jsou specifikovány pomocí CLI a jiné jsou specifické pro Microsoft.

BCL zahrnuje malou podmnožinu celé knihovny tříd a je základní sadou tříd, které slouží jako základní API CLR.[23] Pro .NET Framework se většina tříd považovaných za součást BCL nachází v mscorlib.dll, System.dll a System.Core.dll. Třídy BCL jsou k dispozici v .NET Framework i v jeho alternativních implementacích včetně .NET Compact Framework, Microsoft Silverlight, .NET Core a Mono.

FCL odkazuje na celou knihovnu tříd dodávanou s .NET Framework. Zahrnuje rozšířenou sadu knihoven, včetně BCL, Windows Forms, ASP.NET, a Windows Presentation Foundation (WPF), ale také rozšíření knihoven základních tříd ADO.NET, Jazyk integrovaný dotaz (LINQ), Windows Communication Foundation (WCF) a Workflow Foundation (WF). FCL má mnohem větší rozsah než standardní knihovny pro podobné jazyky C ++, a rozsahem srovnatelný s standardní knihovny Java.

Se zavedením alternativních implementací (např. Silverlight) představila společnost Microsoft koncept Portable Class Libraries (PCL), který umožňuje provozování náročné knihovny na více než jedné platformě. S dalším množením platforem .NET se přístup PCL nepodařilo škálovat (PCL jsou definované křižovatky povrchu API mezi dvěma nebo více platformami).[24] Jako další evoluční krok PCL byla .NET Standard Library vytvořena zpětně na základě System.Runtime.dll založené API nalezené v UWP a Silverlight. Nové platformy .NET se vyzývají k implementaci verze standardní knihovny, která jim umožní znovu použít existující knihovny třetích stran ke spuštění bez jejich nových verzí. Standardní knihovna .NET umožňuje nezávislý vývoj vrstev knihoven a modelů aplikací v architektuře .NET.[25]

NuGet je správce balíčků pro všechny platformy .NET. Používá se k načtení knihoven třetích stran do projektu .NET s globálním zdrojem knihoven na NuGet.org.[26] Soukromé kanály lze spravovat samostatně, např. Serverem sestavení nebo adresářem systému souborů.

S přesunem společnosti Microsoft na .NET Core, implementace základních tříd knihoven CLI je známá jako CoreFX místo FCL.

Modely aplikací

Na vrcholu knihoven tříd se k vytváření aplikací používá několik modelů aplikací. .NET Framework podporuje konzolu, Windows Forms, Windows Presentation Foundation, ASP.NET a ASP.NET Core aplikace ve výchozím nastavení. Jiné modely aplikací nabízejí alternativní implementace .NET Framework. Console, UWP a ASP.NET Core jsou k dispozici na .NET Core. Mono se používá k napájení Xamarin v modelech aplikací pro Android, iOS, a Operační Systém Mac. Retroaktivní architektonická definice modelů aplikací se objevila počátkem roku 2015 a byla také aplikována na předchozí technologie, jako jsou Windows Forms nebo WPF.

C ++ / CLI

Microsoft představil C ++ / CLI v Vizuální studio 2005, což je jazyk a prostředek kompilace Visual C ++ programy spouštěné v rámci .NET Framework. Některé části programu C ++ stále běží v nespravovaném Visual C ++ Runtime, zatímco speciálně upravené části jsou přeloženy do Kód CIL a běží s .NET Framework CLR.

Sestavení kompilovaná pomocí kompilátoru C ++ / CLI se nazývají sestavení ve smíšeném režimu, protože obsahují nativní a spravovaný kód ve stejné knihovně DLL.[27] Takové sestavy jsou složitější pro zpětnou analýzu, protože .NET dekompilátory jako .NET Reflector odhalit pouze spravovaný kód.

Princip návrhu

Interoperabilita

Protože počítačové systémy běžně vyžadují interakci mezi novějšími a staršími aplikacemi, poskytuje .NET Framework prostředky pro přístup k funkcím implementovaným v novějších a starších programech, které se spouštějí mimo prostředí .NET. Přístup k Komponentní objektový model Součásti (COM) jsou poskytovány v System.Runtime.InteropServices a System.EnterpriseServices jmenné prostory rámce. Přístup k dalším funkcím je přes Služby vyvolání platformy (P / Vyvolání). Přístup k funkcím .NET z nativních aplikací je prostřednictvím funkce zpětného P / Invoke.

Jazyková nezávislost

.NET Framework zavádí a Společný typ systému (CTS), který definuje vše možné typy dat a programování konstrukce podporované CLR a jak mohou nebo nemusí interagovat v souladu se specifikací CLI. Z důvodu této funkce podporuje .NET Framework výměnu typů a instancí objektů mezi knihovnami a aplikacemi napsanými pomocí jakýkoli vyhovující jazyk .NET.

Typ bezpečnosti

CTS a CLR použité v .NET Framework také vynucují bezpečnost typu. To zabrání špatně definovanému přetypování, nesprávnému vyvolání metody a problémům s velikostí paměti při přístupu k objektu. To také dělá většinu jazyků CLI staticky napsané (s odvozením typu nebo bez něj). Počínaje .NET Framework 4.0 však Dynamic Language Runtime rozšířil CLR a umožnil implementaci dynamicky psaných jazyků na vrcholu CLI.

Přenosnost

Zatímco společnost Microsoft nikdy neimplementovala celý rámec na žádném systému kromě systému Microsoft Windows, vytvořila rámec jako platformu,[28] a implementace jsou k dispozici pro jiné operační systémy (viz Silverlight a § Alternativní implementace ). Microsoft předložil specifikace pro CLI (který zahrnuje knihovny základních tříd, CTS a CIL),[29][30][31] C#,[32] a C ++ / CLI[33] oběma Ecma International (ECMA) a Mezinárodní organizace pro normalizaci (ISO), čímž jsou k dispozici jako oficiální standardy. To umožňuje třetím stranám vytvářet kompatibilní implementace rámce a jeho jazyků na jiných platformách.

Bezpečnostní

.NET Framework má svůj vlastní bezpečnostní mechanismus se dvěma obecnými funkcemi: Zabezpečení přístupu k kódu (CAS) a ověření a ověření. CAS je založen na důkazech, které jsou spojeny s konkrétním sestavením. Důkazy jsou obvykle zdrojem sestavy (ať už je nainstalována na místním počítači nebo byla stažena z Internetu). CAS používá důkazy k určení oprávnění udělených kódu. Jiný kód může požadovat, aby volacímu kódu bylo uděleno zadané oprávnění. Požadavek způsobí, že CLR provede procházení zásobníku volání: u každé sestavy každé metody v zásobníku volání je zkontrolováno požadované oprávnění; pokud libovolné sestavení není uděleno oprávnění, je vyvolána výjimka zabezpečení.

Podařilo se CIL bytecode je snadnější zpětný inženýr než nativní kód, pokud zmatený.[34] .SÍŤ dekompilátor Programy umožňují vývojářům, kteří nemají dovednosti v oblasti reverzního inženýrství, zobrazit zdrojový kód za unobfuskovanými sestaveními .NET. Naproti tomu aplikace zkompilované do nativního strojového kódu je mnohem obtížnější zpětně analyzovat a zdrojový kód se téměř nikdy neprodukuje úspěšně, hlavně kvůli optimalizacím kompilátoru a nedostatku odraz.[35] To vytváří v podnikatelské komunitě obavy z možné ztráty obchodní tajemství a obcházení mechanismů kontroly licencí. Abychom to zmírnili, Microsoft zahrnul Dotfuscator Komunitní vydání s Visual Studio .NET od roku 2002.[b] Nástroje zamlžování třetích stran jsou k dispozici také od prodejců, jako jsou VMware, V.i. Laboratoře, Turbo, a Software Red Gate. Šifrovací nástroje na úrovni metody pro kód .NET jsou k dispozici od prodejců, jako je SafeNet.

Správa paměti

CLR osvobozuje vývojáře od zátěže správy paměti (přidělení a uvolnění po dokončení); zpracovává samotnou správu paměti detekcí, kdy lze paměť bezpečně uvolnit. Instance typu .NET (objekty) jsou přidělovány ze spravované haldy; fond paměti spravovaný CLR. Dokud existuje odkaz na objekt, který může být buď přímý, nebo prostřednictvím a graf objektů, je objekt považován za používaný. Pokud neexistuje žádný odkaz na objekt a nelze jej dosáhnout ani použít, stane se z něj odpad, vhodný pro sběr.

.NET Framework obsahuje a Popelář (GC), který běží pravidelně, na samostatném vlákno z vlákna aplikace, které vyčíslí všechny nepoužitelné objekty a uvolní jim přidělenou paměť. Je to nedeterministické, označit a zamést Popelář. GC běží pouze v případě, že bylo použito určité množství paměti nebo je v systému dostatečný tlak na paměť. Vzhledem k tomu, že není zaručeno, kdy je dosaženo podmínek pro získání paměti, běhy GC jsou nedeterministický. Každá aplikace .NET má sadu kořenů, které jsou ukazateli na objekty na spravované haldě (spravované objekty). Patří mezi ně odkazy na statické objekty, objekty definované jako lokální proměnné nebo parametry metody aktuálně v oboru a objekty, na které odkazují registry CPU.[36] Při spuštění GC pozastaví aplikaci a poté ji pro každý objekt uvedený v kořenovém adresáři rekurzivně vyjmenuje všechny objekty dosažitelné z kořenových objektů a označí je jako dosažitelné. Používá metadata CLI a odraz objevit objekty zapouzdřené objektem a poté je rekurzivně projít. Potom vytvoří výčet všech objektů na haldě (které byly původně přiděleny souvisle) pomocí reflexe. Všechny objekty, které nejsou označeny jako dosažitelné, jsou odpadky.[36] To je označit fáze.[37] Vzhledem k tomu, že paměť uchovávaná odpadky nemá žádný důsledek, považuje se za volné místo. To však ponechává kusy volného prostoru mezi objekty, které byly původně sousedící. Předměty jsou tedy zhutněný společně, aby volné místo na spravované hromadě bylo opět souvislé.[36][37] Jakýkoli odkaz na objekt zneplatněný přesunutím objektu je aktualizován GC tak, aby odrážel nové umístění.[37] Po ukončení uvolňování paměti je aplikace obnovena. Nejnovější verze rozhraní .NET framework používá souběžné uvolňování paměti spolu s uživatelským kódem, takže pauzy jsou nepozorovatelné, protože se to děje na pozadí.[38]

Sběrač odpadků používaný .NET Framework je také generační.[39] Objekty jsou přiřazeny a generace. Nově vytvořené objekty jsou označeny Generace 0. Objekty, které přežijí jedno uvolnění paměti, jsou označeny Generace 1. Objekty 1. generace, které přežijí další sbírku, jsou Generace 2. Rámec používá až objekty 2. generace.[39] Objekty vyšší generace jsou odpadky shromažďovány méně často než objekty nižší generace. To zvyšuje efektivitu uvolňování paměti, protože starší objekty mají tendenci mít delší životnost než novější objekty.[39] Ignorováním starších objektů ve většině běhů sběru je celkově zapotřebí méně kontrol a operací zhutnění.[39]

Výkon

Při prvním spuštění aplikace .NET Framework zkompiluje Kód CIL do spustitelného kódu pomocí jeho kompilátor just-in-time a ukládá spustitelný program do mezipaměti .NET Native Image.[40][41] Z důvodu ukládání do mezipaměti se aplikace spouští rychleji pro další spuštění, ačkoli první spuštění je obvykle pomalejší. Pro urychlení prvního spuštění mohou vývojáři použít Nativní generátor obrázků nástroj ručně kompilace předem a ukládat do mezipaměti libovolnou aplikaci .NET.[41]

Garbage collector, který je integrován do prostředí, může zavést neočekávané zpoždění provádění, nad nimiž má vývojář malou přímou kontrolu. „Ve velkých aplikacích může být počet objektů, se kterými musí sběrač odpadků pracovat, velmi velký, což znamená, že jejich návštěva a uspořádání všech může trvat velmi dlouho.“[42]

.NET Framework poskytuje podporu pro volání Streamování rozšíření SIMD (SSE) prostřednictvím spravovaný kód od dubna 2014 ve Visual Studio 2013 Update 2. Nicméně, Mono poskytuje podporu pro SIMD Rozšíření od verze 2.2 v rámci oboru názvů Mono.Simd v roce 2009.[43] Mono vedoucí vývojář Miguel de Icaza vyjádřil naději, že tato podpora SIMD bude přijata standardem ECR společnosti CLR.[44] Streamovací rozšíření SIMD jsou k dispozici v x86 CPU od zavedení Pentium III. Některé další architektury jako např PAŽE a MIPS mají také rozšíření SIMD. V případě, že CPU nemá podporu těchto rozšíření, jsou pokyny simulovány v softwaru.[Citace je zapotřebí ]

Alternativní implementace

.NET Framework je převládající implementací technologií .NET. Pro části rámce existují další implementace. Přestože je modul runtime popsán specifikací ECMA-ISO, může být zatěžován jinými jeho implementacemi patent problémy; Normy ISO mohou obsahovat odmítnutí odpovědnosti: „Je třeba upozornit na možnost, že některé prvky tohoto dokumentu mohou být předmětem patentových práv. ISO nenese odpovědnost za identifikaci jakéhokoli nebo všech takových patentových práv.“[45] Je těžší vyvinout alternativy k FCL, která není popsána otevřeným standardem a může podléhat omezením autorských práv. Části FCL mají také funkce a chování specifické pro Windows, takže implementace na platformách jiných než Windows může být problematická.

Zde jsou uvedeny některé alternativní implementace částí rámce.

  • .NET Micro Framework je platforma .NET pro zařízení s extrémně omezenými prostředky. Zahrnuje malou verzi CLR a podporuje vývoj v C# (ačkoli někteří vývojáři byli schopni použít VB.NET,[46] i když s množstvím hackerství a s omezenými funkcemi) a ladění (v emulátoru nebo na hardwaru), obojí pomocí Microsoft Visual Studio. Obsahuje také podmnožinu knihovny tříd .NET Framework (přibližně 70 tříd s přibližně 420 metodami), a GUI framework volně založený na WPF a další knihovny specifické pro vložené aplikace.
  • Mono je implementací CLI a FCL a poskytuje přidané funkce. to je s dvojí licencí tak jako volný, uvolnit a proprietární software. Zahrnuje podporu knihoven ASP.NET, ADO.NET a Windows Forms pro širokou škálu architektur a operačních systémů. Zahrnuje také kompilátory C # a VB.NET.
  • Portable.NET (část DotGNU ) poskytuje implementaci CLI, částí FCL a kompilátoru C #. Podporuje různé CPU a operační systémy. Projekt byl ukončen s posledním stabilním vydáním v roce 2009.
  • Microsoft Sdílená infrastruktura Common Language Infrastructure je nesvobodný implementace CLR. Poslední verze však běží pouze na Windows XP SP2 a od roku 2006 nebyla aktualizována. Proto neobsahuje všechny funkce verze 2.0 .NET Framework.
  • CrossNet[47] je implementace CLI a částí FCL. Je to svobodný software využívající otevřený zdroj Licence MIT.

Licencování

Licencované rámce spravovaného kódu Microsoft a jejich součásti jsou následující:

SoučástkaLicence
.NET Framework (redistribuovatelný balíček)Proprietární software[48]
Odkaz zdrojový kód .NET Framework 4.5 a staršíReferenční licence Microsoft (Ms-RSL[A])[10][49]
Referenční zdrojový kód .NET Framework 4.6Licence MIT[50]
MonoLicence MIT[51]
.SÍŤ (dříve .NET Core)
CoreFX, CoreCLR a CLI
Licence MIT[52]
.NET Micro FrameworkLicence Apache 2.0[53]
Platforma .NET Compiler (kódové označení „Roslyn“)Licence MIT[54]
ASP.NET MVC, Web API a webové stránky (Břitva )Licence Apache 2.0[55]
ASP.NET CoreLicence Apache 2.0[56]
Sada nástrojů ASP.NET Ajax Control ToolkitLicence BSD[57]
SignalR technologie ASP.NETLicence Apache 2.0[58]
Rámec entitLicence Apache 2.0[59]
NuGetLicence Apache 2.0[60]

Viz také

Poznámky

  1. ^ A b Licence byla dříve zkrácena na Ms-RL, ale Ms-RL nyní odkazuje na Reciproční licence Microsoft.
  2. ^ Dotfuscator Community Edition 4.0

Reference

  1. ^ „Stáhnout .NET Framework 4.8 Offline Installer“. Microsoft.
  2. ^ „Microsoft vstupuje na trh s otevřeným zdrojovým kódem“. Opensource.com. 19. listopadu 2014. Citováno 2. ledna 2020.
  3. ^ gewarren. „Verze .NET Framework a Windows OS“. docs.microsoft.com. Citováno 21. listopadu 2020.
  4. ^ „Announcing .NET 5.0“. .NET Blog. 10. listopadu 2020. Citováno 21. listopadu 2020.
  5. ^ „Standard ECMA-335: Common Language Infrastructure (CLI)“. ecma-international.org (6. vyd.). ECMA. Červen 2012.
  6. ^ „Standard ECMA-334: C # Language Specification“. ecma-international.org (4. vyd.). ECMA. Červen 2006.
  7. ^ „ISO / IEC 23271: 2012 Informační technologie - Common Language Infrastructure“. iso.org (3. vyd.). Mezinárodní organizace pro normalizaci. 13. února 2012.
  8. ^ „ISO / IEC 23270: 2006 - Informační technologie - Programovací jazyky - C #“. iso.org (2. vyd.). Mezinárodní organizace pro normalizaci. 26. ledna 2012.
  9. ^ „Prázdný slib společnosti Microsoft“. Free Software Foundation. 16. července 2009. Archivováno z původního 19. srpna 2009. Citováno 3. srpna 2009. Existuje však několik knihoven, které jsou součástí Mono a běžně používané aplikacemi jako Tomboy, které standard nevyžaduje. A aby bylo jasno, nemluvíme o knihovnách specifických pro Windows, jako je ASP.NET a Windows Forms. Místo toho mluvíme o knihovnách v oboru názvů systému, které poskytují běžné funkce, které programátoři očekávají v moderních programovacích jazycích
  10. ^ A b Guthrie, Scott (3. října 2007). „Uvolnění zdrojového kódu pro NET Framework“. Blog Scotta Guthrieho. Microsoft. Archivováno od originálu 7. září 2010. Citováno 15. září 2010.
  11. ^ Guthrie, Scott (16. ledna 2008). „Zdrojový kód knihovny .NET Framework je nyní k dispozici“. Blog Scotta Guthrieho. Microsoft. Citováno 28. února 2015.
  12. ^ de Icaza, Miguel. „Microsoft Open Sources .NET a Mono“. Osobní blog Miguela de Icaza. Citováno 16. listopadu 2014.
  13. ^ Landwerth, Immo (12. listopadu 2014). „.NET Core je otevřený zdroj“. Blog .NET Framework. Microsoft. Citováno 30. prosince 2014.
  14. ^ „dotnet / corefx“. GitHub. Citováno 16. listopadu 2014.
  15. ^ „Microsoft / referenceource“. GitHub. Citováno 16. listopadu 2014.
  16. ^ „Microsoft Patent Promise for .NET Libraries and Runtime Components“. Citováno 16. listopadu 2014.
  17. ^ Krill, Paul (1. dubna 2016). „Xamarinův Mono runtime získá volnější licenci“. InfoWorld. IDG.
  18. ^ Ferraira, Bruno (31. března 2016). „Xamarin je nyní zdarma s Visual Studio“. Technická zpráva.
  19. ^ „Microsoft Patent Promise for Mono“. Mono na GitHubu. Mono projekt. 28. března 2016. Archivováno z původního dne 16. dubna 2016. Citováno 16. dubna 2016.
  20. ^ „Xamarin pro každého“. Blog Xamarin. Xamarin. 31. března 2016. Archivovány od originál 12. dubna 2016. Citováno 12. dubna 2016.
  21. ^ „Oznamování otevřeného zdroje WPF, Windows Forms a WinUI na Microsoft Connect 2018“. Blog vývojářů Windows. Microsoft. Archivovány od originál dne 15. prosince 2018. Citováno 24. prosince 2018.
  22. ^ rpetrusha. „Kompilace aplikací s nativním .NET“. docs.microsoft.com.
  23. ^ "Knihovna základní třídy". Citováno 1. června 2008.
  24. ^ „.NET Platform Standard“. Citováno 23. dubna 2016.
  25. ^ „Aktualizace na ASP.NET Core 1.0 RC2“. Citováno 23. dubna 2016.
  26. ^ „Galerie NuGet - Domů“. nuget.org.
  27. ^ Smíšené (nativní a spravované) sestavy, MSDN
  28. ^ „Scott Guthrie: Silverlight and Cross-Platform CLR“. Kanál 9. 30.dubna 2007. Archivováno z původního dne 25. března 2015. Citováno 16. dubna 2016.
  29. ^ „ECMA 335 - Standard ECMA-335 Common Language Infrastructure (CLI) 4th edition (June 2006)“. ECMA. 1. června 2006. Archivovány od originál dne 14. června 2008. Citováno 1. června 2008.
  30. ^ „ISO / IEC 23271: 2006“. Standards.iso.org. 29. září 2006. Citováno 17. dubna 2012.
  31. ^ „Technical Report TR / 84 Common Language Infrastructure (CLI) - Information Derived from Partition IV XML File“. ECMA. 1. června 2006. Archivováno z původního dne 25. března 2015. Citováno 16. dubna 2016.
  32. ^ „Specifikace jazyka ECMA-334 C #“. ECMA. 1. června 2006.
  33. ^ „Standardní specifikace jazyka ECMA-372 C ++ / CLI“. ECMA. 1. prosince 2005. Archivovány od originál 10. srpna 2008. Citováno 16. ledna 2008.
  34. ^ Gartner, Inc., jak uvádí „Hype Cycle for Cyberthreats, 2006“, září 2006, Neil MacDonald; Amrit Williams a kol.
  35. ^ Cifuentes, Cristina (červenec 1994). "6: Analýza toku řízení". Techniky reverzní kompilace (PDF) (Teze). Queensland University of Technology. Archivovány od originál (PDF) dne 22. listopadu 2016.
  36. ^ A b C „Garbage Collection: Automatická správa paměti v rozhraní Microsoft .NET Framework“. Archivovány od originál 3. července 2007. Citováno 1. června 2008.
  37. ^ A b C „Odpadky v .NET“. Archivovány od originál dne 25. května 2008. Citováno 1. června 2008.
  38. ^ „.NET Framework 4.5 obsahuje nová vylepšení uvolňování paměti pro klientské a serverové aplikace“. Citováno 2. října 2015.
  39. ^ A b C d „Garbage Collection - Část 2: Automatická správa paměti v rozhraní Microsoft .NET Framework“. Archivovány od originál 26. června 2007. Citováno 1. června 2008.
  40. ^ „Porozumění kompilaci .NET Just-In-Time“. telerik.com. 28. května 2013.
  41. ^ A b Kompilace MSIL do nativního kódu, MSDN, Microsoft
  42. ^ „Porozumění uvolňování paměti v .NET“. 17. června 2009.
  43. ^ „Poznámky k vydání Mono 2.2 - Mono“. mono-project.com.
  44. ^ „Mono's SIMD Support: Making Mono safe for Gaming“. Tirania.org. 3. listopadu 2008. Citováno 17. dubna 2012.
  45. ^ ISO 9001: 2008, Předmluva
  46. ^ "Používání VB.NET s .NET Micro Framework« / dev / mobile ". Christec.co.nz. 1. dubna 2008. Citováno 17. dubna 2012.
  47. ^ „CrossNet“. Codeplex.com. Citováno 17. dubna 2012.
  48. ^ „Microsoft .NET Framework Redistributable EULA“. MSDN. Microsoft. Citováno 28. února 2015.
  49. ^ Bray, Brandon (15. srpna 2012). „Oznamujeme vydání .NET Framework 4.5 RTM - produktový a zdrojový kód“. Blog .NET Framework. Microsoft.
  50. ^ „Announcing .NET 2015 Preview: a New Era for .NET“. Blog .NET Framework. Microsoft. 12. listopadu 2014.
  51. ^ „Xamarin pro každého“. Blog Xamarin. Microsoft. 17. dubna 2016.
  52. ^ „.NET Core 5“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.
  53. ^ „.NET Micro Framework“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.
  54. ^ „Roslynská licence“. GitHub. .NET Foundation. 5. února 2020. Citováno 14. dubna 2018.
  55. ^ „ASP.NET MVC, webové rozhraní API a webové stránky (Razor)“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.
  56. ^ „Základní licence ASP.NET“. GitHub. .NET Foundation. 5. července 2017. Citováno 14. dubna 2018.
  57. ^ „Sada nástrojů ASP.NET Ajax Control Toolkit“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.
  58. ^ „SignalR technologie ASP.NET“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.
  59. ^ „Entity Framework“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 18. dubna 2016. Citováno 16. dubna 2016.
  60. ^ „NuGet“. dotnetfoundation.org. .NET Foundation. Archivovány od originál dne 17. února 2015. Citováno 17. února 2015.

externí odkazy