Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Tento článek vysvětluje rozdíly mezi reflexí a generováním zdroje, protože souvisí se System.Text.Json serializací. Obsahuje také pokyny k volbě nejlepšího přístupu pro váš scénář.
Kolekce metadat
Chcete-li serializovat nebo deserializovat typ, potřebuje informace o tom, JsonSerializer jak získat přístup k členům typu.
JsonSerializer potřebuje následující informace:
- Jak přistupovat k getterům a polím vlastností pro sérializaci.
- Jak přistupovat ke konstruktoru, nastavovačům vlastností a polím pro deserializaci.
- Informace o tom, které atributy byly použity k přizpůsobení serializace nebo deserializace.
- Konfigurace modulu runtime z JsonSerializerOptions.
Tyto informace se označují jako metadata.
Úvaha
Ve výchozím nastavení JsonSerializer shromažďuje metadata za běhu pomocí reflexe. Kdykoli JsonSerializer musí serializovat nebo deserializovat typ poprvé, shromažďuje a ukládá tato metadata do mezipaměti. Proces shromažďování metadat nějakou dobu trvá a využívá paměť.
Generování zdroje
Jako alternativu může System.Text.Json využít funkci generování kódu v C# ke zlepšení výkonu, snížení využití privátní paměti a usnadnění optimalizace sestav, což snižuje velikost aplikace. Kromě toho se určitá rozhraní API reflexe nedají použít v nativních aplikacích AOT, takže pro tyto aplikace musíte použít generování zdroje.
Generování zdroje se dá použít ve dvou režimech:
Režim založený na metadatech
Během kompilace
System.Text.Jsonshromažďuje informace potřebné pro serializaci a generuje soubory zdrojového kódu, které naplní metadata kontraktu JSON pro požadované typy.Režim optimalizace serializace (rychlá cesta)
JsonSerializer funkce, které přizpůsobují výstup serializace, jako jsou zásady pojmenování a zachování odkazů, mají dopad na výkon. V režimu optimalizace serializace System.Text.Json generuje optimalizovaný serializační kód, který používá
Utf8JsonWriterpřímo. Tento optimalizovaný nebo rychlý kód cesty zvyšuje propustnost serializace.Deserializace fast-path není v současné době dostupná. Další informace viz dotnet/runtime issue 55043.
Generování zdroje pro System.Text.Json vyžaduje C# 9.0 nebo novější verzi.
Porovnání funkcí
Zvolte režimy reflexe nebo generování zdroje na základě následujících výhod, které každá nabízí:
| Výhoda | Úvaha | Generování zdroje (Režim založený na metadatech) |
Generování zdroje (Režim optimalizace serializace) |
|---|---|---|---|
| Jednodušší kód. | ✔️ | ❌ | ❌ |
| Jednodušší ladění. | ❌ | ✔️ | ✔️ |
| Podporuje neveřejné členy. | ✔️ | ✔️* | ✔️* |
| Podporuje všechna dostupná přizpůsobení serializace. | ✔️ | ❌ † | ❌ † |
| Zkracuje dobu spuštění. | ❌ | ✔️ | ✔️ |
| Snižuje využití privátní paměti. | ❌ | ✔️ | ✔️ |
| Eliminuje odraz modulu runtime. | ❌ | ✔️ | ✔️ |
| Usnadňuje zmenšení velikosti aplikací bez narušení jejich funkčnosti. | ❌ | ✔️ | ✔️ |
| Zvyšuje propustnost serializace. | ❌ | ❌ | ✔️ |
* Zdrojový generátor podporuje některé neveřejné členy, například interní typy ve stejném sestavení. † zdrojové kontrakty je možné upravit pomocí rozhraní API pro přizpůsobení kontraktu.