errno_t strncpy_s ( char * destination,size_t size, const char * source, size_t n ); 부분 문자열을 복사하는 함수
입력 매개 변수 리스트
destination 문자열을 복사할 버퍼
size destination 버퍼 크기
source 복사할 원본 문자열
n 복사할 문자 개수
반환 값
에러 번호
strncpy 함수는 n개의 문자를 복사한 뒤 맨 뒤에 종료 문자를 추가하지 않습니다. 그리고 복사할 버퍼 크기가 n 보다 작으면 버퍼 오버플로우 문제가 발생합니다. strncpy_s는 이러한 문제를 개선한 C11 표준에서 제공합니다. strncpy_s 함수를 사용할 때는 두 번째 인자로 문자열을 복사할 버퍼의 크기를 전달합니다.
사용 예
//C언어 표준 라이브러리 함수 가이드 //errno_t strncpy_s ( char * destination, size_t size, const char * source, size_t n ); 부분 문자열을 복사하는 함수 //문자열을 복사한 후 출력 #include <assert.h> #include <string.h> #include <stdio.h> void ehstrncpy_s(char *dest,size_t size, const char *source, size_t n) { size_t i; assert(size >= n);//size는 n보다 크거나 같아야 함 for (i = 0; i<n; i++)//i가 n보다 작으면 반복 { dest[i] = source[i]; } } int main(void) { char *src = "1234567890"; char buffer[50] = "aaaaaaa"; printf("== strncpy_s 사용 ==\n"); strncpy_s(buffer, sizeof(buffer), src, 5); printf("buffer: %s \n", buffer ); strncpy_s(buffer, sizeof(buffer), src + 2, 5); printf("buffer: %s \n", buffer); printf("== ehstrncpy_s 사용 ==\n"); ehstrncpy_s(buffer, sizeof(buffer), src, 5); ehstrncpy_s(buffer, sizeof(buffer), src + 2, 5); printf("buffer: %s \n", buffer); printf("buffer: %s \n", buffer); return 0; }
출력
== strncpy 사용 == buffer: 12345aa buffer: 34567aa == ehstrncpy 사용 == buffer: 12345aa buffer: 34567aa