Szukam tutaj pomysłów.
Przeczytałem artykuł Jak powinny być przeprowadzane recenzje kodu i Recenzje kodu, jakie są zalety? które były bardzo pouczające, ale nadal potrzebuję większej jasności w poniższym pytaniu.
Moje pytanie brzmi,
Będąc programistą docelowym, możesz zasugerować kilka najlepszych praktyk, które programista może zastosować, zanim jego kod zostanie sprawdzony.
Obecnie ćwiczę następujące metody
- PPT dla logicznego przepływu
- Szczegółowe komentarze.
Problem: mimo że zastosowałem powyższe praktyki, nie pomagają one w przeglądzie. Problem, z którym się spotkałem, kiedy odnoszę się do pewnej logiki, wciąż szukam implementacji i przepływu, a zbyt wiele czasu jest marnowane w procesie i zaczynam działać na nerwy ludzi.
Myślę, że wielu programistów również przejdzie przez to, przez co przechodzę.
źródło
Odpowiedzi:
Tak więc na podstawie dostarczonych szczegółów OP brzmi, jakby pytanie brzmiało: „jak nauczyć się własnego kodu, aby zapytać go o X lub wyjaśnić Y, mogę szybko odpowiedzieć”.
Kilka sugestii, które mogę wymyślić:
Podczas kodowania musisz poświęcić trochę czasu na naukę i zrozumienie własnego kodu. Może to być to, co twój TL próbuje ci przekazać w niewielu słowach. Będąc TL obecnego projektu, w ciągu ostatnich 11 miesięcy dokonałem wielu recenzji kodu i zauważam, że niektórzy programiści szukają „przykładowego kodu” w naszej własnej bazie kodu lub gdzie indziej (google itp.) i skopiuj / wklej. Osobiście nie mogę tego znieść, ponieważ podczas gdy ich kod przechodzi proste testy jednostkowe, nie rozumieją, co faktycznie robi, więc nigdy nie mamy gwarancji, że nie ma • niektóre przypadki graniczne lub spodziewane warunki awarii, które mogą wystąpić.
W następstwie poprzedniego oświadczenia, jeśli musisz skopiować / wkleić, spróbuj skopiować / wklej tylko kod, który wcześniej napisałeś i który rozumiesz. Z pewnością można „pożyczyć” pomysł innych ludzi, ale w takim przypadku przepisać kod po linii, ponieważ podczas pisania będziesz lepiej rozumieć, co robi. Jeśli korzystasz z zewnętrznych interfejsów API, nawet jeśli masz przykład, który używa tego interfejsu API, i tak poświęć kilka minut na znalezienie odniesienia i dowiedz się, jak działa ten interfejs API. Nie zakładaj tylko, że jeśli wcześniej działał, będzie działał również w twojej sytuacji.
Przeczytaj i naucz się kochać zasadę SUCHEGO . Wiele razy to, co kusi cię do skopiowania / wklejenia, może być umieszczone we wspólnej lokalizacji (osobna funkcja, osobna klasa, osobna biblioteka ...)
Przeczytaj i naucz się kochać SOLIDNE zasady, a gdy już to zrobisz, przejrzyj KISS, o którym wspomniał już mouviciel. Wszystkie te zasady mają na celu stworzenie bardzo zwięzłego, czystego i modułowego kodu. Jeśli masz w nich duże klasy i duże funkcje, to o wiele trudniej będzie znaleźć rzeczy, a na dodatek spróbować wyjaśnić, co robi kod. Z drugiej strony, jeśli podążasz (lub przynajmniej próbujesz podążać) SRP i czynisz każdą klasę / funkcję odpowiedzialną tylko za jedną rzecz, twój kod będzie mały i bardzo czytelny.
Odbierz kopię Clean Code . Bardzo dobra książka. Mówi o pisaniu kodu, który jest zrozumiały i łatwy do odczytania, utrzymania i rozszerzenia. Jeśli ćwiczysz pisanie łatwego do odczytania kodu, nie powinieneś mieć problemów z czytaniem własnego kodu w recenzjach kodu. I to jest zabawne, poprosiłem ludzi, aby przeczytali własny kod lub po prostu powiedzieli mi, co reprezentują zmienne, i nie mogli odpowiedzieć, mimo że napisali ten kod (zupełnie nowe klasy, a nie starsze wersje) zaledwie tydzień temu . Dobre nazewnictwo ma długą drogę.
Jeśli po wszystkich uproszczeniach i refaktoryzacji nadal masz funkcję, która musi wykonać jakiś algorytm, który nie jest bardzo widoczny, poświęć trochę czasu i napisz blok komentarza w tej funkcji wyjaśniającej algorytm. Nie tylko będzie to pomocne, gdy będziesz musiał zmodyfikować tę funkcję za 2 miesiące, ale jeśli wpadniesz w zasadzkę podczas przeglądu kodu, będziesz mógł po prostu przeczytać to, co napisałeś.
Jeśli po wszystkich powyższych elementach nadal masz problemy? jesteś nowy w zespole i zostałeś poproszony o pracę z wieloma starszymi kodami? W takim przypadku może być tak, że twój TL jest A $$ i możesz być proaktywny, prosząc go przed spotkaniem, aby poszedł spokojnie i nie marnował czasu wszystkich zaangażowanych. Gdy do zespołu dołączają nowe osoby, TL musi mieć wystarczającą cierpliwość, ponieważ praca na nowej platformie, nowym produkcie, nowych osobach, nowym środowisku wymaga dużej koncentracji od nowej osoby, a na początku tej osobie brakuje niektórych szczegółów. Działa zgodnie z przeznaczeniem i twój TL powinien to zaakceptować.
Jeśli mimo wszystko powyżej, nadal masz wrażenie, że masz okropne recenzje kodu. Porozmawiaj ze swoim TL. Czasami ludzie czują się źle z powodu natury spotkań związanych z recenzowaniem kodu, gdy w rzeczywistości TL jest z Ciebie w pełni zadowolony. Kiedy robię recenzje kodu, moim celem jest podkreślenie, co należy zmienić, upewnienie się, że rozumiesz zmiany i kontynuacja. Wiele razy nie mam czasu na uprzejmość, a niektórzy się bronią i próbują odpowiedzieć na każdy z moich komentarzy. W takich sytuacjach spotkanie przeglądu kodu kończy się, więc mam tendencję do ich przerywania i kontynuowania. Ogólnie po spotkaniu rozmawiałem z nowymi facetami, aby upewnić się, że rozumieją proces i że nie jest to nic osobistego. Po kilku recenzjach kodu ludzie są na ogół znacznie wygodniejsi.
źródło
Praktyki są różne, ale z mojego doświadczenia:
Nie rób nic specjalnego z kodem. To naturalne, że trochę poprawiasz kod, gdy dowiadujesz się, że zostanie on poddany przeglądowi, a naprawianie oczywistych rzeczy, takich jak błędy ortograficzne i nic nie szkodzi. Ale nie wchodź i nie dodawaj wielu szczegółowych komentarzy lub w inny sposób zmieniaj kod tylko dlatego, że jest on zaplanowany do przeglądu.
Kod jest przygotowywany i dystrybuowany do recenzentów z dużym wyprzedzeniem przed recenzją. Zwykle robi to neutralna strona trzecia, prawdopodobnie osoba ułatwiająca przegląd kodu. Po wydrukowaniu kod powinien być wystarczająco mały, aby wiersze nie były zbyt często zawijane, ale wystarczająco duży, aby każdy mógł go łatwo odczytać. Wydrukuj go w formacie poziomym, jeśli tego potrzebujesz.
Kod powinien być wydrukowany lub wyświetlony z numerami linii . Najlepiej, aby numer był kontynuowany od jednego pliku do następnego. O wiele łatwiej jest odnieść się do „linii 3502” niż „linii 238 foo.c”, a posiadanie liczb pozwala wszystkim rozmawiać o konkretnych liniach bez marnowania czasu na znajdowanie tych linii.
Zdecydowanie powinien być facylitator . Jego zadaniem jest zapobieganie zapadnięciu się recenzji w drobiazgi, zapobieganie personalizacji lub nagrzewaniu się oraz ścisłe ograniczanie czasu trwania recenzji.
Jako autor, powinieneś sam przejrzeć kod przed spotkaniem recenzującym. Zapisz zmiany, które sugerowałbyś, gdyby był to kod innej osoby. To pobudza pamięć do kodu, którego mogłeś nie oglądać w ciągu kilku dni, a także pomaga ćwiczyć patrzenie na swój kod krytycznym okiem. Po przejrzeniu kilku recenzji, zarówno jako recenzent, jak i autor, przekonasz się, że własne notatki będą bardziej pasować do notatek reszty grupy.
Przygotuj się do robienia notatek podczas przeglądu. To nie powinno być twoim głównym zmartwieniem - ktoś inny powinien rejestrować elementy akcji, na które grupa się zgadza, abyś mógł skupić się na wyjaśnianiu kodu i słuchaniu opinii. Ale będą chwile, kiedy otrzymasz cenne informacje zwrotne, które nie są przedmiotem akcji, i powinieneś je naprawić, gdy tylko się pojawią.
Pamiętaj, że to nie jest sprawa osobista. Podczas przeglądu trudno jest uniknąć poczucia obrony (i działania). Możesz wyjaśnić swój kod, jeśli uważasz, że został źle zrozumiany, ale bardziej niż cokolwiek innego, spróbuj po prostu słuchać.
źródło
Jeszcze jedna rzecz, którą należy dodać do pozostałych odpowiedzi: aby ułatwić formalnym recenzentom kodu, przeprowadzaj WIELE NIEformalnych recenzji kodu! Na przykład:
„Hej Bob, mogę pokazać ci, jak zaimplementowałem funkcję foo ()?” „Hej Steve, czy możesz rzucić okiem na ten schemat zajęć i dać mi znać, co myślisz?” „Hej Karen, czy możesz mi pomóc przemyśleć ten problem? Myślę, że mam dobre rozwiązanie, ale mógłbym skorzystać z twojej pomocy ...”
Uczyń to regularnym nawykiem. Kiedy angażujesz współpracowników na wczesnym etapie procesu projektowania, możesz:
źródło