在使用strcpy(d,s);函数时会把‘\0’也考入字符中,打印遇到'\0'就会停止,原arr1中‘\0’后还有 * 字符。
接下来自己写一个my_strcpy函数,实现如系统strcpy一样的功能。
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
//#include<string.h>
//debug version 1
//void my_strcpy(char* dest,char* src)
//{
// while (*src!='\0')//传入字符不为'\0'则继续传字符
// {
// *dest = *src;//传入对应数组下标的元素
// src++;
// dest++;
// }
// *dest = *src;//将'\0'传入字符
//}
//debug version 2 实现语句优化以及'\0'一起传入
void my_strcpy(char* dest, char* src)
{
while (*dest++ = *src++)//传入字符
{
;
}
}
int main() {
char arr1[] = "********";
char arr2[] = "lalala";printf("%s", arr1);//%s打印地址会打印出里面内容
return 0;
}
库函数中这样描述的如下图
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
//debug version 3 想到用户操作问题char * my_strcpy(char* dest, const char* src)//const 修饰*src 防止误操作修改
{
char* ret = dest;//记录desrt初始地址,最后返回
assert(dest!=NULL);
assert(src != NULL);
while (*dest++ = *src++);//传入字符
return ret;
}
int main() {
char arr1[] = "********";
char arr2[] = "lalala";printf("%s",my_strcpy(arr1, arr2));//%s打印地址会打印出里面内容
return 0;
}
根据以上自写strlen
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>
int my_strlen(const char* arr)
{
assert(arr!=NULL);
int count = 0;//用于计数
while (*arr++ != '\0')
{
count++;
}
return count;
}int main() {
char arr[] = "abcdef";
int len = my_strlen(arr);
printf("%d", len);return 0;
}