-
Data: 2011-08-16 09:51:27
Temat: Re: jaki wybrac jezyk?
Od: "Wojciech \"Spook\" Sura" <w...@o...com.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Dnia 15-08-2011 o 21:46:29 Maciej Sobczak <s...@g...com>
napisał(a):
>> *W tym kontekście* absolutnie zgadzam się ze stwierdzeniem, że wJavie
>> robi się mniej błędów.
>
> Otóż nie, to nie przeszkadza w robieniu błędów. Ten mechanizm je co
> najwyżej wykrywa. W run-time. Nic nie stoi na przeszkodzie, żeby
> wysłać klientowi program z błędem i w tym kontekście uważam, że Java
> nie wnosi istotnego postępu w dziedzinie poprawności.
Ok, może w przypadku testowania zakresów tablic tak. Ale popatrz na taki
przypadek:
switch (myEnum)
{
case enVal1:
{
x = someOtherVarX / 2.0f;
y = someOtherVarY / 2.0f;
}
default:
{
x = NaN;
y = NaN;
}
}
W C++ powyższy kod się skompiluje i będzie działał zgodnie z tym, co
programista napisał (choć raczej niezgodnie z tym, co zamierzał). W C#
próba kompilacji takiego kodu skończy się błędem (w Javie, natomiast,
przejdzie).
Zmierzam do tego, że - choć język jako taki nie może wykluczyć powstawania
błędów - to jednak istnieją takie jego konstrukcje, które znacznie
zmniejszają prawdopodobieństwo posadzenia takiego buraka, jak w powyższym
przykładzie (chodzi mi o ogólną zasadę, a nie o ten czy inny konkretny
przypadek).
W końcu zarówno Java jak i C# wyewoluowały z C++, co dało projektantom
szansę poprawienia niektórych językowych konstrukcji.
W dyskusji wspominana jest Ada. Nie znam tego języka, ale czytałem o nim
kiedyś, że jest pełen nadmiarowych konstrukcji językowych - na przykład
koniec bloku wymaga informacji, jaki to był blok (np. END PROCEDURE).
Przymus kończenia bloku case instrukcją break, goto lub return w C# jest w
pewnym sensie nadmiarowy, ale znacząco ogranicza możliwość popełnienia w
tym miejscu błędu. Wydaje mi się, że istnieje silna zależność pomiędzy
stosunkiem szybkości i wygody pisania w danym języku a jego
błędogennością. Niedawno nadziałem sie na C++owe max, które wywołane dla
parametrów rand() - 2 i 0 zwróciło nagle -1. W Delphi, C# i Javie nie da
się napisać odpowiednika C++owego makra, które w konkretnych
okolicznościach może działać niezgodnie z założeniami. Niemożność
stosowania makr w pewnym stopniu utrudnia pisanie, ale z drugiej strony
eliminuje możliwość popełnienia trudnego do zlokalizowania błędu.
W C++ można bardzo łatwo strzelić sobie w stopę trzymając w jednej ręce
komplet tomów encyklopedii Britannica, a w drugiej - średniej wielkości
piłkę plażową. Ale na przykład w C# trzeba już mieć na wyposażeniu karabin
snajperski :)
Pozdrawiam -- Spook.
--
Używam klienta poczty Opera Mail: http://www.opera.com/mail/
Następne wpisy z tego wątku
- 16.08.11 13:38 A.L.
- 16.08.11 20:27 Maciej Sobczak
- 16.08.11 20:29 Adam Przybyla
- 16.08.11 21:24 m...@t...pl
- 16.08.11 21:31 m...@t...pl
- 17.08.11 04:30 Maciej Pilichowski
- 17.08.11 05:23 m...@t...pl
- 17.08.11 06:11 Michal Kleczek
- 17.08.11 08:29 Stachu 'Dozzie' K.
- 17.08.11 08:12 Artur M. Piwko
- 17.08.11 09:55 Edek
- 17.08.11 10:01 Michal Kleczek
- 17.08.11 12:12 Stachu 'Dozzie' K.
- 17.08.11 12:15 Marcin Biegan
- 17.08.11 12:41 Paweł Kierski
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-22 Gdańsk => System Architect (Java background) <=
- 2025-01-22 Katowice => Senior Field Sales (system ERP) <=
- 2025-01-22 Warszawa => Java Developer <=
- 2025-01-22 pokolenie Z
- 2025-01-22 Wyświtlacz ramki cyfrowej
- 2025-01-22 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A
- 2025-01-22 Chrzanów => Team Lead / Tribe Lead FrontEnd <=
- 2025-01-22 Ostrów Wielkopolski => Konsultant Wdrożeniowy Comarch XL/Optima (Ksi
- 2025-01-22 oferta na ubezpieczenie OC życie prywatne
- 2025-01-22 Bieruń => Spedytor Międzynarodowy (handel ładunkami/prowadzenie flo
- 2025-01-22 Warszawa => International Freight Forwarder <=
- 2025-01-22 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-21 Zgromadzenie użytkowników pojazdów :-)
- 2025-01-21 bateria na żądanie
- 2025-01-21 Warszawa => IT Business Analyst <=