-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: "Wojciech \"Spook\" Sura" <w...@o...com.pl>
Newsgroups: pl.comp.programming
Subject: Re: jaki wybrac jezyk?
Date: Tue, 16 Aug 2011 11:51:27 +0200
Organization: Optopol Technology
Lines: 118
Message-ID: <o...@l...medicom.local>
References: <2...@v...googlegroups.com>
<5...@n...onet.pl>
<a...@e...googlegroups.com>
<op.vz9ot2qr8x7o78@notebook>
<3...@h...googlegroups.com>
NNTP-Posting-Host: 207.162.akron.net.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=iso-8859-2; format=flowed; delsp=yes
Content-Transfer-Encoding: Quoted-Printable
X-Trace: inews.gazeta.pl 1313488305 19824 86.111.207.162 (16 Aug 2011 09:51:45 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Tue, 16 Aug 2011 09:51:45 +0000 (UTC)
X-User: spoko_ws
User-Agent: Opera Mail/11.50 (Win32)
Xref: news-archive.icm.edu.pl pl.comp.programming:191923
[ ukryj 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
- 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
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
Najnowsze wątki
- 2025-08-19 UWAGA na scam: diperson_com
- 2025-08-19 UWAGA na scam: diperson_com
- 2025-08-15 Co to za dziwne "białe namioty" co stawiają je w różnych dziwnych miejscach?!?
- 2025-08-11 Francuska elektrownia atomowa zamknięta. Powodem "nieprzewidywalny" rój meduz
- 2025-08-14 bateria 6000mAh
- 2025-08-11 ,,dwie za 25" - Gadająca papuga wsypała gang handlarzy narkotyków
- 2025-08-11 Zhakowano eSIMy! Ale (na razie) się nie martw
- 2025-08-18 ZIELONA ENERGIA ZARZYNA NIEMIECKĄ GOSPODARKĘ. GWIAZDOWSKI KOMENTUJE
- 2025-08-18 Estakada w Chorzowie
- 2025-08-15 otwarcie obwodnicy Lęborka
- 2025-08-14 zjebane małe ronda
- 2025-08-14 JAK NIE SPŁONĄĆ W ELEKTRYKU?
- 2025-08-14 Kostomłoty
- 2025-08-12 Ceny badań technicznych w górę i to już od września - nagłe przyspieszenie Ministerstwa!
- 2025-08-11 Transponder RFID