一、 strlen
1. ‘\0’
‘\0’是字符串结束的表示
而strlen是统计直到‘\0’位置 不包括‘\0’
2. 返回值
strlen的返回值是一个无符号整数 所以它一定是正数
3. strlen的模拟实现
我总结了三种写法
常规:
递归:
指针 - 指针:
二、 strcpy
我们先来看cpp中的strcpy函数
char * strcpy ( char * destination, const char * source );
我们可以发现 它的返回值是一个char类型的指针
它的参数有两个都是指针 一个指向目的地 一个指向源地址
1. 源字符串必须以’\0’结束
这个很好理解 如果源字符不是以’\0’结束的话 那么它要拷贝的长度是未知的
我们不能很好的控制这个函数
2. 目标空间要足够大 能够存放需要拷贝的数据
这个是常识了 如果目标空间不够大会报错
3. 模拟实现
其实这个函数我们再前面以及模拟实现过了
设计两个指针 一个指向目的地 一个指向源字符串
然后将源字符串的值赋值给目的地 并且接着下一个字符 直到达到源目的地的\0为止
代码如下:
三、 strcmp
1. 定义
我们规定
第一个字符串大于第二个字符串 则返回大于0的数字
第一个字符串等于第二个字符串 则返回0
第一个字符串小于第二个字符串 则返回小于0的数字
2. 如何判断?
我们逐个比较字符串内字符的ascll码值
再按照上面定义的标准 返回1 0 -1这三个值
3. 模拟实现
运行结果如下:
四. strcat
1. 定义
字符串拼接函数 将一个字符串拼接到任何一个字符串末尾(‘\0’)
des是被拼接字符串
sour是拼接字符串
strcat会将sour的\0也拼接上 当然我们的目标字符串需要足够大
2. 模拟实现
代码如下:
可以运行
3. 注意事项
值得注意的是 strcat并不能实现字符串自身的拼接 因为再拼接的时候会改变字符串自身的字符 从而导致死循环
五. strstr
1. 定义
再一个字符串内部寻找一个字符串是否存在
返回值是原字符串中 首元素第一次出现的位置
2. 模拟实现
第一步首先查找sour字符串中是否有和des字符串开头相同的字符如果有开始逐个遍历是否每个元素都相同直到遍历到des字符串的\0如果不相同p指向下一个元素查找是否和des的首元素相同
代码如下:
运行结果: