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
1219

被折叠的 条评论
为什么被折叠?



