strncpy_s 함수

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