-
Data: 2012-03-28 16:11:10
Temat: Re: wydajnosc wyjatkow
Od: Edek Pienkowski <e...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-05-26 O co chodzi?
- 2024-05-26 PJ autobus-tramwaj
- 2024-05-26 Renault Trafic i lampka z czerwonym STOP
- 2024-05-26 cena pięciocyfrowa
- 2024-05-26 Re: Jak dobra KE "okrada" złą Rosję "dla Ukrainy"
- 2024-05-25 supercap
- 2024-05-25 Sulzbach => Technischer Rollouter (d/m/w) <=
- 2024-05-25 Warszawa => Senior Account Manager <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Interactive/Experience Designer <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Re: znów ten wrocław