-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: " " <f...@g...pl>
Newsgroups: pl.comp.programming
Subject: Re: wydajnosc wyjatkow
Date: Wed, 28 Mar 2012 15:47:34 +0000 (UTC)
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 71
Message-ID: <jkvbqm$tq$1@inews.gazeta.pl>
References: <jkuce7$3sv$1@inews.gazeta.pl> <jkujkr$f6k$1@inews.gazeta.pl>
<jkunjr$1dq$1@inews.gazeta.pl>
NNTP-Posting-Host: localhost
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: 8bit
X-Trace: inews.gazeta.pl 1332949654 954 172.20.26.242 (28 Mar 2012 15:47:34 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Wed, 28 Mar 2012 15:47:34 +0000 (UTC)
X-User: fir
X-Forwarded-For: 31.62.36.199
X-Remote-IP: localhost
Xref: news-archive.icm.edu.pl pl.comp.programming:196421
[ ukryj nagłówki ]M.M. <m...@g...pl> napisał(a):
> <f...@g...pl> napisał(a):
>
> > M.M. <m...@g...pl> napisał(a):
> >
> > > Czesc
> > >
> > > Kiedyś dawno z lat temu 10 albo jeszcze dawniej, przeczytałem
> > > straszną rzecz o wyjątkach w C++. Pisał sam Lippman więc się trochę
> > > przejąłem. Pisał on mianowicie że po włączeniu wyjątków skompilowany
> > > program nie zmieścił się w pamięci ram. Nie zastanawiając się głębiej
> > > uznałem że wyjątki wiążą się z jakimś narzutem i gdy była ważna
> > > szybkość działania programu to ich nie używałem.
> > >
> > > Teraz gdy się zastanawiam to wydaje mi się kompletnie bezsensowne aby
> > > wyjątki wiązały się z jakimś dużym narzutem. Do czego ten narzut niby
jest
> > > potrzebny?
> > >
> > > Gdy kompilator napotyka instrukcję try to co musi zrobić? Moim zdaniem
> > > musi gdzieś zapamiętać adres wejścia do sekcji catch. Coś takiego
> > > chyba najlepiej zapamiętać na jakimś stosie. Więc dużo zależy od tego
> > > jak stos jest realizowany. Jeśli odkładanie elementu na stos jest
> > > związane z malloc to mamy narzut taki sam jaki narzut ma malloc. Jeśli
> > > stos jest budowany bez malloc to narzut jest pomijalny, wystarczy tylko
> > > zapamiętać trochę danych, może z 20-30 bajtów.
> > >
> > > Gdy kompilator napotyka koniec sekcji catch to co musi zrobić? Chyba
tylko
> > > musi usunąć ze stosu to co wcześniej na nim zapamiętał. Więc o
wydajności
> > > decyduje sposób w jaki to kompilator zapamiętuje.
> > >
> > > A co gdy kompilator napotyka throw Object? Zdaje się że musi odczytać
> > > kolejno zapamiętane informacje przy napotkaniu try. Jeśli znajdzie
> > > pasujący catch( Object ) to musi odtworzyć stos pointer. Potem na stos
> > > odkłada Object i musi zrobić long jump do odpowiedniego catch.
> > >
> > > Jednak wyjatki rzadko sie uaktywniają. Najczęściej mamy
> > > if( false ) throw Object. Czy kompilator jak widzi ze w
> > > procedurze jest throw Object to musi wygenerować jakiś
> > > kod który się wykona pomimo że wyjątek nie będzie rzucony?
> > > Moim zdaniem nie musi.
> > >
> > > Gdzie tu jest problem z wydajnością, albo z ogromną pamięcią? Nie
> > > mogę się doszukać. Lippman bzdury pisał czy ja czegoś nie rozumiem?
> > >
> > > Pozdrawiam
> > >
> > >
> > a ja od dawna sie zastanawiam jak upewnic sie (na 100%) ze kompilator
> > nie wstawia mi jakiegos spowolnienia zwiazanego z obsluga wyjatkow
> > (ktorych nie uzywam), czy zajrzenie do zrodla w asmie i nie
> > dostrzezenie tam nic dziwnego (bez co prawda wglebiania sie
> > w dokladnie czytanie) to gwarancja, ze nie mam zadnych wiazacych sie
> > z tym spowolnien? (pewnie tak bo jakies grzebanie w prologach i epilogach
> > to bym pewnie zauwazyl)
>
> Można napisać jakiś program i zmierzyć czasy wykonania. Jeśli nikt nie
> odpowie to tak zrobię :)
> Pozdrawiam
>
>
trzeba przeczytac w necie jest raczej duzo info - sam moge odpowiedziec
jak przeczytam (tyle ze troche pozniej bo wlasnie wrocilem z malej
wloczego balangi (ostatnio trace duzo czasu) i jestem b zmeczony)
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 28.03.12 19:43
- 29.03.12 09:01
- 29.03.12 10:39
- 30.03.12 15:24 Adam Wysocki
- 30.03.12 15:49 M.M.
- 30.03.12 18:56 bartek szurgot
- 30.03.12 20:54
- 28.03.12 09:00 Roman W
- 28.03.12 12:18 Krzysiek Kowaliczek
- 29.03.12 19:23 Tomasz D
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-01-13 Zasięg Tesli przy szybszej jeździe
- 2025-01-13 Gdańsk => Application Security Engineer <=
- 2025-01-13 Białystok => System Architect (Java background) <=
- 2025-01-13 Warszawa => Konsultant ds. sprzedaży <=
- 2025-01-13 Warszawa => Key Account Manager <=
- 2025-01-13 Szczecin => Senior Field Sales (system ERP) <=
- 2025-01-13 Rzeszów => International Freight Forwarder <=
- 2025-01-13 Bydgoszcz => Specjalista ds. Sprzedaży (transport drogowy) <=
- 2025-01-13 Poznań => Konsultant wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-01-13 Warszawa => Staż w dziale Sprzedaży B2B <=
- 2025-01-13 Wydajność klimy w obecnych temperaturach
- 2025-01-13 Błonie => Analityk Systemów Informatycznych (TMS SPEED) <=
- 2025-01-13 Kraków => UX Designer <=
- 2025-01-13 Katowice => Key Account Manager (ERP) <=
- 2025-01-13 Mińsk Mazowiecki => Spedytor Międzynarodowy <=