버퍼 작업 안내서
버퍼란?
버퍼(Buffer)는 물리적 메모리의 특정 영역으로, 데이터를 한 장소에서 다른 장소로 이동하거나 조작하는 동안 임시로 저장하는 데 사용됩니다. 예를 들어, 게임 상태 데이터를 저장할 때 버퍼를 사용할 수 있습니다.
GameMaker에서의 버퍼
GameMaker에는 버퍼를 생성하고 수정하며 로드/저장하는 것과 관련된 여러 특정 작업(actions)이 있습니다. 사용하기 전에 다음 사항을 숙지해 주세요.
- 버퍼가 생성되면 자동으로 초기화되고 0으로 채워집니다.
- 버퍼 함수의 "크기(size)" 인자는 항상 버퍼의 바이트 단위 크기를 의미합니다.
- GML Visual에서 버퍼는 항상 1바이트 정렬로 유지됩니다.
- 버퍼 내 데이터는 순차적으로 읽고 씁니다. 즉,
Write Buffer작업을 세 번 호출하면 첫 번째 데이터를 쓰고, 다음으로 넘어가 두 번째 데이터를 쓰고, 마지막으로 세 번째 데이터를 씁니다. - "seek" 값은 버퍼 내에서 다음 읽기/쓰기 작업이 발생할 위치를 지정합니다.
- 모든 데이터는 문자열로 버퍼에 기록되고 반환됩니다. 따라서 실수(real number)를 저장한 경우, 데이터 타입 작업(Data Type Actions)을 사용하여 문자열에서 값을 변환해야 합니다.
- 버퍼를 생성하는 데 사용되는 메모리는 시스템 메모리이므로 게임이 포커스를 잃어도 버퍼에 저장된 데이터는 안전하지만, 앱이 종료되거나 재시작되면 데이터는 손실됩니다.
- 또한, 버퍼는 파일로 저장한 다음 게임으로 다시 로드할 수 있습니다.
버퍼 사용법
버퍼 라이브러리에는 다음과 같은 작업이 포함되어 있습니다:
| 작업 | 설명 |
|---|---|
| Create Buffer | 버퍼를 생성합니다. |
| Copy Buffer | 버퍼를 복사합니다. |
| Delete Buffer | 버퍼를 삭제합니다. |
| Read Buffer | 버퍼에서 데이터를 읽습니다. |
| Write Buffer | 버퍼에 데이터를 씁니다. |
| Seek Buffer | 버퍼의 현재 읽기/쓰기 위치를 설정합니다. |
| Get Buffer Size | 버퍼의 크기를 가져옵니다. |
| Get Buffer Position | 버퍼 내 현재 위치를 가져옵니다. |
| If Buffer Exists | 버퍼가 존재하는지 확인합니다. |
| If End Of Buffer | 버퍼의 끝에 도달했는지 확인합니다. |
코드 예제
아래는 GML을 사용한 간단한 버퍼 작업 예제입니다.
// 버퍼 생성
var myBuffer = buffer_create(1024, buffer_grow, 1);
// 데이터 쓰기
buffer_write(myBuffer, buffer_u8, 255); // 0-255 사이의 값 작성
buffer_write(myBuffer, buffer_string, "Hello"); // 문자열 작성
// 데이터 읽기
var value = buffer_read(myBuffer, buffer_u8);
var text = buffer_read(myBuffer, buffer_string);
// 버퍼 삭제
buffer_delete(myBuffer);
활용 및 응용 예제
- 게임 상태 저장:
- 특정 게임의 상태(예: 레벨, 점수 등)를 버퍼에 저장하고, 나중에 복원할 수 있습니다.
- 데이터 전송:
- 서버와의 통신 시 데이터를 임시로 버퍼에 확보하고, 버퍼 내 데이터를 적절한 형식으로 변환하여 전송할 수 있습니다.
- 파일로 저장:
- 플레이어 설정이나 점수 등의 데이터를 파일로 저장하고, 필요 시 다시 로드하여 게임에서 사용할 수 있습니다.
- 배열 데이터 관리:
- 배열 데이터를 손쉽게 관리하기 위해 버퍼를 사용하여 데이터를 쓰고 읽는 작업을 수행할 수 있습니다.
이러한 환경에서 버퍼는 게임의 성능 개선과 다양한 데이터 관리에 큰 도움이 됩니다. 이제 GameMaker에서 버퍼를 활용해 보세요! ```