Develop
2003.04.23 10:56
[c] 문자열 처리 관련 함수들 설명
조회 수 7997 댓글 0
1. 문자열 함수
strcpy(3) : 문자열을 복사한다.
strncpy(3) : 문자열의 일부를 복사한다.
strcat(3) : 문자열을 결합한다.
strncat(3) : 문자열의 일부를 결합한다.
strlen(3) : 문자열의 길이를 알아본다.
strcmp(3) : 두 문자열을 비교한다.
strncmp(3) : 두 문자열의 일부분을 비교한다.
strcasecmp(3) : 문자열의 대소문자를 가리지 않고 비교한다.
strncasecmp(3) : 대소문자를 가리지 않고 문자열의 일부를 비교한다.
strdup(3) : 문자열을 복사한다.
strchr(3) : 문자열에서 해당되는 문자의 첫번째를 찾아낸다.
strpbrk(3) : 문자열에서 해당되는 문자의 첫번째 문자의 포인터를 리턴한다.
strrchr(3) : 문자열에서 마지막으로 매치되는 문자의 포인터를 리턴한다.
strstr(3) : 문자열이 포함될 때 처음 위치의 문자를 리턴한다.
strspn(3) : 문자열이 일치하는 곳까지 문자의 갯수를 리턴한다.
strtok(3) : 문자열에서 토큰을 분리해낸다.
--------------------------------------------------------------------------------
2. 문자열 복사하기
#include <string.h>
strcpy
char *strcpy(char *dst, const char *src);
strncpy
char *strncpy(char *dst, const char *src, size_t n);
strdup
char *strdup(const char *s1);
--------------------------------------------------------------------------------
3. 문자열 길이 알아보기
strlen
size_t strlen(const char *s);
--------------------------------------------------------------------------------
4. 문자열 비교하기
strcmp
int strcmp(const char *s1, const char *s2);
strncmp
int strncmp(const char *s1, const char *s2, size_t n);
strcasecmp
int strcasecmp(const char *s1, const char *s2);
strncasecmp
int strncasecmp(const char *s1, const char *s2, int n);
다음 프로그램 string.c는 스트링에 관련된 전반적인 사용법을 익히는 프로그램이다.
예: string.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
main()
{
char * string1 = "hello";
char * string2 = "world";
char * string3;
/** malloc을 이용해서 string3을 위한 공간을 잡아둔다. **/
string3 = (char *)malloc(sizeof(char)*255);
/** string1의 문자열을 string3의 문자열에 결합시킨다. **/
strcat(string3, string1);
/** string2의 문자열을 string3의 문자열에 결합시킨다. **/
strcat(string3, string2);
printf("string1 + string2: %s :: length: %dn", string3, strlen(string3));
/** strcpy를 이용해 string1의 문자열을 string3에 복사한다. **/
strcpy(string3, string1);
printf("string copy from string1 to string3: %sn", string3);
/** strdup을 이용해 string1의 문자열을 string3에 복사한다. **/
string3 = strdup(string2);
printf("string copy from string2 to string3: %sn", string3);
/** strcmp를 이용해서 두 문자열을 비교한다.
리턴 값이 0이면 두 문자열이 같다. **/
if(strcmp(string1, string3) !=0)
printf("string1 and string3 are differnetn");
else
printf("string1 and string3 are samen");
}
--------------------------------------------------------------------------------
5. 문자열에서 원하는 내용의 일부분 찾기
strchr
char *strchr(const char *s, int c);
strrchr
char *strrchr(const char *s, int c);
strpbrk
char *strpbrk(const char *s1, const char *s2);
strstr
char *strstr(const char *s1, const char *s2);
strspn
size_t strspn(const char *s1, const char *s2);
--------------------------------------------------------------------------------
6. 문자열에서 토큰 얻기
strtok
char *strtok(char *s1, const char *s2);
다음 프로그램은 문장에서 원하는 토큰을 찾는 방법을 알려주는 프로그램이다.
예: strtok.c
#include <stdio.h>
#include <string.h>
main()
{
char *p, buf[]="Hello world";
/** buf로 부터 문자열을 읽어와 토큰을 분리한다. 토큰 분리자는 스페이스이다. **/
p = strtok(buf, " ");
/** 분리된 토큰을 출력한다. **/
printf("p = %sn", p);
/** 토큰을 계속해서 얻기위해서는 출처를 NULL로 해야한다. **/
p = strtok(NULL, " ");
printf("p = %sn", p);
p = strtok(NULL, " ");
if(p != NULL)
printf("p = %sn", p);
}
다음 프로그램은 토큰 분리자가 단순한 스페이스가 아니라 다양한 분리자를 허용하는 프로그램이다.
예: strtok2.c
#include <stdio.h>
#include <string.h>
main()
{
char *p, buf[100];
char *re;
re = gets(buf);
/** 토큰 분리자를 스페이스,탭,.,:,*,&,^,%,$,#,@,!,(,)로 설정한다. **/
p = strtok(buf, " t,.:*&^%$#@!()");
while(p != NULL) {
printf("p = %sn", p);
p = strtok(NULL, " t,.:*&^%$#@!()");
}
}
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
781 | Develop | [c] 가위 바위 보 서버, 클라이언트 소스코드 | hooni | 2003.04.23 | 8182 |
780 | Develop | [c] fork() 시스템 콜 사용 방법. | hooni | 2003.04.23 | 27593 |
779 | Develop | [c] 소켓 프로그래밍 요약.. | hooni | 2003.04.23 | 6973 |
778 | Develop | [c] 소켓주소 구조체에 대해.. | hooni | 2003.04.23 | 6736 |
777 | Develop | [c] 소켓의 세가지 동작모드 | hooni | 2003.04.23 | 6914 |
776 | Develop | [c] 컴파일러 DFA구현^^ 입력 받아 실행 4 | hooni | 2003.04.23 | 8116 |
775 | Develop | [c] OpenGL 시어핀스키 가스킷(p.73 - 첫시간) | hooni | 2003.04.23 | 8761 |
774 | Develop | [c] 시어핀스키 가스킷..(p.582, A.2 - 두번째) | hooni | 2003.04.23 | 7485 |
773 | Develop | [c] 약수/최대공약수/완전수 알고리즘 | hooni | 2003.04.23 | 8872 |
772 | Develop | [c] 프로그래밍의 전반적인 설명 ppt | hooni | 2003.04.23 | 7677 |
771 | Develop | [jsp] HelloServlet 출력문 | hooni | 2003.04.23 | 7801 |
770 | Develop | [jsp] Get방식, Post방식 전송 예제.. | hooni | 2003.04.23 | 13766 |