strncpy
헤더 파일
[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - string.h
char * strncpy ( char * destination, const char * source, size_t n ); 부분 문자열을 복사하는 함수
입력 매개 변수 리스트
destination 문자열을 복사할 버퍼
source 복사할 원본 문자열
n 복사할 문자 개수
반환 값
destionation
strncpy 함수는 n개의 문자를 복사한 뒤 맨 뒤에 종료 문자를 추가하지 않습니다.
그리고 복사할 버퍼 크기가 n 보다 작으면 버퍼 오버플로우 문제가 발생합니다.
C11에서는 이러한 문제를 개선하는 strncpy_s 함수를 제공합니다.
사용 예
//C언어 표준 라이브러리 함수 사용법 가이드
//char * strncpy ( char * destination, const char * source, size_t n ); 부분 문자열을 복사하는 함수
//문자열을 복사한 후 출력
#pragma warning(disable:4996)
#include <string.h>
#include <stdio.h>
char *ehstrncpy(char *dest, const char *source,size_t n)
{
int i;
for (i = 0; i<n; i++)//i가 n보다 작으면 반복
{
dest[i] = source[i];
}
return dest;
}
void main (void)
{
char *src = "1234567890";
char buffer[50] = "aaaaaaa";
printf("== strncpy 사용 ==\n");
printf("buffer: %s \n",strncpy(buffer,src,5));
printf("buffer: %s \n",strncpy(buffer,src+2,5));
printf("== ehstrncpy 사용 ==\n");
printf("buffer: %s \n", ehstrncpy(buffer, src, 5));
printf("buffer: %s \n", ehstrncpy(buffer, src + 2, 5));
}
출력
== strncpy 사용 ==
buffer: 12345aa
buffer: 34567aa
== ehstrncpy 사용 ==
buffer: 12345aa
buffer: 34567aa
사용한 함수
[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - printf
관련 함수
[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - strncpy_s
[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - strcpy
[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - strcpy_s
'언어 자료구조 알고리즘 > C11 표준 라이브러리 함수' 카테고리의 다른 글
strcat_s [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
---|---|
strcat 함수 [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strncmp 함수 [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strcmp 함수[C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strncpy_s 함수[C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strcpy_s 함수 [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strcpy 함수 [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
strlen 함수 [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
string.h [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |
fsetpos [C언어 표준 라이브러리 함수 가이드] (0) | 2016.01.03 |