티스토리 뷰

sprintf의 문제

문자열 복사를 위해서 sprintf 함수를 자주 사용하게 되는데,다국어 프로그래밍 시에 sprintf를 사용하면 스트링 복사시에 ANSI 값 즉 1바이트만 복사하게 되어 출력되고자 하는 다국어 문자열이 이상하게 표시되는 오류가 발생될 수 있다.유니코드를 위한 swprintf나 wsprintf를 쓰도록 하자.

위의 이미지를 한번 보자. 변수 A와 B가 메모리에 8바이트 2바이트 할당되어 있다고 가정하자. 그런데 아래와 같이 8바이트 문자열을 sprintf함수를 사용해서 쓰면 실제로는 마지막에 널 문자 0까지 붙어서 9바이트가 들어가게 된다. abcdefgh0 이런식으로 말이다. 그럼 변수 B의 영역을 침범하게 되므로 이건 메모리 오버플로우 에러가 발생하게 된다. 이런 버그는 참 찾기 힘들다. 주의해야 한다.

sprintf(a, "abcdefgh");