目录

1.strlen函数

2.strcpy函数

3.strcat函数

4.strncat函数

5.strcmp函数

6.strimp函数

7.strncmp函数

拓展:

(1)strnicmp函数

(2)strcasecmp函数

(3)strncasecmp函数

8.strchr函数

9.strrchr函数

10.strcspn函数

11.strspn函数

12.strdup函数

13.strrev函数

14.strstr函数

15.strtok函数

拓展:

(1)strtok_s函数

(2)strtok_r函数

16.strpbrk函数

17.substr函数——s.substr(l, r)


1.strlen函数

原型:size_tstrlen(const char *str)

功能:返回字符串str的长度(不包括’\0′)。

实现如下:

size_t my_strlen(const char *str){assert(str != NULL);int count = 0;while (*str != '\0'){count++;str++;}return count;}

2.strcpy函数

原型:char *strcpy(char *dest, const char *src)

功能:strcpy为覆盖拷贝,将src所指向的内容全覆盖拷贝到dest。

实现如下:

void my_strcpy(char *dest, const char *src){while (*src){*dest = *src;++src;++dest;}*dest = '\0';}

3.strcat函数

原型:char* strcat(char *dest, const char *src)

功能:功能为连接两个字符串,把src连接到dest后面;返回dest地址。

实现如下:

char *my_strcat(char *dest,const char *src){char* addr=dest;while(*dest)//{dest++;};while(*dest++=*src++){};return addr;}

4.strncat函数

原型:char *strncat(char *dest, const char *src, int n)

功能:指定长度,追加拷贝,将src指向的字符串的前n个字符追加拷贝到dest指向的字符串后面。

实现如下:

char *my_strncat(char *dest, const char *src, int n){char* ret = dest;assert(dest != NULL && src != NULL);while (*dest != '\0')dest++;while (n && (*dest++ = *src++) != '\0')n--;*dest = '\0';return ret;}

5.strcmp函数

原型:int strcmp(const char *str1, const char *str2)

功能:比较两个字符串的大小,一个字符一个字符比较,按ASCLL码比较。
标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字

实现如下:

int my_strcmp(const char *str1, const char *str2){while(*str1==*str2){if(*str1=='\0')return 0;str1++;str2++;}return *str1-*str2;}

6.strimp函数

原型:int stricmp(const char *str1, const char *str2)

功能:比较字符串str1和str2,按ASCLL码比较,但不区分字母的大小写。
当str1<str2时,返回值<0
当str1=str2时,返回值=0
当str1>str2时,返回值>0

实现如下:

int my_strcmp(const char *str1, const char *str2){while(*str1==*str2||(*str1+32)==*str2||(*str1-32)==*str2){if(*str1=='\0')return 0;str1++;str2++;}return *str1%97-*str2%97;}

7.strncmp函数

原型:int strncmp(const char *str1, const char *str2,int n)

功能:比较字符串str1和str2的前n个字符串,按ASCLL码比较。
当str1<str2时,返回值<0
当str1=str2时,返回值=0
当str1>str2时,返回值>0

实现如下:

int my_str_ncmp(const char * str1, const char * str2, int n){if (NULL == str1 || NULL == str2 || n <= 0){exit(EXIT_FAILURE);}char* pos1 = NULL;char* pos2 = NULL;pos1 = str1;pos2 = str2;int ret = 0;while (0 != n && (*pos1 == *pos2)){++pos1;++pos2;--n;}ret = *pos1 - *pos2;if (0 == ret)return 0;else if (ret < 0)return -1;elsereturn 1;}

拓展:

(1)strnicmp函数

原型:int strnicmp(const char *str1, const char *str2,int n)

功能:比较字符串str1和str2的前n个字符串,按ASCLL码比较,但不区分字母的大小写。
当str1<str2时,返回值<0
当str1=str2时,返回值=0
当str1>str2时,返回值>0

(2)strcasecmp函数

Linux下特有函数,功能相当于stricmp函数

(3)strncasecmp函数

Linux下特有函数,功能相当于strnicmp函数

8.strchr函数

原型:char *strchr(char *str, char c)

功能:查找str中首次出现c的位置,如有有,则返回出现位置,否则返回NULL。

实现如下:

char *my_strchr(char *str, char c){while(*str!='\0'&&*str!=c){str++;}return (*str==c? str: NULL);}

9.strrchr函数

原型:char *strrchr(char *str, char c)

功能:查找str中最后一次出现c的位置,如有有,则返回出现位置,否则返回NULL。

实现如下:

char *my_strrchr(char *str, char c){char *p=str+strlen(str);//p指向最后一个字符while(p!=str&&*p!=c)p--;if(p==str&&*p!=c)return NULL;else return p;}

10.strcspn函数

原型:size_t strcspn(const char *pstr, const char *strCharset)

功能:用于检索pstr开头连续有几个字符不包含于strCgarset中。

实现:https://blog.csdn.net/chenyu2202863/article/details/5293941

11.strspn函数

原型:size_t strspn(const char *pstr, const char *strCharset)

功能:用于检索pstr开头连续有几个字符包含于strCgarset中。

12.strdup函数

原型:char* strdup(const char* str)

功能:拷贝字符串到新建的内存,返回内存指针。若失败,返回NULL。(返回的指针指向的内存在堆中,需要手动释放。)

实现如下:

char *my_strdup(const char *str){char *p=NULL;if(str&&(p=(char*)malloc(strlen(str)+1)))strcpy(p,str);return p;

13.strrev函数

原型:char *strrev(char *str)

功能:反转字符串,返回字符串指针。

实现如下:

char *my_strrev(char *str){if(str==NULL)return NULL;char *start=str;char *end=str+strlen(str)-1;char temp;while(start<end){temp=*start;*start=*end;*end=temp;start++;end--;}return str;}

14.strstr函数

原型:char *strstr(const char str1, const char *str2)

功能:在字符串str1中查找是否含有字符串str2,如果存在,返回str2在str1中第一次出现的地址;否则返回NULL。

实现如下:

char *my_strstr(const char str1, const char *str2){int length1=strlen(str1);int length2=strlen(str2);while(length1>=length2){length1--;if(!strncpy(str1,str2,length2))//比较前n个字符串,类似strcpyreturn str1;str1++;}return NULL;}

15.strtok函数

原型:char *strtok(char *str, const char *delim)

功能:在str指向的字符串中检索包含于delim所指向的字符串中的字符,并对str进行分割;返回str被分解的第一个子字符串,若无可检索的字符串,则返回NULL。

实现如下:

char *my_strtok(char *str,const char *delim){static char *next_start = NULL; if(str == NULL && (str = next_start) == NULL){return NULL;}char *s = str;const char *t = NULL;while(*s){t = delim;while(*t){if(*t == *s){next_start = s + 1;if(s == str) {str = next_start;break;}else{*s = '\0';return str;}}else{t++;}}s++;}return NULL;}

拓展:

(1)strtok_s函数

原型:char *strtok_s( char *strToken, const char *strDelimit, char **buf)

strtok_s是windows下的一个分割字符串安全函数,这个函数将剩余的字符串存储在buf变量中,而不是静态变量中,从而保证了安全性。

(2)strtok_r函数

原型:char *strtok_r(char *str, const char *delim, char **saveptr)

strtok_s函数是linux下分割字符串的安全函数,该函数也会破坏待分解字符串的完整性,但是其将剩余的字符串保存在saveptr变量中,保证了安全性。

16.strpbrk函数

原型:char * strpbrk(const char *str1,const char *str2)

功能:从str1的第一个字符向后检索,直到’\0’,如果当前字符存在于str2中,那么返回当前字符的地址,并停止检索;若str1、str2中无相同的字符,则返回NULL。

实现如下:

char * strpbrk(const char * cs,const char * ct){const char *sc1,*sc2; for( sc1 = cs; *sc1 != '\0'; ++sc1) {for( sc2 = ct; *sc2 != '\0'; ++sc2) {if (*sc1 == *sc2)return (char *) sc1;}}return NULL;}

17.substr函数——s.substr(l, r)

功能:用于截取字符串,从第l个截取至第r个

【例】

#include#includeusing namespace std;int main(){string s;cin >> s;string t = s.substr(2, 5);cout << t;return 0;}