-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!newsgate.m10r2.
onet.pl!niusy.onet.pl
From: m...@t...pl
Newsgroups: pl.comp.programming
Subject: Re: kwestia estetyczna
Date: Sun, 07 Aug 2011 23:22:48 +0200
Organization: Onet.pl
Lines: 83
Sender: n...@n...onet.pl
Message-ID: <4...@n...onet.pl>
References: <r...@4...com>
NNTP-Posting-Host: newsgate.m10r2.onet.pl
Mime-Version: 1.0
Content-Type: text/plain; charset="iso-8859-2"
Content-Transfer-Encoding: 8bit
X-Trace: newsgate.onet.pl 1312752168 19946 213.180.150.14 (7 Aug 2011 21:22:48 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Sun, 7 Aug 2011 21:22:48 +0000 (UTC)
Content-Disposition: inline
X-Mailer: http://niusy.onet.pl
X-Forwarded-For: 89.229.34.123, 10.174.28.51
X-User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:5.0) Gecko/20100101 Firefox/5.0
Xref: news-archive.icm.edu.pl pl.comp.programming:191747
[ ukryj nagłówki ]
> Single Entry Point, Single Exit Point Style
> A piece of code is likely to be more easily understood if it has only
> one entry point (at the top of its listing) and only one exit point at
> (or near, e.g., a return statement just before the closing "}" of a
> non-void C++ function) the bottom of its listing. In C++, this
> philosophy has the following implications:
Czasami to jest racja a czasami bez sensu. Czesto czuje duzy
komfort jesli ciag instrukcji ktorego dotyczy if jest krotki, w
szczegolnosci gdy sprowadza sie do jednej instrukcji return.
Jesli mamy:
if( warunek ) {
instrukcje;
}
to oczy zwyczajnie sie mecza przy w wyszukiwaniu klamry
zamykajacej. Nawet gdy procedura ma 20-30 wierszy to
jest meczace.
W takim kodzie:
if( ! warunek )
return;
instrukcje;
szybciej widze i rozumiem cale(!) przeznaczenie tego ifa.
Moze to zalecenie pochodzi z czasow gdy trzeba bylo zamykac
pliki, zwalniac pamiec, itd? Wtedy owszem w przy kilku
punktach wyjscia trudniej zapanowac nad zwalnianiem zasobow.
Dzis sa jezyki w ktorych pamiec i uchwyty plikow niewiele
mnie obchodza. A moze ten kto to zalecal mial wyjatkowy
dryg do liczenia klamerek? Ja takiego nie mam, myle sie i
mecze, musze korzystac z ulatwien.
> Don't use goto statements. If the target of a goto is not at the start
Instrukcja goto to jeszcze inna sprawa... srednio uzywam jej raz
na rok, nie wiem dlaczego... jak czuje ze trzeba uzyc goto to uzywam i
tyle.
> In general, it's wise to keep every subprogram (in C++, every
> function, including main) short. A reader typically tries to
> understand one function at a time, so keeping functions short makes
> them more "digestable." A classical guideline: a maximum of 25 lines
> of code, what used to be the maximum viewable on a computer screen
> using a typical text editor. Today's screens often show more than 25
> lines, and I won't send a student to the guillotine for a 26th line,
> but if you're in excess of 30, there's probably a natural way to
> abbreviate your function, perhaps by extracting one or more blocks of
> its code as (a) separate function(s).
No ale co z tego ze moge wydzielic z jednej procedury 10-30 blokow?
Na czytelnosci nie zyskam nic. Na bezpieczenstwie nic. Wydajnosci
nie potrzebuje. Co za roznica czy mam 30 funkcji czy jedna funkcje
z 30-ma blokami? Przypomne ze mowie o funkcji ktora nie ma nawet
jednej petli, nie wspominajac o danych lokalnych. Sterowanie leci z
gory do dolu, wykonywane sa kolejne testy, jak test nie przechodzi
to jest return. Sa przypadki gdzie podzial na 30 funkcji powoduje
tylko klopot - chocby wymyslenie sensowych nazw dla funkcji. No
chyba ze zrobie bez sensownych nazw, wtedy moze nie pomyle sie
przy kolejnosci wywolania, bo po numerkach latwiej poznac:
Funkcja1() {
}
Funckcja2() {
}
...............
FunkcjaN() {
}
Funkcja() {
if( ! Funkcja1() ) return 1;
if( ! Funkcja2() ) return 2;
if( ! FunkcjaN() ) return N;
}
Zysk z takiego czegos jest zerowy, taki sam zysk mam z dwoch wolnych
wierszy pomiedzy blokiem instrukcji.
Pozdrawiam
--
Wysłano z serwisu OnetNiusy: http://niusy.onet.pl
Następne wpisy z tego wątku
- 07.08.11 21:35 A.L.
- 08.08.11 08:03 m...@t...pl
- 08.08.11 13:27 A.L.
- 08.08.11 14:56 Adam Przybyla
- 08.08.11 16:30 Paweł Kierski
- 08.08.11 17:40 A.L.
- 08.08.11 17:41 A.L.
- 08.08.11 19:14 Adam Przybyla
- 08.08.11 19:51 Waldek M.
- 08.08.11 20:20 m...@t...pl
- 08.08.11 21:35 A.L.
- 09.08.11 04:25 Waldek M.
- 09.08.11 19:53 p...@p...onet.pl
- 10.08.11 14:41 Wojciech Muła
- 10.08.11 18:23 R. P.
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-02-01 Śmierć mózgu a narządy do pobrania
- 2025-01-31 A niektórym to naprawdę zależy na ekologi w miastach LPG POWRACA ;-)
- 2025-01-31 Lublin => Programista Delphi <=
- 2025-01-31 Łódź => Programista NodeJS <=
- 2025-01-31 Wrocław => Senior SAP Support Consultant (SD) <=
- 2025-01-31 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2025-01-31 Gdańsk => iOS Developer (Swift experience) <=
- 2025-01-31 Kraków => UX Designer <=
- 2025-01-31 Warszawa => Data Engineer (Tech Leader) <=
- 2025-01-31 Gliwice => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2025-01-31 Gliwice => Business Development Manager - Network and Network Security
- 2025-01-31 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-01-31 Warszawa => Full Stack .Net Engineer <=
- 2025-01-31 Warszawa => Programista Full Stack (.Net Core) <=
- 2025-01-31 Gdańsk => Programista Full Stack .Net <=