目录
二.长度不受限制的字符串函数 strcpy strcat strcmp
三.长度受限制的字符串函数介绍 strncpy strncat strncmp
五.错误信息报告 strerror
1.strlen函数
函数原型:
size_t strlen(const char* str); 头文件为<string.h>
参数:
str:想测量的字符串的首元素的地址
作用:
strlen函数的作用是求字符串的长度,参数为char*的指针,接受需要测量的字符串的首地址,strlen的工作原理是计算从给出地址起一直到'\0'的字符串的大小,返回类型为size_t,size_t为无符号整形(unsigned int)。
注意事项:
1.注意strlen判断字符串的结束标识为 ' \0 ' ,strlen统计的是结束标识前面的字符个数。
2.返回类型为size_t,不存在负的情况
举例说明:
模拟实现:
模拟实现原理和strlen的工作原理是一样的,都是通过判断字符串什么时候碰到字符串结束的标识符即 ' \0 ' ,所以我们的模拟实现如下。
size_t my_strlen(const char* str)
{
int num = 0;
if (str == NULL)
{
perror("default:");//进行错误判断
}
while (*str != '\0')
{
str++;
num++;
}
return num;
}
2.strcpy
函数原型
char* strcpy( char *destination , const char* source) 头文件<string.h>
函数参数
destination:想把source中字符串拷贝进的目的地址
source:要被拷贝的字符串的首元素地址
函数作用:
函数会把source中的字符串拷贝进入destination指向的空间中,但是要注意,destination要有足够的空间去接受source中的字符串,source中只拷贝结束标志(' \0 ')以前的字符串内容。
注意事项:
1.目的地址空间要足够大以便于接受要拷贝的字符串内容。
2.源字符串必须以' \0 '结尾。
3.目标空间必须可以变。
举例:
模拟实现:
#include<assert.h>
char* my_strcpy(char* dest, const char* str)
{
char* ret = dest;//便于返回dest的地址
assert(dest != NULL);
assert(str != NULL);
while (*str!='\0')
{
*dest++=*str++;
}
*dest = '\0';
return ret;
}
3.strcat
函数原型
char * strcat ( char * destination, const char * source) 头文件<string.h>
函数参数:
destination:目标地址
souce:源地址
函数作用:
在目标地址的字符串后面追加soure中字符串的内容,source中的追加字符串仍然是'\0'以前的内容,目的地址也是以第一个'\0'作为字符串的结束标志,在第一个'\0'后追加内容
函数注意事项:
1.源字符串必须以 '\0' 结束。
2.目标空间必须有足够的大,能容纳下源字符串的内容。
3.目标空间必须可修改。
4.注意给自己追加的时候会有一些问题。
举例:
模拟实现:
char* my_strcat(char* dest, const char* str)
{
char* ret = dest;
assert(dest != NULL && str!=NULL);
while (*dest != '\0')
{
*dest++;
}
while (*str != '\0')
{
*dest++ = *str++;
}
*dest = '\0';
return ret;
}
4.strcmp
函数原型
char * strcmp ( const char * str1, const char * str2) 头文件<string.h>
函数参数:
str1:要比较的字符串1
str2:要比较的字符串2
函数作用:
比较字符串1和字符串2,比较方法是逐位比较,按照ASCII码的大小来比较两个字符串,如果第一个字符串小于第二个字符串则返回一个小于零的数字,如果两个字符串完全相等,则返回零,如果第一个字符串大于第二个字符串则返回一个大于零的数字。
举例:
模拟实现:
int my_strcmp(const char* str1,const char* str2)
{
assert(str1 != NULL && str2 != NULL);
while (*str1 == *str2 && *str1!='\0'&& *str2!='\0')
{
str1++;
str2++;
}
if (*str1 - *str2 > 0)
{
return 1;
}
else if (*str2 - *str2 < 0)
{
return -1;
}
else
{
return 0;
}
}
5.strncpy
函数原型
char * strncpy ( char * destination, const char * source,size_t number)
函数参数:
destination:目的地址
source:源地址
number:要拷贝的字节数量
函数作用:
同strcpy函数,都是把源地址的字节拷贝到目标地址,但是多了数量限制,strcpy函数没有数量的限制。
函数注意事项:
如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个
举例:
6.strncat
函数原型
char * strncat ( char * destination, const char * source,size_t num)
函数参数:
destination:目标地址
source:源地址
num:要追加的字符数量
函数作用:
同strcat但是对于字符的追加数量由num来指定。
举例:
7.strncmp
函数原型:
int strncmp ( const char * str1, const char * str2,size_t num)
函数参数:
str1:要比较的字符串1
str2:要比较的字符串2
num:要比较的字符串前几位的数量
函数作用:
同strncmp,但是对于输入的大小有一定的限制
举例:
8.strstr
函数原型:
char * strstr (const char * str1, const char * str2)
函数作用:
如果str1中有str2,则返回str1中第一个匹配str2的地址,如果没有找到,则返回一个空指针,模拟实现可用暴力算法解决或者参考KMP算法。
举例:
9.strtok
函数原型
char * strtok ( char * str, const char * delimiter)
函数作用:
我们用delimiter指向我们定义的一个符号集合,这个符号集合包含了我们自己定义的这个分隔符号,用于根据分割符号来分割str指向的字符串,strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。 strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串 中的位置。 strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记,如果字符串中不包含更多的标记,则返回一个空指针。
举例:
10.strerror
函数原型:
char * strerror ( int errnum)
函数作用:
打印错误信息。其中参数errnum可以取errno,errno包含在<errno.h>这个头文件中。
举例子:
#include <stdio.h>
#include <string.h>
#include <errno.h>//必须包含的头文件
int main ()
{
FILE * pFile;
pFile = fopen ("unexist.ent","r");
if (pFile == NULL)
printf ("Error opening file unexist.ent: %s\n",strerror(errno));
//errno: Last error number
return 0;
}
Edit & Run