Unity에서는 가비지 컬렉터를 사용하여 애플리케이션과 Unity에서 더 이상 사용하지 않는 오브젝트로부터 메모리를 회수합니다. 스크립트가 관리되는 힙에 할당하려고 하지만 할당을 수용할 수 있는 사용 가능한 힙 메모리가 충분하지 않으면 Unity는 가비지 컬렉터를 실행합니다. 가비지 콜렉터가 실행되면 힙의 모든 오브젝트를 검사하고 애플리케이션에서 더 이상 레퍼런스가 없는 오브젝트를 삭제하도록 표시합니다. 그런 다음 Unity는 레퍼런스가 없는 오브젝트를 삭제하여 메모리를 확보합니다.
가비지 컬렉터는 필요한 블록 크기를 할당할 수 있을 만큼 충분히 큰 빈 공간이 없을 때까지 동일한 방식으로 후속 요청을 처리합니다. 이 상황에서 할당된 모든 메모리가 아직 사용 중일 가능성은 거의 없습니다. Unity의 스크립팅 백엔드는 찾을 수 있는 레퍼런스 변수가 있는 경우에만 힙의 레퍼런스 항목에 액세스할 수 있습니다. 메모리 블록에 대한 모든 레퍼런스가 누락된 경우(레퍼런스 변수가 재할당되었거나 범위를 벗어난 로컬 변수인 경우) 가비지 컬렉터가 점유한 메모리를 재할당할 수 있습니다.
어떤 힙 블록이 더 이상 사용되지 않고 있는지를 확인하기 위해, 가비지 컬렉터는 모든 액티브 레퍼런스 변수를 검색하고 이 변수가 참조하는 메모리 블록을 “살아있음(live)”이라고 표시합니다. 검색이 끝나면 가비지 컬렉터는 “살아있는(live)” 블록 사이의 공간이 비어 있는 것으로 간주하고 후속 할당에 사용할 수 있도록 표시합니다. 사용하지 않는 메모리를 찾아서 비우는 프로세스를 가비지 컬렉션(GC)이라고 합니다.
참고:가비지 컬렉터는 WebGL에서 다르게 작동합니다.자세한 내용은 가비지 컬렉션 고려 사항을 참조하십시오.
Unity에서 가비지 컬렉터는 다음과 같은 모드를 사용합니다.
Unity에는 메모리 할당을 추적하기 위한 다음과 같은 도구가 있습니다.
CPU 사용 모듈의 계층 구조 뷰에는 GC Alloc 열이 있습니다. 이 열에는 Unity에서 특정 프레임의 관리되는 힙에 할당한 바이트 수가 표시됩니다. 또한 가비지 컬렉터가 관리한 메모리 양을 표시하며 Unity가 후속 프레임에서 할당하고 재사용했을 수 있는 메모리를 포함합니다. 즉, 모든 프레임에 대한 GC Alloc의 합계가 그 시간동안 관리되는 메모리가 얼마나 증가했는지를 합산하지 않는다는 것을 의미합니다.
가장 정확한 정보를 얻으려면 항상 빌드하려는 타겟 플랫폼 또는 장치의 개발 빌드에서 애플리케이션을 프로파일링해야 합니다. Unity 에디터는 빌드와 다른 방식으로 작동하며 이는 프로파일링 데이터에 영향을 미칩니다. 예를 들어 GetComponent
메서드는 에디터에서 실행될 때 항상 메모리를 할당하지만 빌드된 프로젝트에서는 할당하지 않습니다.
또한 프로파일러에서 호출 스택 모드를 사용하여 할당하는 메서드를 결정할 수 있습니다. GC.Alloc 샘플에 대해 전체 호출 스택 추적을 활성화할 수 있으며 가비지 컬렉터가 실행된 위치와 시간을 결정하는 데 도움이 됩니다.
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.