buffer_read 함수 설명 및 활용 예제

함수 개요

buffer_read 함수는 주어진 버퍼의 현재 탐색 위치에서 지정된 타입의 데이터를 읽어오는 기능을 제공합니다. 함수 실행 후, 탐색 위치는 읽은 바이트 수만큼 이동합니다. 다음 buffer_read 호출은 이 새로운 위치에서 데이터를 읽게 됩니다.

버퍼의 현재 탐색 위치에서 시작하여 내용을 읽기 때문에, 함수 호출 전에 탐색 위치가 올바르게 설정되어 있어야 합니다. 그렇지 않으면 잘못된 결과가 반환되거나 아무것도 반환되지 않을 수 있습니다. buffer_peek 함수를 사용하면 탐색 위치를 변경하지 않고도 버퍼의 어느 위치에서든 값을 가져올 수 있습니다.

함수의 반환 값은 읽고 있는 데이터의 타입에 따라 달라지며, 다음과 같은 상수 중 하나가 될 수 있습니다:

  • 함수가 성공하면 지정된 타입의 값을 반환합니다.
  • 실패할 경우 실행 오류가 발생합니다.
  • 잘못된 데이터 타입을 사용하면 잘못된 값이 반환됩니다.

HTML5에서 buffer_s32 또는 buffer_u32를 읽으면 값이 64비트 더블인 Real로 반환됩니다. 이는 int32가 해당 플랫폼에서 지원되지 않기 때문입니다.

문법

buffer_read(buffer, type)

인수 설명

인수 타입 설명
buffer Buffer 읽어올 버퍼
type Buffer Data Type Constant 버퍼에서 읽어올 데이터의 타입

반환 값

  • Real, Boolean 또는 String

예제 코드

다음은 buffer_read 함수를 사용하는 예제입니다:

buffer = buffer_create(10240, buffer_grow, 1); // 버퍼 생성
// buffer_seek(buffer, buffer_seek_start, 0); // 탐색 위치 설정 (생략 가능)
buffer_write(buffer, buffer_string, "Hello World"); // 문자열을 버퍼에 쓰기
buffer_seek(buffer, buffer_seek_start, 0); // 탐색 위치를 0으로 설정
result = buffer_read(buffer, buffer_string); // 버퍼에서 문자열 읽기
show_debug_message("Result = " + result); // 결과 출력

위 코드는 버퍼를 생성하고 문자열을 기록한 후 다시 읽어오는 과정을 보여줍니다. 처음에 10240 바이트의 새로운 성장 버퍼를 생성하고, 문자열 "Hello World"를 버퍼에 기록합니다. 이때 탐색 위치는 12 바이트만큼 이동합니다: 문자열의 문자 수 11 바이트와 마지막 널 바이트 1 바이트입니다. 이후, 탐색 위치를 0으로 설정한 후 buffer_read를 사용하여 문자열을 읽어옵니다. 읽은 데이터는 result 변수에 저장되며, 디버그 메시지로 출력됩니다.

추가 활용 예제

  1. 정수 데이터 읽기
buffer = buffer_create(10240, buffer_grow, 1);
buffer_write(buffer, buffer_s32, 12345);
buffer_seek(buffer, buffer_seek_start, 0);
result = buffer_read(buffer, buffer_s32);
show_debug_message("Integer Result = " + string(result));
  1. 부울 데이터 읽기
buffer = buffer_create(10240, buffer_grow, 1);
buffer_write(buffer, buffer_boolean, true);
buffer_seek(buffer, buffer_seek_start, 0);
result = buffer_read(buffer, buffer_boolean);
show_debug_message("Boolean Result = " + string(result));
  1. 문자열 배열 읽기
buffer = buffer_create(10240, buffer_grow, 1);
buffer_write(buffer, buffer_string, "First String");
buffer_write(buffer, buffer_string, "Second String");
buffer_seek(buffer, buffer_seek_start, 0);
result1 = buffer_read(buffer, buffer_string);
result2 = buffer_read(buffer, buffer_string);
show_debug_message("First String = " + result1);
show_debug_message("Second String = " + result2);

이러한 예제들은 buffer_read 함수를 다양한 데이터 타입에 대해 활용하는 방법을 보여줍니다.

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