函数介绍
求字符串长度
strlen
长度不受限制的字符串函数
strcpy
strcat
strcmp
长度受限制的字符串函数介绍 strncpy
strncat
strncmp
字符串查找
strstr
strtok
错误信息报告
strerror
字符操作
内存操作函数
memcpy
memmove
strlen
size_t strlen ( const char * str );
字符串已经 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )。
参数指向的字符串必须要以 ‘\0’ 结束。
注意函数的返回值为size_t,是无符号的( 易错 )
strlen函数的模拟实现
//方法一
int MyStrlen(char *str)
{
int count = 0;
while (*str != '\0')
{
count ++;
str ++;
}
return count;
//方法二
int MyStrlen1(char * str)
{
char *p = str;
while (*p)
{
p++;
}
return p - str;
}
}
strcpy
char* strcpy(char * destination, const char * source );
源字符串必须以 ‘\0’ 结束。
会将源字符串中的 ‘\0’ 拷贝到目标空间。
目标空间必须足够大,以确保能存放源字符串。
目标空间必须可变。
strcpy模拟实现
char *MyStrcpy(char *dst, const char *src)
{
char *ret = dst;
assert(dst && src);
while (*dst++ = *src++);
return ret;
}
stract
char * strcat ( char * destination, const char * source );
源字符串必须以’\0’ 结束。
目标空间必须有足够的大,能容纳下源字符串的内容。
目标空间必须可修改。
stract模拟实现
char *MyStrcat(char *dst, const char*src)
{
assert(dst && src);
char *ret = dst;
while (*dst)
{
dst++;
}
while ((*dst++ = *src++));
return ret;
}
strcmp
int strcmp(const char * str1, const char * str2 );
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
strcmp模拟实现
int MyStrcmp(char *dst, char *src)
{
assert(dst && src);
if (dst == NULL)
return -1;
if (src == NULL)
return 1;
while (*dst = *src)
{
if (*dst = '\0')
{
return 0;
}
}
if (*dst > *src)
{
return 1;
}
else
{
return -1;
}
}
strcnpy
char * strncpy ( char * destination, const char * source, size_t num
);
拷贝num个字符从源字符串到目标空间。
如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。
strncat
char * strncat ( char * destination, const char * source, size_t num
);
链接num个字符从源字符串到目标空间,并添加一个终止null字符。
如果源字符串的长度小于num,则只复制到终止符null之前的内容。
strncmp
int strcmp(const char *str1,const char *str2,size_t num);
比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完。
strstr
char * strstr ( const char *, const char * );
返回一个指向str1中第一个出现str2的指针,如果str2不是str1中的一部分,则返回一个空指针。
strstr模拟实现
char *MyStrstr(char *str1, char *str2)
{
assert(str1 && str2);
char *start = str1;
while (*start)
{
char *s1 = start;
char *s2 = str2;
while (*s1 && *s2 && *s1 == *s2)
{
s1++;
s2++;
}
if (*s2 == '\0')
{
return start;
}
start++;
}
return NULL;
}
strtok
char * strtok ( char * str, const char * sep );
sep参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:strtok函数会改
变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
如果字符串中不存在更多的标记,则返回 NULL 指针。
strerror
char *strerror(int errnum);
返回错误码,所对应的错误信息;
memcpy
void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据destination的内存位置。
这个函数在遇到 '\0’的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的。
memcpy模拟实现
void *MyMemcpy(void *dst,void *src,int count)
{
assert(dst && src);
void *ret = dst;
while (count--)
{
*(char*)dst = *(char*)src;
((char*)dst)++;
((char*)src)++;
}
return ret;
}
memmove
void * memmove ( void * destination, const void * source, size_t num
);
和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。
memmove模拟实现
void *MyMemMove(void *dst, void *src, int count)
{
assert(dst && src);
void *ret = dst;
if (dst <= src)
{
while (count--)
{
*(char*)dst = *(char*)src;
((char*)dst)++;
((char*)src)++;
}
}
else
{
(char*)dst = (char*)dst + count - 1;
(char*)src = (char*)src + count - 1;
while (count--)
{
*(char*)dst = *(char*)src;
((char*)dst)--;
((char*)src)--;
}
}
return ret;
}