一.常用的字符串函数(大部分都存放在<string.h>函数库中)
1.strlen——计算字符串长度函数
声明为 :size_t strlen ( const char * str );
因为字符串以'\0'作为结束标志 ,而strlen函数统计的是'\0'之前的所有字符串的长度(不包含'\0').
如果没有'\0',则返回值为一个随机值。
如:
strlen函数有三种模拟方法:
方法1:
//计数器方式
int my_strlen(const char * str)
{
int count = 0;
while(*str)
{
count++;
str++;
}
return count;
}
方法2
//不能创建临时变量时,考虑递归方式
int my_strlen(const char * str)
{
if(*str == '\0')
return 0;
else
return 1+my_strlen(str+1);
}
方法三:
//指针-指针的方式
int my_strlen(char *s)
{
char *p = s;
while(*p != ‘\0’ )
p++;
return p-s;
}
请注意
#include <stdio.h>
int main()
{
const char*str1 = "abcdef";
const char*str2 = "bbb";
if(strlen(str2)-strlen(str1)>0)
{
printf("str2>str1\n");
}
else
{
printf("srt1>str2\n");
}
return 0;
}
这段代码的结果是什么?
答案是
注意函数的返回值为size_t,是无符号的( 易错)
2.strcpy——字符串拷贝函数
函数声明为:char* strcpy(char * destination, const char * source );
作用是将字符串source的内容拷贝到destination中去
如
模拟实现
char *my_strcpy(char *dest, const char*src)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while((*dest++ = *src++))
{
;
}
return ret;
}
3.strcat——字符串连接函数
函数声明为:char * strcat ( char * destination, const char * source );
作用是将字符串source的内容连到destination中去
注意:
源字符串必须以'\0' 结束。
目标空间必须有足够的大,能容纳下源字符串的内容。
目标空间必须可修改。
模拟实现
#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, const char*src)
{
assert(dest && src);
char* ret = dest;
//找目标空间中的\0
while (*dest != '\0')
{
dest++;
}
//拷贝
while (*dest++ = *src++)
{
;
}
return ret;
}
思考:能不能自己链接自己?
4.strcat——字符串比较函数
函数声明为:int strcmp ( const char * str1, const char * str2 );
标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
如
模拟实现
#include<stdio.h>
#include<string.h>
#include<assert.h>
int my_strcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
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个。
6.strncat——长度受限制的字符串链接函数
函数声明:char * strncat ( char * destination, const char * source, size_t num );
链接到source中的num个字符结束
注意:和strncat在思考问题的结果上有不同
7.strncmp——长度受限制的字符串比较函数
比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完。
此三个函数和之前三个没什么区别,只是更加安全,故不展开更多叙述.
8 strstr ——字符串查询函数
函数声明:char * strstr ( const char *str1, const char * str2);
用于判断字符串str2是否是str1的子串。
如果是,则该函数返回 str1字符串从 str2第一次出现的位置开始到 str1结尾的字符串;否则,返回NULL。
如:
模拟实现
char* my_strstr(const char*str1, const char* str2)
{
char* s1 = NULL;
char* s2 = NULL;
char* cp = (char*)str1;
while (*cp)
{
s1 = cp;
s2 = (char*)str2;
while (*s1 && *s2 && *s1 == *s2)
{
s1++;
s2++;
}
if (*s2 == '\0')
{
return cp;
}
cp++;
}
return NULL;
}
9 strtok ——字符串分割函数
函数声明:char * strtok ( char * str, const char * sep );
sep参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标
记。
strtok函数找到str中的下一个标记,并将其用\0 结尾,返回一个指向这个标记的指针。(注:
strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容
并且可修改。)
strtok函数的第一个参数不为NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串
中的位置。
strtok函数的第一个参数为NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标
记。
如果字符串中不存在更多的标记,则返回NULL 指针。
如
10 strerror——字符串错误信息函数
函数声明:char * strerror ( int errnum );
返回错误码,所对应的错误信息。
二.常用的内存函数
1 memcpy——内存拷贝函数
函数声明:void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
这个函数在遇到'\0' 的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的。
如:
模拟实现
#include<stdio.h>
#include<assert.h>
void my_memcpy(char* dest, const void* src, size_t num)
{
assert(dest && src);
void* ret = dest;
while (num--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest+1;
src = (char*)src+1;
}
}
2 memmove——内存拷贝函数
函数声明:void * memmove ( void * destination, const void * source, size_t num );
和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。
如:
模拟实现
#include<stdio.h>
#include<assert.h>
void my_memmove(char* dest, const void* src, size_t num)
{
assert(dest && src);
void* ret = dest;
if (dest < src)
{
while (num--)
{
*(char*)dest= *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
}
else
{
while (num--)
{
*((char*)dest + num) = *((char*)src + num);
}
}
}
3 memcmp——内存比较函数
函数声明:int memcmp ( const void * ptr1,const void * ptr2,size_t num );
比较从ptr1和ptr2指针开始的num个字节,如果ptr1大于ptr2,返回大于0的数字;如果等于ptr2,返回0;否则返回小于0的数字.
如: