Windows Runtime - Windows Runtime

Windows Runtime
Ostatní jménaWinRT
VývojářiMicrosoft
Operační systémMicrosoft Windows
PředchůdceWin32 API
TypAplikační programovací rozhraní
webová stránkamsdn. Microsoft.com/ cs-USA/Okna/ aplikace/ Upravte to na Wikidata

Windows Runtime (WinRT) je platformně-agnostická aplikační architektura, která byla poprvé představena v Windows 8 a Windows Server 2012 v roce 2012. WinRT podporuje vývoj v C ++ / WinRT (standardní C ++), C ++ / CX (Component Extensions, jazyk založený na C ++ ), Rust / WinRT, JavaScript -Strojopis a spravovaný kód jazyky C# a Visual Basic .NET (VB.NET). Aplikace WinRT nativně podporují oba x86 a PAŽE procesory a mohou běžet uvnitř a pískoviště prostředí umožňující větší bezpečnost a stabilitu.[1][2] Součásti WinRT jsou navrženy s ohledem na interoperabilitu mezi více jazyky a API, včetně nativních, spravovaných a skriptovacích jazyků.

Windows Phone 8.1 používá verzi Windows Runtime s názvem Windows Phone Runtime. Umožňuje vývoj aplikací v C # a VB.NET a komponenty Windows Runtime v C ++ / CX.[3]

Technologie

WinRT je implementován v programovacím jazyce C ++[4] a je objektově orientovaný podle návrhu.[4] Jeho základní technologie, Windows API (Win32 API), je psán většinou v jazyce C.[5] Je to nespravovaný kód aplikační programovací rozhraní (API) na základě Komponentní objektový model (COM), který umožňuje propojení z více jazyků, stejně jako COM. Definice API jsou však uloženy v .winmd soubory, které jsou zakódovány do Metadata ECMA 335 formát, který .NET Framework také používá s několika úpravami.[6][7][nespolehlivý zdroj? ] Tento běžný formát metadat umožňuje výrazně menší režii při vyvolání WinRT z aplikací .NET, relativně k P / Vyvolání a mnohem jednodušší syntaxe.[8][nespolehlivý zdroj? ]

Nové C ++ / CX (Component Extensions) jazyk, který si některé vypůjčuje C ++ / CLI syntaxe, byla zavedena pro psaní a konzumaci komponent WinRT s méně kód lepidla viditelné pro programátora, ve srovnání s klasickým programováním COM v C ++, a ukládá méně omezení v porovnání s C ++ / CLI pro typy míchání. Komponentní rozšíření C ++ / CX se doporučují používat pouze na rozhraní API, nikoli pro jiné účely.[9] K programování s komponentami WinRT lze také použít běžný C ++ (s disciplínou specifickou pro COM),[10] s pomocí knihovny Windows Runtime C ++ Template Library (WRL), která má podobný účel jako co Knihovna aktivních šablon stanoví COM.[11] V roce 2019 Microsoft zastaral C ++ / CX ve prospěch C ++ / WinRT knihovna záhlaví.[12]

Aplikace WinRT běží v izolovaném prostoru a pro přístup k důležitým funkcím operačního systému a základnímu hardwaru vyžadují výslovný souhlas uživatele. Ve výchozím nastavení je přístup k souborům omezen na několik předem určených umístění, například do adresářů Dokumenty nebo Obrázky.[13]

Aplikace WinRT pro Windows RT, Windows 8 a novější jsou baleny v .appx formát souboru; na základě Otevřete konvence o balení, používá a Formát ZIP s přidanými soubory XML.[14] Aplikace WinRT jsou distribuovány většinou prostřednictvím obchod s aplikacemi pojmenovaný Microsoft Store, kde je software WinRT (nazývaný Aplikace Windows Store) si uživatelé mohou stáhnout a zakoupit. Aplikace WinRT mohou být pouze naloženo z prostředí mimo Windows Store v systémech Windows 8 nebo RT, které jsou součástí a Windows doména, nebo vybaven speciálním aktivačním klíčem získaným od společnosti Microsoft.[15][16][17][18]

V zásadním odchodu z Win32 a podobně do .NET Framework 4.5, většina API, u nichž se očekává, že jejich dokončení bude trvat značný čas, je implementována jako asynchronní. Aplikace odešle volání rozhraní API, které se okamžitě vrátí, což aplikaci uvolní provádění dalších úkolů při čekání na výsledky.[19] Asynchronní model vyžaduje nové konstrukce programovacího jazyka (klíčové slovo asynchronní a operátor čekat v C # a Visual Basic, třída úkol a metoda .pak v C ++, které poskytuje WinRT sada pro vývoj softwaru (SDK), třída Slib a metoda .pak v JavaScriptu-HTML5), podobně jako Snaž se/chytit použito v zpracování výjimek. Části API vyžadující asynchronní přístup zahrnují zprávy a dialogy na obrazovce, přístup k souborům, připojení k internetu, zásuvky, streamy, zařízení a služby a kalendář, kontakty a schůzky.

Služby

Metadata

Metadata popisují kód napsaný pro platformu WinRT. Definuje a programovací model což umožňuje psát objektově orientovaný kód, který lze sdílet napříč programovací jazyky a umožňuje služby jako odraz.

Herb Sutter, C ++ expert ve společnosti Microsoft, vysvětlil během svého zasedání o C ++ v roce 2011 Vytvořte konferenci že metadata WinRT jsou ve stejném formátu jako Metadata CLI.[9] Nativní kód (tj. Strojově specifický strojový kód) nemůže obsahovat metadata, takže je uložen v samostatných souborech WINMD, které lze odrážet jako běžné Sestavy CLI.[20]

Protože se jedná o metadata CLI, lze kód napsaný v nativních jazycích WinRT použít ze spravovaného Jazyky CLI.

Typový systém

WinRT má bohaté objektově orientovaný třída -na základě typový systém která je postavena na metadatech. Podporuje konstrukce s odpovídajícími konstrukcemi v rozhraní .NET: třídy, metody, vlastnosti, delegáti, a Události.

Jedním z hlavních přírůstků WinRT ve srovnání s COM je křížovýbinární rozhraní aplikace (ABI), .NET generika. V C ++ / CX jsou deklarovány pomocí klíčového slova obecný se syntaxí velmi podobnou syntaxi klíčového slova šablona. Třídy WinRT (třídy ref) lze také zobecnit pomocí šablon C ++, ale pouze instance šablon lze exportovat do metadat .winmd (s některými zmanipulované jméno ), na rozdíl od generik WinRT, které zachovávají svou obecnost v metadatech. WinRT také poskytuje obecnou knihovnu kontejnery že paralela ti v Standardní knihovna C ++ a některé funkce vzájemného převodu (tam a zpět). Spotřeba kolekcí WinRT v jazycích .NET (např. C # a VB) a v JavaScriptu je transparentnější než v C ++, přičemž v zákulisí dochází k automatickému mapování na jejich přirozené ekvivalenty. Při vytváření komponenty WinRT ve spravovaném jazyce je třeba dodržovat některá další pravidla ve stylu COM, např. Typy kolekce .NET framework nelze deklarovat jako návratové typy, ale na hranici komponenty lze použít pouze rozhraní WinRT, která implementují.

Komponenty WinRT

Jsou volány třídy, které jsou kompilovány tak, aby cílily na WinRT Komponenty WinRT. Jsou to třídy, které lze psát v jakémkoli podporovaném jazyce a pro jakoukoli podporovanou platformu. Klíčem jsou metadata. Tato metadata umožňují rozhraní s komponentou z jakéhokoli jiného jazyka WinRT. Modul runtime vyžaduje komponenty WinRT, které jsou vytvořeny pomocí .NET Framework, aby používaly definované typy rozhraní nebo rozhraní typu .NET, které se automaticky mapují na první pojmenované. Ve spravovaných součástech WinRT dosud není podporována dědičnost, s výjimkou tříd XAML.[21]

Programovací rozhraní

Programy a knihovny cílené na běhové prostředí WinRT lze vytvářet a spotřebovávat z několika platforem a programovacích jazyků. Zejména C /C ++ (buď s jazykovými rozšířeními, které nabízejí prvotřídní podporu konceptů WinRT, nebo s knihovnou šablon nižší úrovně umožňující psát kód ve standardním C ++), .NET (C# a Visual Basic .NET (VB.NET)) a JavaScript. To umožňují metadata.

V terminologii WinRT, a jazyková vazba se nazývá a jazyková projekce.

C ++ (C ++ / WinRT, rozšíření komponent, WRL)

Nativní C ++ je a občan první třídy platformy WinRT. Od verze 10.0.17134.0 (Windows 10, verze 1803) obsahuje Windows SDK C ++ / WinRT. C ++ / WinRT je zcela standardní moderní projekce jazyka C ++ 17 pro API Windows Runtime (WinRT), implementovaná jako knihovna založená na hlavičkových souborech a navržená tak, aby poskytovala prvotřídní přístup k modernímu Windows API. S C ++ / WinRT lze Windows Runtime API vytvářet a využívat pomocí libovolného kompilátoru C ++ 17 vyhovujícího standardům. WinRT je nativní platforma a podporuje jakýkoli nativní (a standardní) kód C ++, takže vývojář v C ++ může znovu použít existující nativní knihovny C / C ++. S C ++ / WinRT neexistují žádná jazyková rozšíření.

Před oficiálním vydáním C ++ / WinRT v sadě Windows SDK, od října 2016,[22] Microsoft nabídl na GitHub C ++ / WinRT.[23] Nespoléhá se na kód C ++ / CX, což má za následek produkci menších binárních souborů a rychlejšího kódu.[24]

Existují dvě další možnosti pro použití WinRT z C ++: WRL, knihovna šablon ve stylu ATL a C ++ / CX (C ++ s rozšířením o komponenty), která se podobá C ++ / CLI.[25] Z důvodu požadavků na interní spotřebu v Microsoftu je WRL bez výjimek, což znamená, že jeho disciplína návratové hodnoty je HRESULT -založeno stejně jako u COM.[26] C ++ / CX na druhé straně shrnuje volání WinRT s kódem, který provádí kontrolu chyb a podle potřeby vyvolává výjimky.[27]

C ++ / CX má několik rozšíření, která umožňují integraci s platformou a jejím typovým systémem. Syntaxe se podobá syntaxi C ++ / CLI i když produkuje nativní (i když ne standardní) kód a metadata, která se integrují s modulem runtime. Například objekty WinRT mohou být přiděleny ref nový, který je protějškem gcnew z C ++ / CLI. Provozovatel klobouku ^ si zachovává svůj význam, avšak v případě, že volající i volaný jsou zapsáni v C ++ a žijí ve stejném procesu, je odkaz na klobouk jednoduše ukazatelem na vptr na a tabulka virtuálních metod (vtable, VMT).[27]

Spolu s C ++ / CX, vzhledem k tradičnímu programování C ++ COM, jsou dílčí třídy, opět inspirováno .NET. Ty umožňují instanci XAML kód, který má být nástrojem přeložen do kódu C ++, a poté zkombinován s kódem napsaným člověkem, aby se vytvořila úplná třída a zároveň bylo možné čisté oddělení strojově generovaných a člověkem upravených částí implementace třídy do různých souborů.

.SÍŤ

The .NET Framework a Common Language Runtime (CLR) jsou integrovány do WinRT jako subplatform. Ovlivnila a stanovila standardy pro ekosystém prostřednictvím formátu metadat a knihoven. CLR poskytuje služby jako JIT kompilace kód a odvoz odpadu. Aplikace WinRT využívající jazyky .NET používají nové Windows Runtime XAML Framework, a jsou primárně psány v C #, VB.NET a poprvé pro XAML s nativní kód pomocí C ++ / CX. I když to ještě není oficiálně podporováno, programy lze psát také v jiných jazycích .NET.

Omezení

Třídy definované v komponentách WinRT, které jsou integrovány ve spravovaných jazycích .NET, musí být deklarovány jako zapečetěný, takže z nich nelze odvodit. Nezapečetěné třídy WinRT definované jinde lze zdědit z .NET, přepsat jejich virtuální metody atd.; ale zděděná spravovaná třída musí být stále zapečetěna.

Členové, kteří komunikují s jiným jazykem, musí mít podpis s typy WinRT nebo spravovaným typem, který je na ně převoditelný.[21]

JavaScript

Aplikace WinRT lze také kódovat pomocí HTML s JavaScript v code-behind, které jsou spuštěny pomocí Trojzubec vykreslovací modul a Čakra JavaScriptový engine, který oba také používá internet Explorer. Při kódování aplikace WinRT v JavaScriptu jsou její funkce přizpůsobeny konvenci pojmenování JavaScriptu a obory názvů jsou také mapovány na objekty JavaScriptu.

Jiné jazyky

Microsoft je v procesu projektování API WinRT do jiných jazyků než C ++. Jedním z příkladů je Rust / WinRT, rozhraní pro programy napsané v Rez používat rozhraní WinRT API.[28] Rust / WinRT je součástí Project Reunion, snahy společnosti Microsoft sladit platformy Win32 a WinRT.[29]

Mosty

Se zavedením Univerzální platforma Windows (UWP), WinRT obdržela mnoho mostů API, které umožňují snadné portování programů původně kódovaných pro jiné jazyky, přičemž využívají výhod funkcí UWP. Společnost Microsoft poskytla mosty pro Android (zaniklý od roku 2016), iOS (Kakaový dotek ), Progresivní webové aplikace, Silverlight, stejně jako standardní desktopové aplikace založené na Win32 (pomocí balení MSIX od Project Reunion).

API

WinRT přichází s aplikační programovací rozhraní (API) ve formě a třídní knihovna který pro vývojáře odhaluje funkce systému Windows 8, jako je jeho pohlcující rozhraní API. Je přístupný a použitelný v jakémkoli podporovaném jazyce.

Runtime třídy

Třídy Windows Runtime jsou sady SDK, které poskytují přístup ke všem funkcím z XAML analyzátor funkce fotoaparátu. SDK jsou implementovány jako nativní C / C ++ knihovny (nespravované).

Konvence pojmenování

Konvence pojmenování pro komponenty (třídy a další členy) v API jsou silně ovlivněny konvencemi pojmenování .NET, které používají velbloudí pouzdro (konkrétně PascalCase). Společnost Microsoft doporučuje uživatelům dodržovat tato pravidla v případě, že nejsou uvedeny žádné další.

Tyto konvence se v některých jazycích promítají odlišně, například JavaScript, který jej převádí na své konvence a naopak. To znamená poskytnout nativní a konzistentní prostředí bez ohledu na programovací jazyk.

Omezení a pravidla

Vzhledem k tomu, že Windows Runtime je promítán do různých jazyků, existují určitá omezení základních datových typů, aby byly všechny tyto jazyky hostovány. Programátoři musí být opatrní při chování těchto typů při použití s ​​veřejným přístupem (pro parametry metody, návratové hodnoty metody, vlastnosti atd.).[30]

Základní typy
V jazycích .NET a C ++ existuje bohatá sada datových typů představující různé číslice.
V JavaScriptu, a Číslo může představovat až 53 bitů přesnosti.
Ve WinRT je jediným chybějícím číselným datovým typem 8bitové celé číslo se znaménkem ve vztahu k .NET a C ++. Vývojáři JavaScriptu musí být při kódování WinRT opatrní při práci s velkými čísly.
Struny
Řetězce jsou neměnné v .NET a JavaScriptu, ale proměnlivé v C ++.
Nulový ukazatel předaný jako řetězec do WinRT pomocí C ++ se převede na prázdný řetězec
V .Net je hodnota null předávaná jako řetězec do WinRT převedena na prázdný řetězec
V JavaScriptu je hodnota null předávaná jako řetězec do WinRT převedena na řetězec se slovem nula. Je to kvůli klíčovému slovu JavaScriptu nula být reprezentován jako nulový objekt. Podobné výsledky se vyskytují při průchodu nedefinováno do WinRT z JavaScriptu.
Struktury
V .NET a C ++ jsou struktury typy hodnot a taková struktura může obsahovat jakýkoli typ.
JavaScript přímo nepodporuje struktury.
Ve WinRT je použití struktur povoleno pouze pro obsahující typy, které mají sémantiku hodnot, včetně číslic, řetězců a dalších struktur. Ukazatele nebo odkazy na rozhraní jsou zakázány.
Reference
V .NET jsou objekty předávány odkazem, zatímco číslice a struktury jsou předávány podle hodnoty.
V C ++ lze všechny typy předat odkazem nebo hodnotou.
Ve WinRT jsou rozhraní předávána odkazem; všechny ostatní typy jsou předávány podle hodnoty.
Pole
V .NET, C ++ a JavaScript jsou pole referenčních typů.
Ve WinRT jsou pole hodnotovými typy.
Události
V .NET a C ++ se klienti přihlašují k odběru událostí pomocí += operátor.
V JavaScriptu addEventListener funkce nebo nastavení na vlastnost se používá k odběru událostí.
Ve WinRT mohou všechny jazyky používat svůj vlastní způsob přihlášení k odběru událostí.
Sbírky
Některé kolekce .NET se mapují přímo na kolekce WinRT.
WinRT Vektor typ se podobá polím a k jejich konzumaci se používá syntaxe pole.
WinRT Mapa type je kolekce párů klíč / hodnota a je projektována jako slovník v jazycích .NET.
Přetížení metody
Všechny jazyky WinRT (.NET, C ++, JavaScript) podporují přetížení parametrů
.NET a C ++ také podporují přetížení na typu.
Ve WinRT se pro přetížení používá pouze číslo parametru.
Asynchrony
Všechny metody WinRT jsou navrženy tak, že jakákoli metoda, která trvá déle než 50 milisekund, je asynchronní metodou.
Zavedený vzorec pojmenování pro rozlišení asynchronních metod je . Pro celou běhovou knihovnu jsou všechny metody, které mají šanci trvat déle než 50 ms, implementovány pouze jako asynchronní metody.

Historie verzí

Verze pro Windows
Windows 8Windows Runtime
Windows 8.1
Windows 10Univerzální platforma Windows (UWP)

Windows Phone Runtime

Začínající od Windows Phone 8 je možné vyvíjet aplikace pomocí verze Windows Runtime zvané Windows Phone Runtime (WPRT). Ačkoli WP8 přinesl omezenou podporu, platforma se nakonec sblížila Windows 8.1 v Windows Phone 8.1.

Windows Phone 8

Windows Phone 8 má omezenou podporu pro vývoj a spotřebu komponent Windows Runtime prostřednictvím Windows Phone Runtime. Mnoho rozhraní Windows Runtime API v systému Windows 8, které zpracovávají základní funkce operačního systému, bylo přeneseno na Windows Phone 8.[31] Byla přidána podpora pro vývoj nativních her pomocí C ++ / CX a DirectX na žádost odvětví vývoje her.

Windows Phone XAML Framework je však stále založen na stejném Microsoft Silverlight framework, jako ve Windows Phone 7, pro zpětnou kompatibilitu. Tedy od roku 2016, Vývoj XAML je v C ++ / CX nemožný. Vývoj pomocí HTML5 nebo WinJS není ve Windows Phone 8 podporován.

Windows Phone 8.1

Podpora Windows Runtime na Windows Phone 8.1 konverguje s Windows 8.1. Vydání přináší na platformu úplné rozhraní Windows Runtime API, včetně podpory pro Windows Runtime XAML Framework a jazykové vazby pro C ++ / CX, a HTML5 -JavaScript. Existuje také typ projektu s názvem Univerzální aplikace umožnit aplikacím sdílet kód ve verzích 8.1 Windows Phone a Windows.

Windows Phone 8 Silverlight Framework byl aktualizován.[když? ] Může využívat některé z nových funkcí v prostředí Windows Runtime.

Windows Phone Runtime používá AppX formát balíčku ze systému Windows 8, po předchozím použití Silverlight XAP.

Viz také

Reference

  1. ^ Avram, Abel (21. září 2011). „Detaily návrhu běhového prostředí Windows“. InfoQ.
  2. ^ Klug, Brian; Smith, Ryan (13. září 2011). „Microsoft Build: Windows 8, náhled před verzí beta“. AnandTech.
  3. ^ „Windows API API reference“. Odkaz na Windows Phone API. Microsoft. 21. července 2014.
  4. ^ A b Michael, Mayberry (2012). WinRT odhaleno. New York City: Apress. p. 3. ISBN  978-1-4302-4585-8.
  5. ^ "Vytváření aplikací Win32 (C ++)". MSDN. Microsoft. Citováno 12. ledna 2014.
  6. ^ „Soubory Windows Metadata (WinMD)“. Reference API pro aplikace UWP. Dokumenty Microsoftu. Citováno 2019-07-20.
  7. ^ De Icaza, Miguel (15. září 2011). „WinRT demystifikováno“. Osobní blog Miguela de Icaza. Vlastní vydání. Citováno 15. ledna 2014.
  8. ^ „Co je režie zařazování COM při volání rozhraní WinRT API z C #?“. Fórum MSDN. Vlastní vydání. 20. září 2011. Citováno 15. ledna 2014.
  9. ^ A b "Používání běhového prostředí Windows z C ++ | Build2011 | Kanál 9". Channel9.msdn.com. 14.09.2011. Citováno 2012-04-24.
  10. ^ Sivakumar, Nish (2011-09-29). „Visual C ++ a WinRT / Metro - některé základy - CodeProject®“. Codeproject.com. Citováno 2012-04-24.
  11. ^ "Používání běhového prostředí Windows z C ++ | Build2011 | Kanál 9". Channel9.msdn.com. 14.09.2011. Citováno 2012-04-24.
  12. ^ „Úvod do C ++ / WinRT - aplikace Windows UWP“. docs.microsoft.com. Microsoft.
  13. ^ příjmeníholiu. „Oprávnění pro přístup k souboru - aplikace UWP“. docs.microsoft.com. Citováno 2020-08-08.
  14. ^ „Designing a simple and secure app package - APPX“. Blog vývojáře aplikací pro Windows 8. Citováno 30. prosince 2013.
  15. ^ „Jak přidávat a odebírat aplikace“. TechNet. Microsoft. 31. května 2012. Citováno 4. října 2012. Chcete-li povolit sideloading na počítači se systémem Windows 8 Enterprise, který není připojen k doméně, nebo na jakémkoli počítači s Windows® 8 Pro, musíte použít aktivační klíč produktu pro sideloading. Chcete-li povolit sideloading na zařízení Windows® RT, musíte použít aktivační klíč produktu sideloading. Další informace o vedlejších aktivačních klíčích produktu najdete v části Microsoft Volume Licensing.
  16. ^ „Windows 8: The Metro Mess“. PC Magazine. Citováno 8. září 2012.
  17. ^ „Microsoft nyní používá„ moderní styl uživatelského rozhraní “k označování aplikací„ Windows Style “ve Windows 8“. Citováno 10. srpna 2012.
  18. ^ „Co je aplikace Microsoft Store?“. Centrum Windows Dev. Citováno 1. října 2012.
  19. ^ „Asynchronous programming (Windows Store apps)“. MSDN. Microsoft. Citováno 12. ledna 2014.
  20. ^ „.NET získává nový životní život“. Archivovány od originál 24. září 2011. Citováno 16. září 2011.
  21. ^ A b "Používání Windows Runtime z C # a Visual Basic | Build2011 | Kanál 9". Channel9.msdn.com. 14.09.2011. Citováno 2012-04-24.
  22. ^ „Počáteční verze náhledu C ++ / WinRT“. github.com. 2016-10-05. Citováno 2016-10-05.
  23. ^ „C ++ / WinRT je standardní projekce jazyka C ++ pro prostředí Windows Runtime“. github.com. 2016-09-14. Citováno 2016-09-14.
  24. ^ "Standardní C ++ a Windows Runtime (C ++ / WinRT)". blogs.windows.com. 2016-11-28. Citováno 2016-11-28.
  25. ^ „Inside the C ++ / CX Design - Visual C ++ Team Blog - Site Home - MSDN Blogs“. Blogs.msdn.com. 2011-10-20. Citováno 2012-04-24.
  26. ^ Charles (2011-10-26). „GoingNative 3: The C ++ / CX Episode with Marian Luparu | C9 :: GoingNative | Channel 9“. Channel9.msdn.com. Citováno 2012-04-24.
  27. ^ A b Pod kryty s C ++ pro aplikace stylu Metro s Deonem Brewisem na // Build
  28. ^ „microsoft / winrt-rs“. GitHub.
  29. ^ „Microsoft / ProjectReunion: vývoj vývojářské platformy Windows, díky kterému bude kompatibilnější, hbitější, moderní a otevřenější“. GitHub.
  30. ^ „Deset tipů při psaní aplikace ve stylu hybridního jazyka Metro - Build2011 - kanál 9“. Kanál 9. Microsoft.
  31. ^ „Windows Phone Runtime API“. microsoft.com. Microsoft.

externí odkazy