-
Data: 2017-01-27 23:40:42
Temat: Re: Czas na Windows 10
Od: Sebastian Biały <h...@p...onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 2017-01-27 22:55, slawek wrote:
>> C++ w programie na linuxa.
> Czyli języku bez GC i bez maszyny wirtualnej. W którym błąd "null
> pointer" wywołuje panikę programistów.
Nie bądź zdziwiony. Tutaj jest o tym mowa. Zaryzykuje również że jeśli
mowa o Linuxie to 95% softu takie jest. Zastanawiające że próbujesz
zachowac twarz uciekając w jezyki z GC skoro była jasno mowa o Linuxie.
Za chwile się okaże że wzrocowa jest maszyna wirtualna javy bo przecież
wątek jest o Javie. A jest, nie?
> Owszem. Tyle że - jak już misiu nauczysz się jak wygląda obsługa
> wyjątków w Javie/C#/Delphi a nawet C++ - wytegolenie się połowy programu
> nie oznacza że program musi przestać działać.
Wyjątki w C++ znam w szczegółach, czesto debuguje cieżkie przypadki i
bywa że robie to na poziomie asm. Jako misio nie zauważyłem aby C++
łapał try catch wyjątki dereferencji nulla. Być może w paralernym
wszechświecie w którym istniejesz. Tak, są implementacje C++ które
pozwalają łapać wyjątki systemowe przez niestandardowe rozszerzenia. Nie
mają za dużego związku z C++ i nie powodują że algorytm z automatu da
się popchnąc dalej. W zasadzie są dośc katastrofalne w skutkach ponieważ
zazwyczaj byle jak lub zupełnie nie zwijają stosu zostawiając stos w
stanie niestabilnym. RAII idzie do piachu.
> Zwłaszcza jeżeli jest
> event driven. Dla przykładu: null pointer bo nie ma drukarki, ale
> przecież nie musisz drukować jak nie ma drukarki. Ważne aby dało się
> dane zapisać. I gdy już podłączysz drukarkę dostaniesz drugą szansę...
> śliczny pointer nie null. I to bez przerwy w działaniu całego programu.
Fascynujące. Opisujesz wysokopoziomowy projekt jakiegos mechanizmu i
jednoczesnie zarzucasz mi brak rozumienia co to jest null pointer
dereference? No weź przestań. Chyba nie chcesz tego mechanizmu
implementowac przechwytując wyjatki SIGSERV? No no, szacun. To jakiś
nowy wzorzec projektowy, null pointer oriented programming może by go
nazwać?
>> Oczywiście że się kończą. Aby to sprawdzić możesz poświęcić 4
> minuty.
> A to porozmawiaj o tym z moim programem, który przez dwa dni liczył
> sobie na inf'ach i nan'ach. Nie kończył się... Ale może to wina
> Fortranu? Bo procesor całkiem zwyczajny I7.
Dzielenie przez zero powoduje wyjatek sprzetowy. Używanie do obliczeń
Nan *może* powodować wyjątek jesli chcesz, albo nie. To cecha wielu FPU.
I mozna tym sterowac z poziomu kodu. Mozna tez sobie dodać ifa w kodzie
wynikowymj przy kompilacji a przed dzieleniem i samodzielnie w runtime
wygenerować exception jak chcesz a potem mówić że dzielenie przez zero
nie zatrzymuje aplikacji.
Tu masz wyjasnione:
http://stackoverflow.com/questions/18118408/what-is-
difference-between-quiet-nan-and-signaling-nan
Nie ma się co dziwic że istnieją *jakieś* niepopularne języki
programowania gdzie bugi są suppresowane na poziomie kompilatora i
runtime używając spacjalnego bitu w liczbie nan. A może wystarczy flaga
do kompilatora aby to zachowanie zmienić.
>> char *a = 0;
>> chat x = *a;
>
> Rozumiem że miało być char?
>
> W czym problem? Pierwsza linijka to niechlujstwo, ale w C++ może
> przejść.
Nie, to dzień jak codzień. Inicjowanie pointera na null jest bezpieczne.
I częste.
> Druga linijka powinna wywołać wyjątek.
Moze. Nie musi. To jest UB. Może rownie dobrze odkręcić kran w piwnicy
albo zajodłować.
Wiele OSów aby silnie zdefiniować to UB stawia pułapkę sprzętową na tym
adresie (0) i zabija aplikację. Natychmiast o ile nie przechwycisz
*specjalnego* wyjątku systemowego. Tylko że w złozonym programie po jego
przechwyceniu niewiele da się zrobić poza poskładaniem tego co się da
*ewentualnie* poskładać i wyjściem z racji faktu że ten wyjątek
systemowy ma głeboko w d... RAII.
> I jak ten wyjątek
> olejesz, to faktycznie program zwyczajowo się kończy. Ale cały myk że
> możesz nie olewać, tylko zrobić coś mądrego.
Co?
> No wiem że akurat tobie
> będzie trudno zrobić coś mądrego.
Więc pokaz jak zrobić coś madrego w tej sytuacji w C++. Jeśli nie znasz
skladni możesz to opisać słowami. W C++, prosze.
Skoro postanowiłes się kompromitować to ciągnijmy to dalej, niechaj
będzie troche pośmiewiska.
Następne wpisy z tego wątku
- 28.01.17 08:08 slawek
- 28.01.17 08:18 slawek
- 28.01.17 08:21 slawek
- 28.01.17 08:27 slawek
- 28.01.17 08:41 Sebastian Biały
- 28.01.17 08:43 Sebastian Biały
- 28.01.17 08:44 Sebastian Biały
- 28.01.17 08:45 Sebastian Biały
- 28.01.17 09:21 slawek
- 28.01.17 09:58 slawek
- 28.01.17 10:02 slawek
- 28.01.17 10:16 slawek
- 28.01.17 10:45 Sebastian Biały
- 28.01.17 10:47 Sebastian Biały
- 28.01.17 10:52 slawek
Najnowsze wątki z tej grupy
- jak szybko plynie prad
- Płytki Milkv-Duo
- Światłowód między budynkami
- POtrzebny bufor 3.3<>5V, jedonkieruowy, trójstanowy, wąski
- retro
- Bezprzewodowe polączenie Windows z projektorem
- rozklejanie obudowy
- Prośba o identyfikację komponentu
- Smart gniazdko straciło na zasięgu wifi?
- Smart gniazdko straciło zasięg wifi?
- nurtuje mnie
- dziwna sprawa...
- Laptop MSI się nie uruchamia.
- Dobra listwa LED (CRI 90-95, bez migotania)
- masowe programowanie AVR
Najnowsze wątki
- 2024-11-04 GNSS Motorola G85 vs Redmi Note 9 pro
- 2024-11-04 Katowice => SAP BTP Consultant (mid/senior) <=
- 2024-11-04 Katowice => Spedytor międzynarodowy <=
- 2024-11-04 Warszawa => Specjalista/tka ds. Zamówień publicznych <=
- 2024-11-04 Poznań => QA Engineer <=
- 2024-11-04 Poznań => QA Inżynier <=
- 2024-11-04 Polskie sądy są bardzo wyrozumiałe...
- 2024-11-04 Wrocław => SAP Project System/EPPM Consultant <=
- 2024-11-04 Gliwice => Team Lead / Tribe Lead FrontEnd <=
- 2024-11-04 Kraków => Programista Full Stack (.Net Core) <=
- 2024-11-04 Kraków => Software .Net Developer <=
- 2024-11-04 Kraków => Programista Full Stack .Net <=
- 2024-11-04 Warszawa => Key Account Manager <=
- 2024-11-04 Warszawa => Spedytor Międzynarodowy <=
- 2024-11-04 Warszawa => E-COMMERCE specialist <=