-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: "M.M." <m...@g...pl>
Newsgroups: pl.comp.programming
Subject: wydajnosc wyjatkow
Date: Wed, 28 Mar 2012 06:51:52 +0000 (UTC)
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 44
Message-ID: <jkuce7$3sv$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 1332917512 3999 172.20.26.238 (28 Mar 2012 06:51:52 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Wed, 28 Mar 2012 06:51:52 +0000 (UTC)
X-User: mariotti
X-Forwarded-For: 89.229.34.123
X-Remote-IP: localhost
Xref: news-archive.icm.edu.pl pl.comp.programming:196412
[ ukryj nagłówki ]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
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 28.03.12 10:54
- 28.03.12 12:02 M.M.
- 28.03.12 13:04 Edek Pienkowski
- 28.03.12 15:32 M.M.
- 28.03.12 16:11 Edek Pienkowski
- 28.03.12 17:47
- 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
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-06 Jeździ, skręca, hamuje
- 2025-01-06 Białystok => System Architect (Java background) <=
- 2025-01-06 Gliwice => Specjalista ds. public relations <=
- 2025-01-06 Białystok => Solution Architect (Java background) <=
- 2025-01-06 Zielona GĂłra => Konsultant WdroĹźeniowy Comarch XL/Optima (KsiÄgowoĹ
- 2025-01-06 Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- 2025-01-06 Ostrów Wielkopolski => Area Sales Manager OZE <=
- 2025-01-06 Do IO i innych elektrooszolomow, tu macie prawdziwe smrody
- 2025-01-06 Białystok => Full Stack .Net Engineer <=
- 2025-01-06 Kraków => Business Development Manager - Network and Network Security
- 2025-01-06 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-01-06 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-06 Lublin => Programista Delphi <=
- 2025-01-06 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-06 śnieg