①strlen()
参考:https://blog.csdn.net/windyj809/article/details/80037006
功能:其用于计算字符串中字符的个数,不包括'\0',遇到'\0'结束。
注:
1、我们定义的指针不能为空,所以要使用assert进行断言。
2、因为是判断字符串长度,所以字符串是不变的,所以用const修饰,使其更加安全。
第一种方法,使用计数器的方法。即当字符数组的指针没有指向’\0’即字符串结束标志时,也就是当字符串没有结束时,让字符数组的指针一直往后移动,同时移动一位,count的值加1一次,最后函数返回count的值,即返回了字符串的长度。
实现代码如下:
#include<stdio.h>
#include<assert.h>
int mystrlen(const char* p)
{
assert(p != NULL);
int n = 0; //计数器
while(*p)
{
p++;
n++;
}
return n;
}
int main()
{
char* s = "hello";
int size = mystrlen(s);
printf("字符串长度为:%d\n",size);
return 0;
}
第二种方法,采用递归的方法。即当字符串为0即一开始就找到了’\0’,那么函数返回0,否则返回1+参数为字符串指针加1再调用此函数。同时此方法也要注意断言和const修饰两点。
实现代码如下:
int mystrlen(const char* p)
{
assert(p != NULL);
int n = 0; //计数器
if(*p == '\0')
{
return 0;
}
else
{
return (1 + mystrlen(p+1));
}
return n;
}
int main()
{
char* s = "hello";
int size = mystrlen(s);
printf("字符串长度为:%d\n",size);
return 0;
}
第三种方法,采用双指针的方法。我们知道,指针-指针的结果是返回之间元素的个数。所以我们可以定义一个指针变量将字符串首元素的地址存放起来, 然后当字符串指针没有找到’\0’时让指针后移,最后将字符串指针-刚才定义的首元素地址的指针,得到的就是字符串的个数。具体实现代码时也要注意assert断言和const修饰。
代码如下:
int mystrlen(const char* p)
{
assert(p != NULL);
const char* s = p;
while(*p)
{
p++;
}
return (p-s);
}
int main()
{
char* s = "hello";
int size = mystrlen(s);
printf("字符串长度为:%d\n",size);
return 0;
}
②strcpy()
参考:https://blog.csdn.net/windyJ809/article/details/80059937
功能:strcpy把从src地址开始且含有’\0’结束符的字符串复制到以dest开始的地址空间,返回值的类型为char*。也就是将一个字符串拷贝到另一个字符串中。
代码如下:
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char* mystrcpy(char* des, const char* src) //源字符串指针变量是不改变的,用const修饰,以起到保护作用
{
assert(des != NULL); //断言指针不为空
assert(src != NULL); //断言指针不为空
char* ret = des; //将des的地址存放在临时指针变量ret中,因为des在循环体内要发生变化。此后des变化会引起ret变化,但ret变化不会引起des变化
/* *des++ = *src++语句的结果是*src赋给*des的值,如果不是'\0',进行循环,
如果是'\0',循环结束,跳出循环。此处要使用后置++,将赋值,再进行++运算,
这样最后才能将'\0'也赋值到目标字符串中 */
while (*des++ = *src++)
{
;
}
return ret;
}
int main()
{
char a[10] = {0};
char* b = "world";
mystrcpy(a,b);
printf("%s\n",a);
return 0;
}