-
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
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
- Ideologia Polskiego Programisty wer.3
Najnowsze wątki
- 2024-05-04 Bonusowe pytanie rozliczenie sie z elektrownia - fotowoltaika.
- 2024-05-04 Ujawnienie porady prawnej prokuraturze
- 2024-05-04 Jaką kamerkę samochodową polecacie?
- 2024-05-04 Warszawa => Spedytor międzynarodowy <=
- 2024-05-04 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-04 Warszawa => Inżynier DevOps (projekt JP) <=
- 2024-05-04 Gdańsk => Specjalista ds. Sprzedaży <=
- 2024-05-04 Łódź => Business Development Manager - obszar bezpieczeństwa IT <=
- 2024-05-04 Warszawa => Interactive/Experience Designer <=
- 2024-05-04 Berlin => IT Systems Administrator and Customer Support Engineer <=
- 2024-05-04 Warszawa => Mid IT Recruiter <=
- 2024-05-04 Odpowiedzialność PORTALU za reklamy
- 2024-05-04 Lunar Rover był elektrykiem. Ważył 35 kg Zasięg 80 km Na Księżycu w 1971 r.
- 2024-05-04 Marki => ERP Implementer <=
- 2024-05-04 Gdańsk => Head of International Freight Forwarding Department <=