• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

[ZAPŁACĘ] Pytanie do ekspertów C++ - Lokalizacja crasha

Object Storage Arubacloud
0 głosów
294 wizyt
pytanie zadane 14 maja 2019 w C i C++ przez Luna Cognita Dyskutant (8,130 p.)
Witam,

Dzisiejszego ranka w mojej aplikacji wystąpiły w crashe, które dosłownie wyłączyły program (lecz w razie wyłączenie a bashu mam skrypt że włącza na nowo). W kern log natknąłem się na takie coś:

May 14 10:13:14 myapp kernel: [61955.249459] app[7512]: segfault at 5cded880 ip 00000000004d4348 sp 00007eff596f2760 error 4 in app[400000+140000]
May 14 11:44:28 myapp kernel: [67429.202533] app[8306]: segfault at 5cded880 ip 00000000004d4348 sp 00007f1d4ffde760 error 4 in app[400000+140000]

 

Czy jest ktoś na tym forum ogranięty w tej kwestii jak ogranąc co spowodowało ten błąd? Zdaję sobię sprawę że może to być trudne, dlatego postanowiłem że zapłacę za pomoc. Aplikacja napisana jest w C++. System to Debian 8 x64.

Pozdrawiam
komentarz 14 maja 2019 przez wsnofi Bywalec (2,680 p.)
komentarz 14 maja 2019 przez Luna Cognita Dyskutant (8,130 p.)
Przeczytałem to i to odnosi się tylko do bibliotek, a crash występuje w mojej aplikacji,

Pozdrawiam

2 odpowiedzi

+3 głosów
odpowiedź 14 maja 2019 przez adrian17 Ekspert (344,860 p.)
wybrane 15 maja 2019 przez Luna Cognita
 
Najlepsza
Jeśli można, zdecydowanie bardziej polecam AddressSanitizera od Valgrinda.

(edit: konkretniej, ASAN jest wbudowany w obecne kompilatory, lepiej rozumie kod bo jest razem z nim kompilowany (trochę mniej fałszywych pozytywów przy wykrywaniu wycieków), znacznie mniej obciąża (Valgrind spowalnia aplikację 10-100 razy))

Skoro kompilujesz na Debianie, to oznacza że wystarczy do opcji kompilacji (i linkowania) dodać `-g -fsanitize=address`, przekompilować projekt i ponownie uruchomić aplikację - dostaniesz ładny komunikat w momencie pierwszej wykrytej niepoprawnej operacji na pamięci.
komentarz 15 maja 2019 przez Luna Cognita Dyskutant (8,130 p.)

Dzięki bardzo. Podczas uruchamiania aplikacji z użyciem fsanitize dostaję komunikat:

https://pastebin.com/raw/SX0EJh9L

po czym aplikacja nie chce się odpalić, czy ktoś mógłby mi powiedzieć jak to zdiagnozować i naprawić?

game.cpp

https://pastebin.com/raw/eTVLPfxE

Pozdrawiam

komentarz 15 maja 2019 przez adrian17 Ekspert (344,860 p.)
AutoList<Player>::listiterator iter = Player::listPlayer.list.begin();
    if((*iter).second){

...lista jest pusta?

W każdym razie, strzelam pewnie najlepiej byłoby zapytać autora tej "modyfikacji".

+2 głosów
odpowiedź 14 maja 2019 przez VirtualMember Pasjonat (15,790 p.)
edycja 14 maja 2019 przez VirtualMember

Puszczałeś swoją aplikację przez valgrinda? Może jakaś alokacja się nie udała - wówczas odwołujesz sie do NULL/nullptr?

Do valdka możesz użyć albo cliona (on ma wbudowanego valdka) albo prosty skrypt:

LEAKEXITCODE=42
VALGRINDFLAGS="--error-exitcode=$LEAKEXITCODE --leak-check=full \
--show-leak-kinds=all --errors-for-leak-kinds=all -q"

RED='\033[0;31m'
GREEN='\033[0;32m'
NC='\033[0m'

    echo  "Testing... $f"
	OUTF="$(mktemp)";

	valgrind $VALGRINDFLAGS ./$PROG < $f 1>$OUTF.out 2>$OUTF.out
	EXIT_CODE=$?
	if [ $EXIT_CODE -ne 0 ];
    then
    	echo -e "-------${RED}WRONG exit code: $EXIT_CODE ${NC}";
    else
        echo -e "-------${GREEN}GOOD exit code: $EXIT_CODE ${NC}";
    fi
        echo ""

gdzie f to twój program. Jak podajesz bezpośrednio to wtedy bez $

no i na końcu możesz usunąć temp files przy użyciu rm -f

+ podczas działania swojego programu odpal top (ewentualnie polecam bardziej zainstalować i korzystać z htop) i zobacz czy memory ci się nie wywala - jeśli nie ma wycieków to nie powinno, chyba, że przesadzasz z jakimiś algorytmami. Wtedy ewentualnie możesz zwiększyć swap:

sudo swapoff -a
sudo dd if=/dev/zero of=/swapfile bs=1G count=8
sudo mkswap /swapfile
sudo swapon /swapfile
grep SwapTotal /proc/meminfo

gdzie wielkość zmieniasz sam - ale weź pod uwagę, że gdy twój komputer zaczyna korzystać ze swapa (czyli gdy ram mu się kończy) to zaczyna mulić dopóki nie oczyścisz ramu - ale chociaż program działa jeśli to niezbędne.

komentarz 14 maja 2019 przez Luna Cognita Dyskutant (8,130 p.)
Nie właśnie, czy byłbyś w stanie mi pomóc? Czy plik binarny mógłby jakoś pomóc w analizie?

 

Pozdrawiam
komentarz 14 maja 2019 przez VirtualMember Pasjonat (15,790 p.)
Jeśli masz CLiona to możesz odpalić swój program w trybie valgrinda - wnet w trakcie działania i po zakończeniu (twoim zatrzymaniu) produkuje informacje na temat wycieków pamięci. Możesz ewentualnie puścić swój skompilowany program z konsoli przez valdka. Edytuję swoją odpowiedź.

Podobne pytania

0 głosów
1 odpowiedź 198 wizyt
pytanie zadane 28 lipca 2017 w Rozwój zawodowy, nauka, praca przez michu1275 Nowicjusz (190 p.)
+3 głosów
1 odpowiedź 187 wizyt
pytanie zadane 20 czerwca 2015 w C i C++ przez MshL Początkujący (270 p.)
+1 głos
1 odpowiedź 170 wizyt
pytanie zadane 23 grudnia 2020 w C i C++ przez xkamiz Użytkownik (500 p.)

92,551 zapytań

141,399 odpowiedzi

319,529 komentarzy

61,937 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...