Ostatnia aktualizacja:

3 września 2025

Opublikowano:

9 stycznia 2017

Jak komentować kod?

Jak komentować kod?

Dzisiaj chciałbym powiedzieć kilka słów o podejściu do komentowania kodu. Wielu początkujących programistów będzie zapewne pod wrażeniem, widząc kod zawierający komentarz na końcu każdej linijki, komentarze blokowe przed wybranymi fragmentami programu i oczywiście docblocki do plików, klas i metod w kodzie. Przyjrzyjmy się jednak temu zagadnieniu bliżej – czy na pewno kod powinien być tak mocno komentowany?

W tym artykule dowiesz się:
  1. Najważniejsze – nie „komentuj” własnego kodu
  2. Dlaczego nie „komentujemy” kodu
  3. Kiedy komentujemy kod
  4. Podsumowanie

Najważniejsze – nie „komentuj” własnego kodu

Dobrze napisany kod jest samokomentujący się i nie wymaga żadnych dodatkowych podpowiedzi autora dla osób, które w późniejszym czasie będą pracować nad danymi fragmentami. Używanie intuicyjnych (nawet dłuższych) nazw zmiennych, metod i klas, krótkie metody i praca na jednym poziomie abstrakcji w obrębie jednej klasy pozwala na swobodne zrozumienie fragmentów programu bez komentarzy. Lepiej jest wyrażać swoje intencje w kodzie poprzez jego odpowiednie pisanie niż opatrywanie go komentarzem. Weźmy pod lupę taki fragment:

//pracownik może posiadać multisport
$employee->isActive() && $emplyee->getMonths() > 3

Mógłby on być z powodzeniem zastąpiony przez wydzielenie tej logiki do osobnej metody:

$employee->isMultisportApplicable()

Pomocna podczas pisania programów może być ta sentencja:

„Don’t comment bad code – rewrite it.” (Brian W. Kerninghan and P. J. Plaugher)

Dlaczego nie „komentujemy” kodu

Powstaje oczywiście pytanie, dlaczego nie dodawać komentarzy do napisanych fragmentów kodu. Otóż komentarze są częścią kodu i wymagają takiej samej opieki jak kod. Kod z komentarzami jest chociażby dłuższy dlatego jego refaktoryzacja/przebudowa/rozwój jest trudniejszy. Przy refaktoryzacji kodu należy także zadbać o przeniesienie lub zmianę komentarzy odpowiadających refaktorowanym fragmentom programu. Przy rozwoju należy zwracać uwagę czy wstawiane nowe fragmenty kodu nie powodują np. że komentarze są w miejscu, które nie jest najbliżej fragmentu kodu, którego dotyczą. Źle umieszczony kod może być bezużyteczny dlatego lepszym rozwiązaniem jest samokomentujący się kod, który na pewno posiada odpowiednie wyjaśnienia w miejscu, w którym są potrzebne. Również nie powinniśmy komentować kodu “na przyszłość”. Taki zakomentowany fragment kodu będzie rodził dodatkowe pytania przy refaktoryzacji, debugowaniu lub rozwoju kodu.

Kiedy komentujemy kod

Oczywiście są sytuacje, które wymagają użycia komentarza.

  1. Mogą występować standardy w projekcie, które wymagają stosowania komentarzy do plików/klas/metod – nie dyskutujemy z takimi wymogami i po prostu stosujemy komentarze, pamiętając, że one również wymagają uwagi podczas zmian w kodzie;
  2. Wyjaśnienie kodu, który nie jest oczywisty na pierwszy rzut oka. Przykładowo do jakiego wzorca dopasowuje dany regexp;
  3. Wyjaśnienie intencji, które ciężko ująć w kodzie. Przykładowo dlaczego uznajemy pierwszy obiekt za większy od drugiego przy implementacji metody compareTo;
  4. Ostrzeżenie o konsekwencjach użycia danej funkcjonalności. Przykładowo w testach, które mogą czyścić bazę danych lub trwać dłuższy czas;
  5. Wyjaśnienie niuansów procesów biznesowych, które realizuje program;
  6. Komentarze TODO – w przypadku gdy w danej chwili nie jest możliwe wdrożenie pełni funkcjonalności z jakiegokolwiek powodu;

Przy komentowaniu kodu powinniśmy zdecydowanie zwracać uwagę na miejsce umieszczania komentarzy – im bliżej fragmentu kodu którego dotyczy komentarz tym lepiej. Podczas rozwoju kodu powinniśmy zwracać uwagę czy komentarze po zmianach w kodzie nie wymagają refaktoryzacji.

Podsumowanie

Jeżeli Twój kod nie wymaga komentarzy, prawdopodobnie jest to wynikiem dobrze wykonanej pracy i dobrej jakości kodu. Jeżeli uważasz, że wybrany fragment wymaga opatrzenia go komentarzem, to jest to pierwszy sygnał do zastanowienia się nad refaktoryzacją kodu – nie należy go ignorować, a skorzystać z szansy na refaktoryzację i polepszenie swoich umiejętności programistycznych.

Ostatnia aktualizacja:

3 września 2025

Opublikowano:

9 stycznia 2017

W tym artykule dowiesz się:
  1. Najważniejsze – nie „komentuj” własnego kodu
  2. Dlaczego nie „komentujemy” kodu
  3. Kiedy komentujemy kod
  4. Podsumowanie

Polecane artykuły

Czym jest punchout i jak może pomóc w rozwoju e-Commerce B2B? - wideo

Czym jest punchout i jak może pomóc w rozwoju e-Commerce B2B?

E-Commerce B2B ma bardzo różne oblicza. Może oznaczać na przykład to, że klient po prostu podaje NIP w procesie zakupowym. Może też oznaczać subkonta i skomplikowany proces ofertowania. Ale naprawdę duże kontrakty B2B często oznaczają wymianę danych przez systemu e-procurement, jak na przykład SAP Ariba. Wtedy to gry wchodzi coś, co ładnie nazywa się punchout. W tym nagraniu opowiem Wam, czy jest punchout i jak można go wykorzystać do rozwoju sprzedaży w e-Commerce B2B.

Czytaj więcej
Testy regresji

Testy regresji w e-Commerce

Głównym celem działania serwisów e-Commercowych jest prawidłowe i przyjazne przeprowadzanie użytkownika przez proces zakupowy: od momentu zaprezentowania produktu, wyboru konkretnego produktu, aż do płatności zakończonej sukcesem. To właśnie problemy w tym zakresie i przeszkody na etapie przejścia tej ścieżki, mogą zniechęcić klienta, który finalnie może wyjść z naszego sklepu i wybrać inny. Testy regresji – […]

Czytaj więcej
Integracja Shopify Baselinker

Integracja Shopify Baselinker – automatyzacja, która robi różnicę

Sprzedajesz przez Shopify i szukasz sposobu, by rozwinąć sprzedaż, zapanować nad logistyką i odzyskać czas? Dobrze trafiłeś. W tym artykule pokażemy Ci, dlaczego integracja Shopify Baselinkerem to jedno z najpotężniejszych rozwiązań, jakie możesz wdrożyć w swoim e-Commerce. I – co ważniejsze – jak wycisnąć z niej 100%. Czym właściwie jest Baselinker? Baselinker to zaawansowane narzędzie […]

Czytaj więcej
Magento 2 moduły

Moduły Magento 2 – co warto wiedzieć?

Jednym z powodów, dla których firmy chętnie kierują swój wzrok ku sklepom na Magento 2, jest całkiem spora baza modułów, czyli dodatków rozwijanych (czasami za darmo, częściej płatnie) przez społeczność. W końcu umówmy się – wersja pudełkowa Magento ma wiele, naprawdę wiele zalet (które zresztą były szeroko omawiane nawet na łamach tego bloga), ale te […]

Czytaj więcej

Skontaktuj się z nami

Opowiedz nam o swoich ambicjach związanych z e-commerce i pozwól nam wspólnie je zrealizować.

Skontaktuj się z nami