-
Data: 2012-06-14 09:28:39
Temat: Re: Czym jest programowanie?
Od: Maciej Sobczak <s...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 14 Cze, 06:38, Andrzej Jarzabek <a...@g...com> wrote:
> Z Adą nie jest przypadkiem tak, że wymusza dodatkowe runtime checks w
> celu uniknięcia undefined behaviour?
Z Adą jest tak, że *jeśli* masz sytuację wyjątkową, to ma być wyjątek.
Nie znaczy to wcale, że w kodzie zawsze musi być check. To, co Adę
odróżnia od Javy to znacznie bogatszy system typów i znacznie bardziej
rozbudowane reguły języka, które pozwalają kompilatorowi na statyczne
stwierdzenie, że skoro sytuacja wyjątkowa nie wystąpi, to nie trzeba
wstawiać run-time checków.
Koncepcyjnie nie jest to wielka filozofia. Przykład w Javie:
for (int i = 0; i < myArray.length; ++i) {
System.out.println(myArray[i]);
}
To jest pattern, który kompilator może rozpoznać jako bezpieczny i
wtedy nie ma potrzeby wstawiać checków w miejscu indeksowania. Podobno
kompilator Javy z tego korzysta. Problem z Javą polega na tym, że w
zasadzie to jest również granica tego typu działań, bo system typów
jest tak żałosny (właściwie można go określić mianem "skryptowy"), że
nic więcej nie wiadomo. Czy w tablicy są nulle? Czy te obiekty są
niezależne, czy może są wzajemnie poaliasowane? Itd.
Ada pozwala zapisać w typach i w kodzie znacznie więcej informacji,
więc kompilator ma też znacznie większe możliwości redukcji checków. W
praktyce i przy właściwym wykorzystaniu języka checki są wstawiane
tylko tam, gdzie naprawdę muszą, czyli np. przy rzutowaniu typów, przy
odczycie z I/O, itp.
Checki w Adzie można też lokalnie bądź globalnie wyłączyć, z
oczywistymi konsekwencjami.
Istnieje też powiązany z Adą język SPARK, w którym w ogóle nie ma
wyjątków, bo język gwarantuje, że nie ma sytuacji wyjątkowych, które
normalnie wymagalyby run-time checka.
--
Maciej Sobczak * http://www.msobczak.com * http://www.inspirel.com
Następne wpisy z tego wątku
- 14.06.12 10:18 Roman W
- 14.06.12 10:16 Roman W
- 14.06.12 11:23 Edek Pienkowski
- 14.06.12 12:31 Wojciech Muła
- 14.06.12 15:28 Maciej Sobczak
- 14.06.12 16:35 Roman W
- 14.06.12 16:51 Wojciech Muła
- 14.06.12 17:34 AK
- 14.06.12 17:52 Roman W
- 14.06.12 20:00 slawek
- 14.06.12 20:20 slawek
- 14.06.12 20:23 slawek
- 14.06.12 20:25 slawek
- 14.06.12 20:28 slawek
- 14.06.12 20:32 noma
Najnowsze wątki z tej grupy
- Alg. kompresji LZW
- 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??
Najnowsze wątki
- 2025-03-12 Ryga => Konsultant Wdrożeniowy Comarch XL/Optima (Księgowość i Kad
- 2025-03-12 Poznań => Konsultant wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-03-12 Warszawa => Programista C <=
- 2025-03-12 Chrzanów => Spedytor Międzynarodowy (handel ładunkami/prowadzenie f
- 2025-03-12 64 proc. kierowców zrobi dodatkowo maks. 500 m, aby przy okazji zatankować pojazd
- 2025-03-12 Warszawa => Generative AI Engineer <=
- 2025-03-12 Dęblin => Node.js / Fullstack Developer <=
- 2025-03-12 Warszawa => Gen AI Engineer <=
- 2025-03-12 Warszawa => Data Engineer (Tech Lead) <=
- 2025-03-12 Gdańsk => PHP Developer <=
- 2025-03-12 China-Kraków => Production Coordinator / Representant Product Dev <=
- 2025-03-12 Warszawa => JavaScript / Node / Fullstack Developer <=
- 2025-03-12 China-Kraków => Key Account Manager IT <=
- 2025-03-12 Warszawa => Java Developer <=
- 2025-03-12 Warszawa => Junior Digital Product Manager <=