Czy martwisz się czasem, że bardziej martwi Cię to, jak coś jest budowane, niż to, co faktycznie budujesz?

11

Jako programista mam wrodzoną irytującą irytację na moje narzędzia, kod innych ludzi, mój kod i cały świat. Zawsze chcę to poprawić. Więc refaktoryzuję się, jestem na bieżąco z najnowszymi technikami. Próbuję uczyć się wzorców, próbuję używać ram, aby nie wymyślać koła na nowo. Mogę napisać specyfikację techniczną, która zdmuchnie twoje skarpetki z ilością wzorów, które mogę wcisnąć.

Jednak ostatnio wydaje mi się, że wiem więcej o narzędziach, których używam, niż o tym, jak wdrożyć udane oprogramowanie.

Wydaje mi się, że brakuje mi umiejętności ludzkich i wierzę, że sukces inżyniera oprogramowania wymaga czegoś więcej niż znajomości najfajniejszych frameworków. Myślę, że potrzebuje również niektórych z poniższych zestawów umiejętności.

  • Projektowanie interakcji
  • Doświadczenie użytkownika
  • Marketing

Mam trochę tego, czego nauczyłem się od ludzi, z którymi pracowałem i świetne projekty, nad którymi pracowałem, ale nie wydaje mi się, żebym „posiadał” te umiejętności.

Czy mam rację? Czy powinienem starać się dalej rozwijać te umiejętności, czy też należy je pozostawić osobom, które je wykorzystują w trakcie kariery?

W jaki sposób upewniasz się, że nie przywiązujesz się zbytnio do tego, jak coś robisz i że „sprawisz, że użytkownicy będą niesamowici”?

Czy ktoś wie o dobrych zasobach do nauki tych umiejętności z punktu widzenia programowania?

Rob Stevenson-Leggett
źródło
2
Tak, to wielka sprawa. Gdybyś był jednoosobową firmą, od razu poczułbyś szczyptę. Start-up może cię nie zatrudnić, ponieważ nie rozumiesz, że walczy o przetrwanie i albo muszą wypchnąć rzeczy w jakości beta w przyszłym miesiącu, albo umrzeć, lub ponieważ nie możesz trochę rozciągnąć prawdy, rozmawiając z klientami. Jednak w dużej korporacji, która jest źle zarządzana, być może lepiej jest realizować samolubny interes własny. Kierownictwo i tak robi to cały czas.
Job
Lubię używać świetnych produktów, w których myślę „wow, to działa płynnie”. Więc próba uczestniczenia w tworzeniu takich produktów „wow” przychodzi mi naturalnie. Jeśli nie jest to dla ciebie naturalne, być może pamiętaj o tych, którzy lubią to i są gotowi zapłacić dobre pieniądze (pomyśl produkty Apple).
LennyProgrammers,
2
Wydaje mi się, że jesteś na drodze do bycia pracownikiem zorientowanym na proces, a nie pracownikiem zorientowanym na wyniki. Skupiasz się na procesie, ponieważ znasz to. Naucz się odpuszczać proces i skupiać się na wynikach. Jak powiedziałeś, wzorce projektowe i inne rzeczy są jedynie narzędziami: Twoim głównym zmartwieniem powinno być to, jaki problem rozwiąże tworzony produkt.
whatsisname
1
@whatisname, to nie jest takie proste, na pewno „wyniki” mogą wydawać się, że taka i taka aplikacja działa świetnie dla wersji 1.0 z pewnym kodem ad-hoc, który został zhakowany razem, ale potem dla wersji 2.0 potrzebna jest poważna zmiana, cóż, nadal jesteś utknie w „wyniku” poprzedniego wysiłku, który będzie wymagał ponownej pracy. Myślę, że tak naprawdę jest to sytuacja, w której funkcjonalność aplikacji z punktu widzenia użytkownika jest tylko wierzchołkiem góry lodowej i można „ Ogranicz do tego „wynik”
programmx10
@whatisname Gdyby to była odpowiedź, zaakceptowałbym ją, ale zgadzam się z tobą także Rick. To, co próbuję osiągnąć, to punkt, w którym jeden z dwóch zestawów umiejętności jest w równowadze, więc jestem w stanie zaprojektować wspaniałe wrażenia użytkownika, korzystając z najlepszych narzędzi i technik. Wydaje się, że teraz jedno lub drugie cierpi. Oba zestawy umiejętności muszę uczynić drugą naturą.
Rob Stevenson-Leggett

Odpowiedzi:

5

Moja rada: rozmawiaj z użytkownikami tak często, jak to możliwe. Nie wiem, czy jesteś w dużej firmie i jesteś na innym kontynencie niż twoi użytkownicy, czy jesteś na stanowisku freelancera, ale jeśli to możliwe, po prostu porozmawiaj z użytkownikami.

Wiem, że wiele razy muszę siedzieć i pamiętać, że moim zadaniem nie jest tworzenie największego kodu, jaki kiedykolwiek widział świat, ani tworzenie funkcji, która wykorzystuje najmniejszą liczbę cykli i zajmuje najkrótszy możliwy czas technologicznie, ale aby zrobić wszystko, czego potrzeba użytkownikom do wykonywania swoich zadań. I w tym celu uważam, że poza zwykłymi możliwościami technicznymi (dla mnie zresztą) najlepszymi 2 cechami, które można mieć, są dobra znajomość działalności biznesowej użytkowników i dobre relacje robocze z nimi.

Pracuję w małej firmie (~ 50 osób) i lubię chodzić do czyichś kostek i rozmawiać o najnowszych rzeczach, które dla nich stworzyłem / naprawiłem. Absolutnie najlepsze uczucie, jakie kiedykolwiek miałem z pracy, kiedy słyszę, jak rozmawiają o swojej pracy, i sugerują coś, co rozwiąże problem, o którym nigdy nie zdawali sobie sprawy, że może istnieć rozwiązanie techniczne. Nie byłoby to możliwe, gdybym nie rozumiał ich interesów i nie mógłbym z nimi swobodnie rozmawiać.

Jason
źródło
+1 za rozmowę z użytkownikami - krytyczne dla stworzenia użytecznego produktu
Gary Rowe
5

Powiedziałbym, że to zależy od tego, gdzie pracujesz i do jakiego rodzaju firm widzisz siebie w przyszłości - to naprawdę otwarta dyskusja.

W mniejszych firmach możesz nosić wiele czapek (choć nie jestem pewien, dlaczego marketing znajduje się na tej liście, chyba że zamierzasz sprzedawać własny produkt).

W większych firmach mogą mieć ludzi, którzy koncentrują się na tych sprawach.

Tak naprawdę chodzi o to, dokąd idziesz i potencjalnie otwierając dla ciebie więcej drzwi.

ozz
źródło
2
Dzięki - ciekawe punkty. Uważam marketing za coś więcej niż sprzedaż, myślę, że blogi programistyczne, SEO, podmioty stowarzyszone, sposób ich integracji itp.
Rob Stevenson-Leggett
2

Dla każdego wiersza kodu, który piszesz, wprowadzasz szansę na błąd.

Zatem najlepsze projekty minimalizują ilość wprowadzanego kodu - być może dzięki zasadzie DRY (Don't Repeat Yourself). Jednak start- upy preferują podejście YAGNI (You Ain't Gonna Need It), które znacznie szybciej prowadzi do MVP (produktu minimalnego).

Jeśli Twoim celem jest stworzenie czystego, łatwego w użyciu produktu, który robi dokładnie to, czego pragną Twoi użytkownicy, to YAGNI jest twoim najlepszym wzorcem projektowym. Wyrzuć wszystko, co nie przyczynia się bezpośrednio do działania kodu. Obejmuje to purystyczne procesy budowania i obsesyjne stosowanie wzorców.

Niektóre materiały do ​​czytania

Możesz przeczytać „ Nie każ mi myśleć ”, która jest doskonałą książką na temat projektowania interfejsu użytkownika. Ponadto, każda z serii książek Gitomer (szczególnie The Little Green Book ) pomoże ci w twoich umiejętnościach sprzedaży, nawiązywania kontaktów i marketingu.

Gary Rowe
źródło
1

Myślę, że pewna wiedza na temat projektowania interakcji i wiedzy o użytkowniku jest bardzo przydatna nawet w dużej firmie z jednego powodu: Ty jako programista jesteś pierwszą osobą, która faktycznie korzysta z interfejsu na tygodnie, a nawet miesiące, zanim będzie on w stanie użytecznym przez tester do przetestowania.

Na początku bardzo przydatne może być wskazanie interfejsu, który nie jest tak łatwy w użyciu, jak planowano, lub pewnej zasady projektowania, która mogła zostać przeoczona. Te rzeczy mogą czasem być trudne do zobaczenia, zanim będziesz mieć coś konkretnego do pracy, i zawsze jesteś pierwszą osobą, która ma coś konkretnego do pracy.

Karl Bielefeldt
źródło
Nie jestem w dużej firmie i w przeszłości pracowałem dla firmy zajmującej się projektowaniem interakcji. Stwierdziłem, że ponieważ czasami brakowało mojej wiedzy, odłożyłem. Czy masz jakieś zasoby lub rekomendacje książek?
Rob Stevenson-Leggett
1

Mogę napisać specyfikację techniczną, która zdmuchnie twoje skarpetki z ilością wzorów, które mogę wcisnąć.

Samo to stwierdzenie prowadzi mnie do przekonania, że ​​musisz pracować nad innymi aspektami tworzenia oprogramowania.

Edward Strange
źródło
Było w tym trochę ironii :) Prawdopodobnie nie trafiło się zbyt dobrze w pytaniu.
Rob Stevenson-Leggett
@ Rob, cieszę się, że to powiedziałeś, miałem duże czerwone migające światła nadużywania wzoru gasnące w całym miejscu.
ocodo
1

Chociaż możesz nigdy nie być odpowiedzialny za każdy aspekt oprogramowania swojej firmy, posiadanie szerokiego zakresu wiedzy na wiele tematów może być niezwykle cenne. Jeśli nic więcej, to więcej rzeczy, które możesz rzucić w wywiadzie, dzięki czemu możesz kontynuować karierę.

Jeśli nie masz wystarczających wyzwań w niektórych obszarach swojej pracy, rozpocznij własny projekt w domu, aby zrobić coś, co uważasz za interesujące. Lub zaangażuj się w projekt open source.

Kazim
źródło
1

Nie, nie wiem, nie moim zadaniem jest martwić się tym, co buduję, ale raczej budować go zgodnie ze specyfikacją określoną przez mojego klienta / pracodawcę. Wiedzą już, czego chcą i ode mnie zależy, czy je odpowiednio wdrożę, aby można było to utrzymać. Udzielę porady, gdy pojawi się szansa, jeśli mogę powiedzieć, że nie są do końca pewni, jak najlepiej wprowadzić funkcję do oprogramowania

Prawdopodobnie w pewnym momencie będę chciał stworzyć własny projekt i martwić się tym, co buduję, ale myślę, że rozpoczynając karierę programistyczną, ważne jest ciągłe dążenie do nauki właściwego sposobu robienia rzeczy.

programmx10
źródło
Interesujące, jesteś w mniejszości. Nie sądzisz, że czasami inni ludzie mogą się mylić?
Rob Stevenson-Leggett