Mateusz Stanek

Dobry pomysł

Enumeracja – wartość domyślna

Pracując w świecie .NET-a często korzystam z typu wyliczeniowego. Enumeracje stosujemy wszędzie tam, gdzie chcemy zwracać wartości, gdzie każda z nich ma jakieś znaczenie.  Czyż nie łatwiej jest zapisać typ wyliczeniowy i później zwrócić go, aniżeli zwracać jakieś liczbowe wartości i następnie je tłumaczyć ? Często nie myślimy co pod tym typem wyliczeniowym się znajduje. A co się tam znajduje ? Otóż, jeśli nie podamy jawnie jakiego typu wewnętrznego ma być nasz typ wyliczeniowy, to będzie on opakowanym int-em. I właśnie z typem wewnętrznym związany jest problem, o którym chciałbym dzisiaj opowiedzieć.

Enum wartość domyślna

Jak wiemy, w czasie inicjalizacji zmiennej typu value object nadawana jest im wartość, co może być dla źle skonstruowanych typów wyliczeniowych problemem. Do rzeczy, mieliśmy w projekcie model danych, gdzie jedną z właściwości był właśnie typ wyliczeniowy. Oczywiście w momencie tworzenia takiego modelu wszystkie wartości w nim zawarte miały wartości domyślne. Poszczególne właściwości w modelu były wypełniane danymi. Aż tu nagle nie działa, dostajemy informacje, że wartość wyliczenia jest zawsze taka sama. O ironio, była to zakładana wartość, jeśli wszystko działało prawidłowo.

Przejdźmy do naszego przykładowego kodu :

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
    public enum State
    {
        Ok,
        Hold,
        Restarting,
        NotResponding
    }
 
    public class DtoClass
    {
        public State State { get; set; }
        public string Name { get; set; }
    }
 
    class Program
    {
        static void Main(string[] args)
        {
            var data = new DtoClass();
            data.Name = "alex";
            // data.State = State.NotResponding;
 
            Console.WriteLine($"Name: {data.Name}, State: {data.State}");
            Console.ReadLine();
 
        }
    }

Jak widzimy mamy tutaj przykładowy typ wyliczeniowy “State”. Prostą klasę “DtoClass” oraz program przedstawiający nasz niefortunny błąd. Powodem naszego problemu był brak przypisania właściwości State w klasie dto (brak przypisania podobnego do tego w linii 21). Widzicie już o co mi chodzi ? W tym przypadku zawsze dostaniemy spodziewany stan Ok, co może być naprawdę ciężko odnaleźć w produkcyjnym kodzie.

Co z tym można zrobić? To akurat jest proste i sprowadza się do dodania naszej własnej wartości domyślnej dla takiego typu wyliczeniowego. Dodając do powyższego stan Unknown  jako pierwszy lub nawet z jawnie podaną wartością ułatwiłby pracę oraz analizę problemu. No cóż, każdy z nas uczy się na błędach. Ważne tylko, ażeby uczyć się na cudzych. A ty czytelniku ile masz niebezpiecznych enumów, które tylko czekają na to, aby się ujawnić ?

No related posts.

23 marca 2017 DSP2017 Tips
4 komentarze

ASP.NET Core MVC - Konfiguracja

Testy - błędne wyniki

  1. kizi 24 marca 2017 o 07:13 Odpowiedz

    A czy nie lepiej zamiast dodawania dodatkowego statusu po prostu wymusić jak ma być reprezentowany i nadać wartość pierwszemu statusowi? Implementacja State wyglądałaby następująco:

    public enum State
    {
    Ok = 1,
    Hold,
    Restarting,
    NotResponding
    }

    Dzięki takiej zmianie nie musisz zmieniać już istniejącej implementacji i testów.

    • Mateusz Stanek 24 marca 2017 o 10:45 Odpowiedz

      Tak również nie musisz. Poprostu pierwszym elementem będzie Unknown który prawdopodobnie nigdy nie powinien się znaleźć w działającej aplikacji. Rozwiązanie w Unknown moim zdaniem jest również lepsze jeśli chodzi o debugowanie gdyż przy podglądzie zmiennej dostajemy nasz status zamiast 0, ale to prawdopodobnie jest bardzo indywidualne.

  2. Ola 23 czerwca 2019 o 19:48 Odpowiedz

    Hej wielkie dzięki za post !

  3. Oktawian Kurzynski 4 listopada 2019 o 08:27 Odpowiedz

    Hej dzięki za wpis !

Dodaj komentarz Anuluj pisanie odpowiedzi

Zobacz

  • Mateusz Stanek o mnie
Mateusz Stanek

Zaprzyjaźnione blogi

SGDev.pl

Ostatnie wpisy

  • Rola Prelegent
  • Elektronika – powrót do starego hobby
  • Badger2040
  • 2023 Tydzień 11
  • 2023 Tydzień 10

Najnowsze komentarze

  • Lukas L - Podsumowanie roku 2022
  • Oktawian Kurzynski - Enumeracja – wartość domyślna
  • Mateusz Stanek - Typy generyczne
  • Ola - Enumeracja – wartość domyślna
  • Typy generyczne w języku C# nie są 'rozwiązywane' w czasie kompilacji - Typy generyczne

Archiwa

  • marzec 2025
  • marzec 2023
  • luty 2023
  • styczeń 2023
  • grudzień 2022
  • marzec 2018
  • luty 2018
  • kwiecień 2017
  • marzec 2017
  • luty 2017

Kategorie

  • Bez kategorii
  • DSP2017
  • Elektronika
  • MiroBurn Challange
  • Narzędzia
  • Podsumowanie
  • Produktywność
  • Programowanie
  • Projekt
  • Prywatne
  • Rok 2023
  • Tips

Ostatnie wpisy

  • Rola Prelegent
  • Elektronika – powrót do starego hobby
  • Badger2040
  • 2023 Tydzień 11
  • 2023 Tydzień 10
Dumnie wspierane przez WordPressa | Motyw: Neblue by NEThemes.
Ta strona korzysta z ciasteczek aby świadczyć usługi na najwyższym poziomie. Dalsze korzystanie ze strony oznacza, że zgadzasz się na ich użycie.Zgoda
Privacy & Cookies Policy

Privacy Overview

This website uses cookies to improve your experience while you navigate through the website. Out of these cookies, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may have an effect on your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. This category only includes cookies that ensures basic functionalities and security features of the website. These cookies do not store any personal information.
Non-necessary
Any cookies that may not be particularly necessary for the website to function and is used specifically to collect user personal data via analytics, ads, other embedded contents are termed as non-necessary cookies. It is mandatory to procure user consent prior to running these cookies on your website.
SAVE & ACCEPT