Jak zmiany kodu mogą mieć wpływ na zgodność
zgodność odnosi się do możliwości kompilowania lub wykonywania kodu w wersji implementacji .NET innej niż ta, z którą kod został pierwotnie opracowany. Określona zmiana może mieć wpływ na zgodność na sześć różnych sposobów:
- zmiana behawioralna
- Zgodność binarna
- zgodność źródłowa
- Zgodność czasu projektowania
- zgodność z poprzednimi wersjami
- Zgodność z przyszłością (nie jest celem .NET.NET Aspire)
Zmiana zachowania
Zmiana zachowania reprezentuje zmianę zachowania członka. Zmiana może być widoczna zewnętrznie (na przykład metoda może zgłosić inny wyjątek) lub może reprezentować zmienioną implementację (na przykład zmianę sposobu obliczania wartości zwracanej, dodawania lub usuwania wywołań metod wewnętrznych, a nawet znacznej poprawy wydajności).
Gdy zmiany zachowania są widoczne zewnętrznie i modyfikują kontrakt publiczny typu, można je łatwo ocenić, ponieważ wpływają one na zgodność binarną. Zmiany implementacji są znacznie trudniejsze do oceny; w zależności od charakteru zmiany oraz częstotliwości i wzorców użycia interfejsu API wpływ zmiany może wahać się od poważnych do nieszkodliwych.
Zgodność binarna
Zgodność binarna odnosi się do możliwości użytkownika interfejsu API do korzystania z interfejsu API w nowszej wersji bez ponownej kompilacji. Zmiany, takie jak dodawanie metod lub dodawanie nowej implementacji interfejsu do typu, nie mają wpływu na zgodność binarną. Jednak usunięcie lub zmodyfikowanie podpisów publicznych zestawu, aby użytkownicy nie mogli już uzyskać dostępu do tego samego interfejsu uwidocznionego przez zestaw, ma wpływ na zgodność binarną. Zmiana tego rodzaju jest określana jako niezgodna zmiana binarna .
Zgodność źródła
Zgodność źródła odnosi się do możliwości ponownego kompilowania istniejących użytkowników interfejsu API względem nowszej wersji bez żadnych zmian w źródle. Zmiana źródła niezgodna z występuje, gdy konsumenci muszą zmodyfikować kod źródłowy, aby pomyślnie skompilować go względem nowszej wersji API.
Zgodność w czasie projektowania
Zgodność w czasie projektowania odnosi się do zachowania doświadczenia czasu projektowania we wszystkich wersjach Visual Studio i innych środowiskach czasu projektowania. Chociaż może to dotyczyć zachowania lub interfejsu użytkownika projektantów, najważniejszym aspektem zgodności podczas projektowania jest kompatybilność projektów. Projekt lub rozwiązanie musi być otwierane i używane w nowszej wersji środowiska projektowego.
Zgodność z poprzednimi wersjami
Zgodność z poprzednimi wersjami odnosi się do zdolności istniejącego klienta API do działania względem nowej wersji API, zachowując się w ten sam sposób. Zarówno zmiany w zachowaniu, jak i zmiany w zgodności binarnej mają wpływ na zgodność z poprzednimi wersjami. Jeśli użytkownik nie może uruchomić lub zachowuje się inaczej podczas uruchamiania względem nowszej wersji interfejsu API, interfejs API jest niezgodny z poprzednimi wersjami.
Zmiany wpływające na wsteczną zgodność są odradzane, ponieważ deweloperzy oczekują zgodności z poprzednimi wersjami interfejsu API.
Zgodność w przód
Zgodność w przód odnosi się do możliwości działania istniejącego konsumenta API wobec starszej wersji przy zachowaniu tej samej funkcjonalności. Jeśli użytkownik nie może uruchomić lub zachowuje się inaczej podczas uruchamiania względem starszej wersji interfejsu API, interfejs API jest przekazywać niezgodne.
Utrzymywanie zgodności w przód praktycznie uniemożliwia wszelkie zmiany lub dodatki z wersji na wersję, ponieważ uniemożliwiają one działanie użytkownikowi, który celuje w nowszą wersję, w starszej wersji. Deweloperzy oczekują, że użytkownik korzystający z nowszego interfejsu API może nie działać poprawnie względem starszego interfejsu API.
Utrzymywanie zgodności przyszłościowej nie jest celem .NET.NET Aspire.