Witam. Programuję grę w Visual Studio 2022. Dodałem parę nowych funkcjonalności i gra zaczęła lagować. Jak namierzyć fragmenty kodu odpowiedzialne za opóźnienia ?
Dodać logi do kodu.
Ja bym szukał profilera dla języka który używasz
jeżeli to c++ może być np. https://github.com/yse/easy_profiler
W visual studio masz wbudowany profiler, "Diagnostic Tools" po prawej. Zwyczajnie włączasz CPU profiling, zaznaczasz na wykresie fragment w którym masz lagi i widzisz ile która funkcja zajęła czasu
po naciśnięciu na funkcję możesz zobaczyć konkretne drzewko wywołań
i konkretne miejsce w kodzie:
@obscurity Mam coś takiego - jak naduszę "Break All" to zawiesza mi grę
tBane napisał(a):
@obscurity Mam coś takiego - jak naduszę "Break All" to zawiesza mi grę
tak, po włączeniu nagrywania musisz zawiesić grę żeby przeanalizować dane
@obscurity a da się jakoś sprawdzać zużycie pamięci i CPU w czasie rzeczywistym ?
tBane napisał(a):
@obscurity a da się jakoś sprawdzać zużycie pamięci i CPU w czasie rzeczywistym ?
no to ci się na wykresie cały czas pokazuje, do analizy pamięci musisz robić snapshoty, ale nie trzeba zatrzymywać aplikacji, analizę CPU można zrobić tylko na zatrzymanej aplikacji, w zasadzie to nie wiem czemu. Może dlatego że sama analiza danych wpływałaby na performance i przekłamywała wyniki?
@obscurity no właśnie mam ten problem, że mi się w czasie rzeczywistym nie wyświetla :-/
@obscurity Tak to u mnie wygląda.
odpalasz nagrywanie (record CPU profile), grasz normalnie, czekasz na laga, na wykresie będziesz tego laga widział prawdopodobnie w postaci pika na wykresie, zaznaczasz ten fragment, zatrzymujesz grę (break) i masz listę funkcji i procentowe zużycie CPU. Do analizy pamięci robisz snapshot na początku i po momencie który chcesz zanalizować i masz listę alokacji. Czego więcej potrzebujesz?
@tBane: nie bardzo rozumiem dlaczego zwracasz uwagę na pamięć jak lagowanie jest zwiane z czasem
ja bym szedł w kierunku pomiaru czasu rysowanie klatek i szukana co trwa najdłużej
a jak to włączyć ?
- git clone https://github.com/yse/easy_profiler
- w cmake add_subdirectory(....)
- target_link_libraries(TWOJA_APLIKACJA easy_profiler)
- obejrzyj przyklad https://github.com/yse/easy_profiler/blob/develop/sample/main.cpp
Nie znam się na monitorowaniu aplikacji desktop, bo pracuję z serwerowymi, ale może to podejście wypali jeśli nie chcesz zatrzymywać gry tylko zbierać dane live i potem je analizować. Także weź poprawkę na to, że mogę wygadywać bzdury.
Profilując dostajesz de facto zestaw metryk tudzież coś na kształt tracingu, masz drzewo wywołań itd. Ja bym poszedł dalej i zamiast profilować i zatrzymywać grę, by się czemuś przyjrzeć, zaczął bym sobie instrumentować aplikację metrykami które mnie interesują i w trakcie testów / debugu gdzieś te metryki wrzucał do analizy.
Nie wiem na ile pozwala profiler, ale z własnymi metrykami masz generalnie pełną dowolność, jak tylko jesteś w stanie wyłuskać daną informację, i może to być wszystko co podejrzewasz, że ma wpływ na rozgrywkę / lagi:
- zużycie CPU przez proces
- stan puli wątków (jeśli masz)
- zużycie I/O (dyski, sieć, jeśli są relewantne)
- metryki z GPU
- metadane gry jak np. liczba postaci, obiektów, sprajtów itd. najlepiej z podziałem na rodzaje
- czas renderowania klatki
- czas przeliczania stanu gry pomiędzy
- FPSy na monitorze
- to ile razy na sekundę przeliczasz stan gry (jeśli jest to niezależnie od rysowania)
Takie metryki możesz generować na bieżąco w ramach diagnostyki, zapiąć się do nich jakąś darmową Grafaną i testować, szukać sobie korelacji itd. w przypadku aplikacji serwerowej tak bym zrobił, pomogłoby mi szukać źródeł problemów w kontekście tego, co robię. Nie da mi to dokładnych wywołań funkcji, które powodują problemy, ale zanim zacznę jej szukać da mi to pogląd sytuacji i pozwoli szukać korelacji.
w easy_profiler masz dwie opcje wszystko oczywiscie w runtime
- albo zapisujesz próbki do pliku i oglądasz potem
- albo podlaczas sie po IP i oglądać dane w czasie rzeczywistym
swego czasu używałem tez https://github.com/wolfpld/tracy
ale trochę większa kobyła