Komentáře
- Propojená otázka byla odstraněna.
- Myslím, že přístup je ve skutečnosti jednoduchý. Pokud jste jej vyvinuli sami, víte o něm všechno. Můžete dokonce opravit chybu bez ladění. S ohledem na to je nejlepší použít čas na kódování něčeho jiného, dokud někdo, kdo o tom ví hodně, neodpoví na vaši otázku, jak to opravit; nebo nechte odpočívat, kódujte jiné věci, dokud vám nenapadne nápad opravit to, abyste neztratili čas ani energii. Myslím, že vaše otázka se týká správy podnikového týmu.
- Myslím, že Raid. Běžný sprej na zabíjení brouků. Je to filozofická otázka? Knihy vznikají z pouhé převahy …
Odpověď
Myšlenka a přístup k ladění je možná nejdůležitější část, protože určuje, jak efektivně chybu opravíte a co se z ní naučíte – pokud vůbec.
Klasika v oblasti vývoje softwaru jako Pragmatický programátor a Code Complete v zásadě argumentují stejným přístupem: každá chyba je příležitost naučit se, téměř vždy o sobě (protože kompilátor / počítač obviňují pouze začátečníci).
Berte to tedy jako záhadu, kterou bude zajímavé prolomit. A prolomení této záhady by mělo být prováděno systematicky, vyjádřením našich předpokladů (pro sebe nebo pro ostatní) a následným testováním našich předpokladů, pokud je to nutné, jednotlivě – pomocí všech nástrojů, které máme k dispozici, zejména debuggerů a automatizovaných testovacích rámců. Poté, co bude záhada vyřešena, můžete si ještě lépe prohlédnout celý svůj kód a najít podobné chyby, které jste možná udělali; a napsat automatický test, aby se zajistilo, že k chybě nedojde nevědomky znovu.
Jedna poslední poznámka – raději nazývám chyby „chyby“ a ne „chyby“ – Dijkstra svým kolegům vynadal, aby použili druhý termín, protože je to nečestné, podporující myšlenku, že zlověstné a vrtkavé chybné víly zasadily do našich programů chyby, zatímco jsme se nedívali, místo abychom tam byli kvůli našemu (nedbalému) myšlení: http://www.cs.utexas.edu/users/EWD/transcriptions/EWD10xx/EWD1036.html
Mohli bychom například začít vyčistit náš jazyk již nevoláte chybu jako chybu, ale voláte ji jako chybu. Je to mnohem upřímnější, protože to dává vinu tam, kam patří, viz. s programátorem, který udělal chybu. Animistická metafora chyby, která se škodlivě vplížila dovnitř, když se programátor nedíval, je intelektuálně nečestná, protože maskuje, že chyba je vlastní tvorbou programátora. Pěknou věcí této jednoduché změny slovní zásoby je, že má tak hluboký účinek : zatímco dříve byl program s pouze jednou chybou „téměř správný“, poté byl program s chybou jen „špatný“ (protože omylem).
Komentáře
- Vlastně se mi líbí výraz " chyba " spíše než " chyba ", ne proto, že by to bylo na vině " programátoru kdo udělal chybu ", ale proto, že jasně ukazuje, že to nemohl ne zavinit programátor. Pro mě " chyba " implikuje chybu v kódu; zatímco " chyba r " implikuje chybu někde . Možná v kódu, možná v nastavení prostředí, možná v požadavcích. Přiměje mě to, když má můj šéf " seznam chyb ", kde polovinou problémů jsou změny požadavků. Říkejte tomu seznam úkolů, ferchrissakes!
- +1 pro " každá chyba je příležitostí se učit, téměř vždy o sobě (protože kompilátor viní pouze začátečníky / nejprve počítač) "
- Znáte historii pojmu " chyba ", že? Mám na mysli, jak se používá při vývoji softwaru. Dnes samozřejmě tento problém nemáme ' t, ale chyba ve skutečnosti vletěla do hardwaru počítače bez povšimnutí programátora a způsobila problém.Pokud si někdo myslí, že mě neopraví, vím, že Edison použil tento výraz dlouho před můrovým incidentem, a proto jsem použil slovo ' history ', ne ' origin '. Viz computerworld.com/article/2515435/app-development/… a en.wikipedia.org/wiki/Software_bug#Etymology
- @threed Samozřejmě. Hmyz však již nějakou dobu nezpůsobil naprostou většinu softwarových chyb.
Odpověď
-
Psát testy. Testování je nejen skvělé při prevenci chyb (podle mých zkušeností TDD provedeno správně eliminuje téměř všechny triviální, hloupé chyby), ale také hodně pomáhá při ladění. Testování nutí váš návrh být spíše modulární, což značně usnadňuje izolaci a replikaci problému. Také ovládáte prostředí, takže vás překvapí mnohem méně. Jakmile navíc získáte testovací případ, který vám propadne, můžete si být přiměřeně jisti, že jste přibili skutečný důvod chování, které vás obtěžuje.
-
Naučte se používat debugger.
print
příkazy mohou na určité úrovni fungovat přiměřeně dobře, ale debugger je většinou velmi užitečný (a jednou víte, jak jej používat, je to mnohem pohodlnější nežprint
prohlášení). -
Promluvte si o svém problému s někým, i když je to jen gumová kachnička . Když se budete nutit slovy vyjádřit problém, na kterém pracujete, opravdu zázraky.
-
Dejte si časový limit. Pokud například po 45 minutách máte pocit, že nikam nevedete, přepněte na nějakou dobu na jiné úkoly. Až se vrátíte k chybě, doufejme, že uvidíte další možná řešení, která byste dříve nezvažovali.
Komentáře
- +1 pro " Nutí vás vyjádřit problém, na kterém pracujete, slovy, dělá opravdu zázraky. "
- A přidat do (1), téměř každá chyba, kterou v kódu vidíte, znamená, že ' sa chyba – nebo alespoň opomenutí – v testovací sadě. Opravte oboje současně a nejen že prokážete, že jste ' opravili problém, jste ' v bezpečí proti jeho znovu zavedeno.
Odpověď
Líbí se mi většina ostatních odpovědí, ale zde je několik tipů, co dělat PŘED tím, než něco z toho uděláte. Ušetří vám čas na beaucoup.
-
Zjistěte, zda skutečně existuje chyba. Chyba je VŽDY rozdíl mezi chováním systému a požadavky; tester by měl být schopen formulovat očekávané a skutečné chování. Pokud není schopen poskytnout podporu očekávanému chování, není tam žádný požadavek a není tam žádná chyba – pouze názor někoho jiného. Zašlete jej zpět.
-
Zvažte možnost že očekávané chování je špatné. Mohlo by to být způsobeno nesprávnou interpretací požadavku. Mohlo by to být také způsobeno vadou samotného požadavku (delta mezi podrobným požadavkem a obchodním požadavkem). Můžete je také odeslat zpět.
-
Izolujte problém. Nejrychlejší způsob, jak to udělat, vás naučí pouze zkušenost – někteří lidé to dokáží téměř se svými vnitřnostmi. Jedním ze základních přístupů je změna jedné věci, zatímco zachování všech ostatních věcí konstantní (nastává problém v jiných prostředích? s jinými prohlížeči? v jiné testovací oblasti? v různých časech dne?) Dalším přístupem je podívat se na skládky zásobníku nebo chybové zprávy – někdy můžete říct jen mimochodem je naformátováno, která součást systému hodila původní chybu (např. pokud je to v němčině, můžete bla já, ta třetí strana, se kterou pracujete v Berlíně).
-
Pokud jste to zúžili na dva systémy, které spolupracují, zkontrolujte zprávy mezi těmito dvěma systémy pomocí sledování provozu nebo souborů protokolu , a určit, který systém se chová ke specifikaci a který ne. Pokud jsou ve scénáři více než dva systémy, můžete provádět párové kontroly a postupovat „dolů“ v zásobníku aplikací.
-
Důvod, proč je izolace problému tak důležitý je, že problém nemusí být způsoben vadou kódu, kterou máte pod kontrolou (např. systémy třetích stran nebo prostředí) a chcete, aby tato strana převzala kontrolu co nejrychleji. To vám má ušetřit práci a okamžitě je dostat na bod, aby bylo možné dosáhnout rozlišení v co nejkratším časovém rámci. Nechcete na problému pracovat deset dní, jen abyste zjistili, že je to opravdu problém s webovou službou někoho jiného.
-
Pokud jste zjistili, že skutečně existuje vada a je to skutečně v kódu, který ovládáte, můžete problém dále izolovat hledáním posledního „známého dobrého“ sestavení a kontrola protokolů řízení zdrojů, zda neobsahují změny, které mohly problém způsobit. To vám může ušetřit spoustu času.
-
Pokud to nemůžete zjistit z řízení zdroje, nyní je čas připojit debugger a projít kódem, abyste to zjistili je pravděpodobné, že už máte o problému docela dobrou představu.
Jakmile víte, kde je chyba, a můžete myslet na opravu, tady je dobré postup pro jeho opravu:
-
Napište test jednotky, který reprodukuje problém a selže.
-
Bez úpravy testu jednotky proveďte to projde (úpravou kódu aplikace).
-
Ponechejte test jednotky ve své testovací sadě, abyste zabránili / detekovali regresi.
Odpověď
Myslím, že je také důležitá reprodukce chyby. Mohou být uvedeny všechny případy, které reprodukují chybu, a poté můžete zajistit, aby oprava chyby zahrnovala všechny tyto případy.
Odpovědět
Na toto téma jsem si přečetl vynikající knihu s názvem Proč selhávají programy , která popisuje různé strategie pro hledání chyb, od použití vědecké metody až po izolaci a vyřešení bug, to delta debugging. Druhou zajímavou částí této knihy je, že odstraňuje pojem „chyba“. Zellerův přístup je:
(1) Programátor vytvoří v kódu vadu. (2) Vada způsobí infekci (3) Infekce se rozšíří (4) Infekce způsobí poruchu.
Pokud si chcete vylepšit své ladicí schopnosti, tuto knihu velmi doporučuji.
Podle vlastních osobních zkušeností jsem v naší aplikaci našel spoustu chyb, ale vedení nás jednoduše tlačí dál získat nové funkce. „Často jsem slyšel“ Tuto chybu jsme našli sami a klient si ji ještě nevšiml, takže ji nechte, dokud to neudělá. “ Myslím, že být reaktivní na rozdíl od proaktivního při opravě chyb je velmi špatný nápad, protože až přijde čas na opravu, máte další problémy, které je třeba vyřešit, a další funkce, které správa potřebuje, jsou hned za dveřmi, takže vás chytí v začarovaném cyklu, který může vést k velkému stresu a vyhoření, a v konečném důsledku k defektnímu systému.
Komunikace je také dalším faktorem, když jsou nalezeny chyby. Zaslání e-mailu nebo jeho zdokumentování na sledování chyb je v pořádku a dobře, ale podle mých vlastních zkušeností najdou ostatní vývojáři podobnou chybu a místo toho, aby znovu použili řešení, které jste vložili k opravě kódu (protože už na to všechno zapomněli), přidávají své vlastní verze, takže ve svém kódu máte 5 různých řešení a ve výsledku to vypadá více nafouklé a matoucí. Takže když opravíte chybu, ujistěte se, že několik lidí tuto opravu zkontroluje a dá vám zpětnou vazbu v případě, že opravili něco podobného a našel dobrou strategii, jak s tím zacházet.
Limist zmínil knihu,
Programátor Pragmatic , který má několik zajímavých materiálů k opravování chyb. Na příkladu, který jsem uvedl v předchozím odstavci, se podívám na toto: Software Entrophy , kde se použije analogie zlomené vdovy. Pokud jsou dvě zlomené objeví se okna, váš tým může být apatický k tomu, aby to kdykoli opravil, pokud nepřijmete proaktivní postoj.
Komentáře
- I ' Slyšeli jsme " Tuto chybu jsme našli sami a klient si ji ' ještě nevšiml, takže ji nechte, dokud dělají to " také mnohokrát. A při návštěvě webů si to klient často všiml , ale ' t to nahlásili. Někdy proto, že si myslí, že ' to nemá smysl, protože to nebude ' opraveno, někdy proto, že se již dívají na náhradu ' s náhradou a někdy (správně či nesprávně) " dobře, je to stejně hromada keců ".
- @JuliaHayward – To se velmi často stává, ale ve vaší situaci, vaši klienti mohou být s touto funkcí spokojeni a nemusí se příliš zajímat o to, co se ' děje pod kapotou. Problém se začíná projevovat, když se klient vrací s požadavkem na další funkce a je třeba přidat další vylepšení, například vytvořit aplikaci vícejazyčnou a kompatibilní s mobilními zařízeními bla bla bla, začnete se dívat na to, co máte, a uvidíte všechny trhliny ve zdi.
- Jen vám ukazuje, že všechny knihy na světě o designu softwaru, testování a dobré komunikaci a spousta produktů, na kterých pracujete, jsou rozlehlý nepořádek.Navzdory tomu, že víte, co je ' s právem, důvodem, proč je kód ve stavu, v jakém je, je stres a nerealistické termíny (tváří v tvář vašemu již pokazenému kódu). Sám na to ' nemám žádné odpovědi, ' jsem v kanceláři docela odlišen jako sténající obličej ***** * když kopu a křičím, abych udržel zdravý kód a vývojový proces hladký, ale někdy tým ' t se dobře nespája.
Odpověď
Chyba, chyba, problém, závada – jakkoli to chcete nazvat, nedělá to velký rozdíl. Budu se držet problému, protože „na co jsem zvyklý.“
- Zjistěte, jaké je vnímání problému: přeložit ze zákazníka „Bob stále není v systému“ na „Když se pokusím vytvořit uživatelský záznam pro Boba, selže s výjimkou duplicitních klíčů, ačkoli Bob už tam není „
- Zjistit, zda je to opravdu problém nebo jen nedorozumění (ve skutečnosti Bob není) Není tam nikdo, komu by se říkalo bob, a insert by měl fungovat).
- Pokuste se získat minimální spolehlivé kroky, kterými můžete problém reprodukovat – něco jako „Vzhledem k systému se záznamem uživatele„ Bruce “, když je vložen záznam uživatele„ Bob “, dojde k výjimce.
- Toto je váš test – pokud je to možné, vložte jej do automatizovaného testovací postroj, který můžete spustit znovu a znovu, bude to při ladění neocenitelné. Můžete jej také zahrnout do své testovací sady, abyste se ujistili, že se daný problém později znovu neobjeví.
- Vyjměte debugger a začněte uvádět zarážky – při spuštění testu zjistěte cestu ke kódu, a zjistit, co se děje. I když to uděláte, můžete také svůj test vylepšit tak, aby byl co nejužší – nejlépe test jednotky.
- Opravte to – ověřte, zda testy úspěšně prošly.
- Ověřte původní problém jak je popsáno zákazníkem, je také opraveno (velmi důležité – možná jste právě opravili podmnožinu problému). Ověřte, že jste nezaváděli regrese v jiných aspektech programu.
Pokud jste velmi dobře obeznámeni s kódem nebo pokud je problém nebo oprava zřejmá, můžete některé z nich přeskočit kroky.
Jak bychom k tomu měli přistupovat, abychom co nejefektivněji využili náš drahocenný čas a umožnili nám trávit méně času jeho hledáním a více času kódováním ?
Beru s tím problém, protože to znamená, že psaní nového kódu je hodnotné než mít vysoce kvalitní pracovní program. Není nic špatného na tom, že řešení problémů je co nejefektivnější, ale program se nemusí nutně zlepšit pouhým přidáním dalšího kódu.
Komentáře
- toto je nejlepší odpověď IMO
odpověď
takto to dělám:
- k nalezení problému použijte vždy stejnou metodu. Tím se zlepší vaše reakční doba na chyby.
- Nejlepší způsob je pravděpodobně číst kód. Je to proto, že všechny informace jsou k dispozici v kódu. Potřebujete pouze efektivní způsoby, jak najít správnou pozici a schopnost porozumět všem podrobnostem.
- ladění je velmi pomalý způsob a je to nutné pouze v případě, že vaši programátoři dosud nerozumí tomu, jak počítač provádí pokyny asm / nerozumí zásobníku volání a základní věci
- Pokuste se vyvinout kontrolní techniky, jako je použití funkčních prototypů k odůvodnění chování programu. Pomůže to rychleji najít správnou pozici
Odpovědět
Když zjistíme chybu v našem kódu, co můžeme udělat, abychom ji odstranili? Jak bychom k tomu měli přistupovat, abychom co nejefektivněji využili náš drahocenný čas a umožnili nám trávit méně času jeho hledáním a více času kódováním? Čemu bychom se měli při ladění vyhnout?
Za předpokladu, že se nacházíte v produkčním prostředí, je třeba udělat toto:
-
Popište správně „chybu“ a identifikujte události, které ji způsobují.
-
Zjistěte, zda je „chyba“ chybou kódu, nebo chyba specifikace. Například zadání 1 písmenného názvu může být považováno za chybu některých systémů, ale přijatelné chování pro jiné systémy. Uživatel někdy ohlásí chybu, o které si myslí, že je problém, ale očekávání uživatele na chování systému nebylo součástí požadavků.
-
Pokud prokázali, že došlo k chybě a chyba je způsobena kódem, můžete určit, které části kódu je třeba opravit, aby se zabránilo chybě. Zkoumat také vliv chování na aktuální data a budoucí operace systému (analýza dopadu na kód a data).
-
V tomto okamžiku byste pravděpodobně měli odhad, kolik zdrojů bude spotřebováno na opravu chyby. Můžete to opravit hned nebo naplánovat opravu v nadcházejícím vydání softwaru.Závisí to také na tom, zda je koncový uživatel ochotný za opravu zaplatit. Měli byste také vyhodnotit různé dostupné možnosti k opravě chyby. Může existovat více než jeden způsob. Musíte vybrat přístup, který nejlépe vyhovuje situaci.
-
Analyzujte důvody, které způsobily vznik této chyby (požadavky, kódování, testování atd.). Vynutit procesy, které by zabránily opakování stavu.
-
Epizodu adekvátně zdokumentujte.
-
Uvolněte opravu (nebo nová verze)