-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: Edek Pienkowski <e...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: wydajnosc wyjatkow
Date: Wed, 28 Mar 2012 14:11:10 +0000 (UTC)
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 73
Message-ID: <jkv65u$qqb$1@inews.gazeta.pl>
References: <jkuce7$3sv$1@inews.gazeta.pl> <jkur6v$bke$1@inews.gazeta.pl>
<jkv3tb$q0$1@inews.gazeta.pl>
NNTP-Posting-Host: 213.241.90.114
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
X-Trace: inews.gazeta.pl 1332943870 27467 213.241.90.114 (28 Mar 2012 14:11:10 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Wed, 28 Mar 2012 14:11:10 +0000 (UTC)
X-User: pieniekusenet
User-Agent: Pan/0.135 (Tomorrow I'll Wake Up and Scald Myself with Tea; GIT 30dc37b
master)
Xref: news-archive.icm.edu.pl pl.comp.programming:196420
[ ukryj nagłówki ]Dnia Wed, 28 Mar 2012 13:32:27 +0000, M.M. napisal:
> Edek Pienkowski <e...@g...com> napisał(a):
>
>> Musi być kod robiący wszystko to, co jest przewidziane. W C++ oznacza
>> to destrukcję lokalnych obiektów, sprawdzenie catch-clauses i
>> unexpected-handlera, poza samym stack unwind.
> No tak, ale to wszystko musi także wykonać bez wyjątków w
> momencie gdy napotyka return?
No nie w tym samym miejscu, mniej optymalizowalne, w skrócie
trochę się to różni:
OnStack s1();
call_meth();
OnStack s2();
...
Jeżeli call rzuci, to musi tylko s1 skasować.
Jeżeli nie używa się wyjątków, kompilowanie z wyjątkami
generuje kod "skasuj tylko s1". Czy jakoś tak, chodzi mi
raczej o ogólną zasadę niż konkretnie o ten przykład.
> Hmmm a tak na marginesie gdy napotyka
> longjump to co robi? Też robi destrukcje obiektów na stosie?
Na mojej mapie longjmp jest tam gdzie mieszkają smoki.
>
>
>> > 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.
>
>
>> (?) Nie kompiluje mi się to co napisałeś.
> Nie wiem dokładnie jak nowoczesne kompilator/optymalizatory realizują obsługę
> wyjątków. Wyobrażam sobie to jako jakąś strukturę stosową. Gdy
> wykonanie programu dochodzi do sekcji try to na tą strukturę odkładana
> jest jakaś informacja. Więc gdy wykonanie programu dojdzie do końca
> sekcji catch to coś z tej struktury stosowej musi zdjąć. Jest to
> związane z jakimś narzutem. Nie wiem na pewno, ale wydaje się że ów
> narzut jest bardzo mały.
Te implementacje które znam działają inaczej. Stos jest właściwie
taki sam jak bez wyjątków; wyjątki robią procedurę zwijania stosu
aż znajdą odpowiedni handler.
Polecam wikipedię, sam poczytam o innych implementacjach, bo wiem
że istnieją inne.
>
>> Sam fakt, że wyjątek ma stos zmienia optymalizacje. W c++
>> stos zależy od optymalizacji; w Javie generalnie nie, ale czasami
>> tak.
> Hmmmm zapewne tak. Ale czy to nie jest podobne utrudnienie optymalizacji
> dla kompilatora jak po dodaniu instrukcji if? Kompilator generuje gorszy
> kod gdy są wyjątki?
Jeżeli w kodzie nie ma wyjątków a kompiluje się z wyjątkami, jest
trosecke niepotrzebnego kodu. Ten kod nie powinien za bardzo
spowalniać, powinien być traktowany jako slow-path.
W sumie ciekawe pytanie, nie wiem, ale cokolwiek się napisze
ma wpływ na optymalizacje (poza abstraction penalty, które już
od dość dawna prawie nie istnieje).
Edek
Następne wpisy z tego wątku
- 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
- 29.03.12 19:23 Tomasz D
Najnowsze wątki z tej grupy
- Xiaomi [Chiny - przyp. JMJ] produkuje w całkowitych ciemnościach i bez ludzi
- Prezydent SZAP/USONA Trump ułaskawił prezydenta Hondurasu Hernandeza skazanego na 45 lat więzienia
- Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Re: Najgorszy język programowania
- NOWY: 2025-09-29 Alg., Strukt. Danych i Tech. Prog. - komentarz.pdf
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
Najnowsze wątki
- 2026-01-25 rozmiar skrzyżowania
- 2026-01-24 Do czego prowadzą REGULACJE opiekuńczego państwa
- 2026-01-23 Stop na zielonym
- 2026-01-23 KSEFowy trolling
- 2026-01-23 KSEFowy trolling
- 2026-01-23 Warszawa => Software Development Team Leader (C#/.Net) <=
- 2026-01-23 Toruń => Sales Engineer (Database background) <=
- 2026-01-23 Toruń => Preseles Inżynier (background baz danych) <=
- 2026-01-23 antena gsm - kabel - antena gsm
- 2026-01-22 Złomnik ty pisowska SZMATO! ;-)
- 2026-01-22 PID - jeszcze raz
- 2026-01-22 konkret24.tvn24.pl "gwarantuje": za SAMO wylanie gnojówki pod domem tusk-ministra aresztu nie będzie! ;-)
- 2026-01-22 Prawo na wesoło: nakaz rozbiórki "dwóch przyczep samochodowych" jako budynku ;-)
- 2026-01-22 Airtagi
- 2026-01-22 Warszawa => Full Stack Developer (Go/React) <=




Nowa era rynku nieruchomości: 9 prognoz na 2026 rok