기본 콘텐츠로 건너뛰기

GCC에서 printf류 함수 인자 타입 검사

format (archetype, string-index, first-to-check)
The format attribute specifies that a function takes printf, scanf, or strftime style arguments which should be type-checked against a format string. For example, the declaration:

extern int
my_printf (void *my_object, const char *my_format, ...)
__attribute__ ((format (printf, 2, 3)));


causes the compiler to check the arguments in calls to my_printf for consistency with the printf style format string argument my_format.

The parameter archetype determines how the format string is interpreted, and should be either printf, scanf, or strftime. The parameter string-index specifies which argument is the format string argument (starting from 1), while first-to-check is the number of the first argument to check against the format string. For functions where the arguments are not available to be checked (such as vprintf), specify the third parameter as zero. In this case the compiler only checks the format string for consistency.

In the example above, the format string (my_format) is the second argument of the function my_print, and the arguments to check start with the third argument, so the correct parameters for the format attribute are 2 and 3.

The format attribute allows you to identify your own functions which take format strings as arguments, so that GNU CC can check the calls to these functions for errors. The compiler always checks formats for the ANSI library functions printf, fprintf, sprintf, scanf, fscanf, sscanf, strftime, vprintf, vfprintf and vsprintf whenever such warnings are requested (using `-Wformat'), so there is no need to modify the header file `stdio.h'.

출처: http://gcc.gnu.org/onlinedocs/gcc-2.95.3/gcc_4.html

printf류 함수를 만들어서 사용할 때, 종종 변수 개수가 많아지면 헷갈려 정확한 인자를 넣지 않아 문제가 발생할 수 있다. 이를 위해 GCC는 -Wformat(또는 -Wall) 옵션을 사용하면, printf류 함수 안에 포맷스트링과 인자 타입과 개수를 검사하여 문제가 있을 경우 경고문구를 뿌려준다. C 기본 함수는 모두 이 검사 기능이 켜져 있지만, 커스텀 함수일 경우 위와 같이 __attribute__((format, (...))) 확장기능을 사용하여 컴파일러에게 알려줄 수 있다.

함수 선언부 뒤에 "__attribute__((format,(타입,포맷스트링인자위치,가변변수시작위치)))" 형태를 붙인다. 타입은 printf/scanf 두 가지 종류가 있으며, 각 위치는 '1'부터 시작한다. 단, static이 아닌 class의 method는 '2'부터 시작한다.

댓글

이 블로그의 인기 게시물

탐색기에서 OneDrive 이 2개로 보이는 문제

왜 2개가 보이는지 모르겠지만, Registry 삭제하면 됨 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Desktop\NameSpace 하위 키에서 OneDrive 둘 중에 하나만 지워도 바로 반영됨. 참조:  https://answers.microsoft.com/en-us/msoffice/forum/all/duplicate-onedrives-in-file-explorer/49c935a6-287b-43a5-aed5-2dee2a1c1b22

절전을 깨운 녀석 알아내기

가끔씩 윈도우 절전을 깨우는 녀석이 있는데, 보통은 USB Keyboard/Mouse 이다. 요런 녀석들은 장치관리자에서 "이 장치를 사용하여 컴퓨터의 대기 모드를 종료할 수 있음"을 꺼주면 된다. 그래도 가끔씩 알 수 없는 이유로 켜졌을 경우, 관리자 권한으로 커맨드 창 열고 확인한다. C:\> powercfg -lastwake 절전 모드 해제 기록 카운트 - 1 절전 모드 해제 기록[0] 절전 모드 해제 소스 카운트 - 1 절전 모드 해제 소스[0] 종류: 장치 인스턴스 경로: XXX 이름: YYY 설명: ZZZ 제조업체: AAA