函数的使用和模拟实现

1.strlen的使⽤和模拟实现

size_t strlen ( const char * str );

• 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前⾯出现的字符个数(不包 含 '\0' )。

• 参数指向的字符串必须要以 '\0' 结束。

• 注意函数的返回值为size_t,是⽆符号的( 易错 )

• strlen的使⽤需要包含头⽂件 • 学会strlen函数的模拟实现

strlen的模拟实现:

//计数器⽅式

⽅式1:

int my_strlen(const char * str)

{ int count = 0; assert(str); while(*str) { count++; str++; } return count; }

⽅式2:

//不能创建临时变量计数器

int my_strlen(const char * str)

{ assert(str); if(*str == '\0') return 0; else return 1+my_strlen(str+1); }

⽅式3:

//指针-指针的⽅式

int my_strlen(char *s)

{ assert(str); char *p = s; while(*p != ‘\0’ ) p++; return p-s; }

2.strcpy的使⽤和模拟实现

char* strcpy(char * destination, const char * source );

• 源字符串必须以 '\0' 结束。

• 会将源字符串中的 '\0' 拷⻉到⽬标空间。

• ⽬标空间必须⾜够⼤,以确保能存放源字符串。

• ⽬标空间必须可修改。

• 学会模拟实现

strcpy的模拟实现:

//1.参数顺序 //2.函数的功能,停⽌条件 //3.assert //4.const修饰指针 //5.函数返回值 

char *my_strcpy(char *dest, const char*src)

{ char *ret = dest; assert(dest != NULL); assert(src != NULL);

while((*dest++ = *src++)) { ; } return ret; }

3.strcat的使⽤和模拟实现

• 源字符串必须以 '\0' 结束。

• ⽬标字符串中也得有 \0 ,否则没办法知道追加从哪⾥开始。

• ⽬标空间必须有⾜够的⼤,能容纳下源字符串的内容。

• ⽬标空间必须可修改。

模拟实现strcat函数:

char *my_strcat(char *dest, const char*src) { char *ret = dest;

assert(dest != NULL); assert(src != NULL);

while(*dest) { dest++; } while((*dest++ = *src++)) { ; } return ret; }

4.trcmp的使⽤和模拟实现

• 标准规定:

◦ 第⼀个字符串⼤于第⼆个字符串,则返回⼤于0的数字

◦ 第⼀个字符串等于第⼆个字符串,则返回0

 ◦ 第⼀个字符串⼩于第⼆个字符串,则返回⼩于0的数字

 ◦ 那么如何判断两个字符串? ⽐较两个字符串中对应位置上字符ASCII码值的⼤⼩。

strcmp函数的模拟实现:

int my_strcmp (const char * str1, const char * str2)

{ int ret = 0 ; assert(src != NULL); assert(dest != NULL);

while(*str1 == *str2) { if(*str1 == '\0') return 0; str1++; str2++; } return *str1-*str2; }

5.strncpy函数的使⽤

char * strncpy ( char * destination, const char * source, size_t num );

• 拷⻉num个字符从源字符串到⽬标空间。

• 如果源字符串的⻓度⼩于num,则拷⻉完源字符串之后,在⽬标的后边追加0,直到num个。

5.strncat函数的使⽤

char * strncat ( char * destination, const char * source, size_t num );

• 将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加⼀个 \0 字 符。

• 如果source指向的字符串的⻓度⼩于num的时候,只会将字符串中到 \0 的内容追加destination指向的字符串末尾。

int main () { char str1[20]; char str2[20]; strcpy (str1,"To be ");

strcpy (str2,"or not to be"); strncat (str1, str2, 6); printf("%s\n", str1); return 0; }

6.strncmp函数的使⽤

int strncmp ( const char * str1, const char * str2, size_t num );

⽐较str1和str2的前num个字符,如果相等就继续往后⽐较,最多⽐较num个字⺟,如果提前发现不⼀ 样,就提前结束,⼤的字符所在的字符串⼤于另外⼀个。如果num个字符都相等,就是相等返回0.

7.strstr的使⽤和模拟实现

char * strstr ( const char * str1, const char * str2);

函数返回字符串str2在字符串str1中第⼀次出现的位置

字符 串的⽐较匹配不包含 \0 字符,以 \0 作为结束标志

/* strstr example */ #include #include

int main () { char str[] ="This is a simple string"; char * pch;

pch = strstr (str,"simple"); strncpy (pch,"sample",6); printf("%s\n", str); return 0; }

strstr的模拟实现:

char * strstr (const char * str1, const char * str2)

{ char *cp = (char *) str1; char *s1, *s2;

if ( !*str2 ) return((char *)str1); while (*cp) { s1 = cp; s2 = (char *) str2;

while ( *s1 && *s2 && !(*s1-*s2) ) s1++, s2++; if (!*s2) return(cp); cp++; } return(NULL); }

8.strtok函数的使⽤

char * strtok ( char * str, const char * sep);

• sep参数指向⼀个字符串,定义了⽤作分隔符的字符集合

 • 第⼀个参数指定⼀个字符串,它包含了0个或者多个由sep字符串中⼀个或者多个分隔符分割的标 记。

• strtok函数找到str中的下⼀个标记,并将其⽤ \0 结尾,返回⼀个指向这个标记的指针。

(注: strtok函数会改变被操作的字符串,所以在使⽤strtok函数切分的字符串⼀般都是临时拷⻉的内容 并且可修改。)

• strtok函数的第⼀个参数不为 NULL ,函数将找到str中第⼀个标记,strtok函数将保存它在字符串 中的位置。

• strtok函数的第⼀个参数为 NULL ,函数将在同⼀个字符串中被保存的位置开始,查找下⼀个标 记。

• 如果字符串中不存在更多的标记,则返回 NULL 指针。

int main() { char arr[] = "192.168.6.111"; char* sep = "."; char* str = NULL;

for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep)) { printf("%s\n", str); } return 0; }

9.strerror函数的使⽤

char * strerror ( int errnum );

strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来

int main() { int i = 0; for (i = 0; i 10; i++) { printf("%s\n", strerror(i)); } return 0; }

perror函数相当于直接将错误信息打 印出来。

perror函数打印完参数部分的字符串后,再打印⼀个冒号和⼀个空格,再打印错误信息。

int main () { FILE * pFile; pFile = fopen ("unexist.ent","r");

if (pFile == NULL) perror("Error opening file unexist.ent"); return 0; }

输出:

Error opening file unexist.ent: No such file or directory

  • 25
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值