-
Data: 2021-08-23 15:44:34
Temat: Re: rzadki bład w programie w C++
Od: Maciek Godek <g...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- 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!!!
- 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ą."
Najnowsze wątki
- 2025-11-13 SO postępowanie cywilne rejestrowe
- 2025-11-13 miesiąc z 5G i wifi calling
- 2025-11-13 Warszawa => APM/Observability Engineer (Presales Engineer) <=
- 2025-11-12 Strefa Schengen
- 2025-11-12 #Motodziennik 352 - STRACH SIĘ BAĆ - Zombi VS radio AM, prawo do naprawy i niemiecki pomysł...
- 2025-11-12 Aparatu szukam
- 2025-11-12 Azylant na Węgrzech donosi prokuraturze na ministra sprawiedliwości/prokuratora generalnego
- 2025-11-12 Wrocław => Specjalista ds. Marketingu Online (PPC) <=
- 2025-11-12 Gdańsk => Delphi Programmer <=
- 2025-11-12 Białystok => Generative AI Engineer <=
- 2025-11-12 Białystok => Gen AI Engineer <=
- 2025-11-12 Chrzanów => Spedytor Międzynarodowy (handel ładunkami/prowadzenie f
- 2025-11-12 Gdańsk => Programista Delphi <=
- 2025-11-12 => Senior Algorithm Developer (Java/Kotlin) <=
- 2025-11-12 Warszawa => Engineering Manager <=




Elektromobilność dojrzewa. Auta elektryczne kupujemy z rozsądku, nie dla idei