-
X-Received: by 2002:ac8:1498:: with SMTP id l24mr29279634qtj.169.1629726274160; Mon,
23 Aug 2021 06:44:34 -0700 (PDT)
X-Received: by 2002:ac8:1498:: with SMTP id l24mr29279634qtj.169.1629726274160; Mon,
23 Aug 2021 06:44:34 -0700 (PDT)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!2.eu.feeder.erj
e.net!feeder.erje.net!proxad.net!feeder1-2.proxad.net!209.85.160.216.MISMATCH!n
ews-out.google.com!nntp.google.com!postnews.google.com!google-groups.googlegrou
ps.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Mon, 23 Aug 2021 06:44:34 -0700 (PDT)
In-Reply-To: <9...@g...com>
Injection-Info: google-groups.googlegroups.com; posting-host=213.192.68.153;
posting-account=f7iIKQoAAAAkDKpUafc-4IXhmRAzdB5r
NNTP-Posting-Host: 213.192.68.153
References: <9...@g...com>
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <4...@g...com>
Subject: Re: rzadki bład w programie w C++
From: Maciek Godek <g...@g...com>
Injection-Date: Mon, 23 Aug 2021 13:44:34 +0000
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
Xref: news-archive.icm.edu.pl pl.comp.programming:215559
[ ukryj nagłówki ]poniedziałek, 23 sierpnia 2021 o 14:59:04 UTC+2 r...@g...com napisał(a):
> Napisałem program w C++. Zawiera błąd którego szczegółów nie znam. Błąd
(niepoprawne wartości zapisywane do pliku) występuje rzadko, nie wiem w jakich
okolicznościach. Wstawiłem asercje i testuję, niestety nie udało mi się odtworzyć
problemu.
> Jak podejść do problemu, jakiej strategii użyć? Co mogę zrobić poza asercjami?
Debugowanie nie ma sensu bo błąd występuje zbyt rzadko.
Strategia, która pozwoli w najprostszy sposób wyeliminować ten "błąd", to uznać go za
ficzer.
A tak serio, jeżeli Twoja wiedza o tym błędzie jest tak duża, jak wiedza, którą się
tu podzieliłeś, odnośnie programu, który napisałeś, to nie widzę wielkich nadziei na
uporanie się z nim.
Możesz chociaż napisać:
- w jaki sposób błąd się objawia
- jak duży jest program
- na jakim etapie rozwoju programu pojawił się błąd
- czy możesz łatwo przepisać program np. na C# albo Javę
Możesz też poszukać w okolicy jakiegoś kolegi-programisty, usiąść z nim i wspólnie
przejrzeć kod.
Rzecz w tym, że jak piszesz w C++ albo C, to możesz łatwo popełnić błąd w rodzaju
przypadkowego nadpisania obszaru w pamięci, i tego rodzaju błędy są raczej trudne do
wykrycia.
Jeden z moich ulubionych to kod w rodzaju takiego czegoś:
printf("liczba wynosi: "+n);
Programista wychowany na C# będzie zaskoczony tym zachowaniem, a tymczasem to jest w
pełni legalny kod w C: do adresu literału znakowego (który sam w sobie jest dość
losowy) dodajemy jakąś liczbę, która w rezultacie daje nam jakiś inny adres, i spod
tego adresu próbujemy teraz przekazać argument do funkcji printf.
Rezultatem jest "nieokreślone zachowanie", czyli może się tak naprawdę zdarzyć
cokolwiek.
Czasem pomaga kompilacja kodu z flagami -Wall albo -Wextra - może pomoże wskazać
miejsce w kodzie, w którym jest jakieś podejrzane użycie języka.
Następne wpisy z tego wątku
- 23.08.21 16:04 Robert Magdziarz
- 23.08.21 16:48 Maciek Godek
- 23.08.21 16:55 Zbych
- 23.08.21 20:51 Maciej Sobczak
- 23.08.21 20:57 Robert Magdziarz
- 24.08.21 10:12 Maciek Godek
- 24.08.21 10:57 Robert Magdziarz
- 24.08.21 11:19 Mateusz Viste
- 24.08.21 16:33 Maciek Godek
- 24.08.21 16:39 Maciek Godek
- 24.08.21 17:27 Mateusz Viste
- 24.08.21 17:50 Maciek Godek
- 24.08.21 19:41 Mateusz Viste
- 24.08.21 20:58 Maciej Sobczak
- 24.08.21 21:05 heby
Najnowsze wątki z tej grupy
- Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Re: Najgorszy język programowania
- NOWY: 2025-09-29 Alg., Strukt. Danych i Tech. Prog. - komentarz.pdf
- 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!!!
Najnowsze wątki
- 2026-01-01 szyby macie całe?
- 2026-01-01 Najbogatsi ludzie na świecie są jeszcze bogatsi. Bezprecedensowa skala zysków
- 2026-01-01 Najbogatsi ludzie na świecie są jeszcze bogatsi. Bezprecedensowa skala zysków
- 2026-01-01 Wszystkiego najlepszego
- 2025-12-31 Czy potrafisz wskazać różnice? [TVN v. RMF]
- 2025-12-31 I kolejny jebnięty
- 2025-12-31 Myślenice => Specjalista ds. kontrolingu <=
- 2025-12-31 Ostróda szlachetnie walczy
- 2025-12-31 Pierwsza mapa kosmosu w 102 długościach fal podczerwieni! To początek nowej ery w astronomii
- 2025-12-31 Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- 2025-12-31 Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- 2025-12-31 Pieniadze-cuchna-oddechem-nawalonego-tatusia
- 2025-12-31 Iran na skraju gospodarczego upadku. Na ulicach Teheranu (znów) wrze. To może być cios dla reżimu
- 2025-12-30 zasilacz
- 2025-12-30 Teraz System Plików PFS z sys. op. Amiga OS będziesz mógł zamontować pod sys. op. Linuks i Jabłoko Makintosz




5 Najlepszych Programów do Księgowości w Chmurze - Ranking i Porównanie [2025]