gc_get_stats 함수 설명

gc_get_stats 함수는 현재 가비지 컬렉터의 상태에 대한 정보를 가져오는 기능을 제공합니다. 이 함수는 다음과 같은 멤버 변수를 가진 구조체를 반환합니다. 여기서 "objects"는 가비지 컬렉션이 가능한 모든 것을 의미하며, 자산 브라우저에서 정의된 일반 객체 인스턴스는 포함되지 않습니다.

GC Stats 구조체

변수 이름 타입 설명
objects_touched Real 이전 프레임에서 가비지 컬렉터가 발견한 활성 객체의 수입니다. 세대에 따라 달라질 수 있습니다.
objects_collected Real 이전 프레임에서 비활성으로 판단된 객체의 수입니다. 이 객체들은 삭제될 수 있습니다.
traversal_time Real 활성 객체를 판단하는 데 걸린 시간(마이크로초)입니다. 주 스레드에서 실행됩니다.
collection_time Real 비활성 객체를 정리하는 데 걸린 시간(마이크로초)입니다. 별도의 스레드에서 실행됩니다.
gc_frame Real 가비지 컬렉션이 발생할 때마다 증가하는 카운터입니다. 가비지 컬렉션이 비활성화된 경우 증가하지 않습니다.
generation_collected Real 마지막으로 수집된 세대의 인덱스입니다. 0은 가장 어린 세대, 3은 현재 가장 오래된 세대입니다.
num_generations Real 가비지 컬렉션 세대의 총 수입니다.
num_objects_in_generation Array of Reals 각 세대에 있는 객체의 수를 포함하는 배열입니다. 배열 크기는 num_generations입니다.

참고: HTML5 플랫폼에서는 가비지 컬렉션이 JavaScript 엔진에 의해 처리되므로, 이 플랫폼에서 이 함수를 사용할 경우 위 구조체의 모든 멤버 변수는 0을 반환합니다.

이 함수를 사용할 때, 객체에 대한 정보는 전체 세대 처리가 완료될 때만 업데이트됩니다. 이 과정은 프레임 시간 설정에 따라 여러 프레임이 걸릴 수 있습니다.

구문

gc_get_stats();

반환값

GC Stats 구조체

예제

if (global.debug == true) {
    var _s = gc_get_stats();
    var _t = _s.traversal_time;
    var _c = _s.collection_time;
    show_debug_message("Traversal time = " + string(_t));
    show_debug_message("Collection time = " + string(_c));
}

위 코드는 전역 변수를 확인하고, 만약 true일 경우 가비지 컬렉터로부터 정보를 가져와 콘솔에 디버그 메시지로 출력합니다.

활용 예제

  1. 가비지 컬렉션 성능 모니터링 gml var stats = gc_get_stats(); if (stats.traversal_time > 1000) { show_debug_message("Traversal time is high!"); }
  2. 가비지 컬렉션 주기 조정 gml if (global.gc_frame % 10 == 0) { gc_enable(); }
  3. 세대별 객체 수 확인 gml var stats = gc_get_stats(); for (var i = 0; i < stats.num_generations; i++) { show_debug_message("Objects in generation " + string(i) + ": " + string(stats.num_objects_in_generation[i])); }
  4. 가비지 컬렉션 비활성화 gml gc_disable(); show_debug_message("Garbage collection disabled.");
  5. 가비지 컬렉션 상태 로그 gml var stats = gc_get_stats(); show_debug_message("GC Frame: " + string(stats.gc_frame)); show_debug_message("Objects Collected: " + string(stats.objects_collected));

이러한 예제들은 가비지 컬렉터의 상태를 모니터링하고, 성능을 최적화하며, 필요한 경우 가비지 컬렉션을 조정하는 데 유용합니다.

Read more

기술 문서 해설 및 활용 예제

이 문서는 특정 기술에 대한 설명과 활용 방법을 다룹니다. 아래에서 내용을 쉽게 이해할 수 있도록 해설하고, 다양한 활용 및 응용 예제를 추가로 제공합니다. 기술 개요 이 기술은 게임 개발에서 자주 사용되는 기능으로, 특정 작업을 자동화하거나 효율적으로 처리하는 데 도움을 줍니다. 주로 게임의 로직을 구성하거나 사용자 인터페이스를 제어하는 데 사용됩니다. 주요

By 이재협/실장/시스템개발실/PHYSIA

키워드 설명서

이 문서는 특정 키워드에 대한 설명과 사용법을 제공합니다. 문법 (arguments); 인수 인수 이름 유형 설명 argument_name 인수에 대한 설명을 여기에 작성합니다. 반환값 (선택적 설명) 예제 code_example() { // 여기에 코드 예제를 설명합니다. } 코드 예제 설명 위의 코드 예제는 특정 기능을 수행하는 함수의 기본 구조를 보여줍니다. 이 함수는 인수를 받아들이고, 특정

By 이재협/실장/시스템개발실/PHYSIA

GameMaker 환경 설정 및 기능

이 문서에서는 GameMaker의 환경 설정 및 다양한 IDE 기능에 대한 정보를 제공합니다. 다음은 주요 항목들입니다: IDE 환경 설정 IDE(통합 개발 환경) 설정은 GameMaker의 전반적인 사용 경험을 조정하는 데 도움을 줍니다. 여기서 사용자는 개인의 필요에 맞게 다양한 옵션을 설정할 수 있습니다. 주요 설정 항목 설정 항목 설명 테마 IDE의 색상

By 이재협/실장/시스템개발실/PHYSIA

GameMaker IDE 설명서

GameMaker IDE는 게임을 만들고 소프트웨어에서 제공하는 모든 기능을 활용하는 주요 인터페이스입니다. 이 프로그램은 시작 화면부터 게임을 만들기 위해 사용하는 모든 편집기 창까지 포함되며, 매뉴얼과 다양한 튜토리얼에서 IDE라고 언급됩니다. IDE의 구성 요소 다음 섹션에서는 IDE에 대한 정보를 다룹니다: 1. 설정 및 기능 IDE의 설정 및 기능은 사용자가 게임 개발을 보다 효율적으로

By 이재협/실장/시스템개발실/PHYSIA