1.模拟实现strcpystrcpy(str1,str2)函数是把从str2地址开始且含有NULL结束符的字符串复制到以str1开始的地址空间中,而且str2和str1所指内存区域不可以重叠。这就要求str1必须有足够的空间来容纳str2的字符串。
//模拟实现strcpy ,'\0'也会被拷贝进去,返回值为char*
#include
#include
#include//断言的头文件
char* My_strcpy(char* str1, const char* str2)//str2不可改变,用const 修饰
{
char* ret=str1;
assert(str1 != NULL && str2 != NULL);//断言
while ((*str1++ = *str2++)!='\0')//优化后的代码
{
;
}
return ret;
}
int main()
{
char arr1[20] = "abcdef";
char *arr2 = "gh";
printf("%s\n", My_strcpy(arr1, arr2));
system("pause");
return 0;
}
2.模拟实现strcat字符串连接函数,既将两个字符串连接在一起
#include <stdio.h>
#include<Windows.h>
#include<assert.h>
char* My_strcpy(char* str1, char* str2)
{
char* ret=str1;
assert(str1 != NULL && str2 != NULL);
//与strcpy不同的是开始拷贝的位置不同(多加以下三行代码)
while (*str1 != '\0')
{
str1++;
}
while ((*str1++ = *str2++)!='\0')
{
;
}
return ret;
}
int main()
{
char arr1[20] = "abcdef";
char *arr2 = "gh";
printf("%s\n", My_strcpy(arr1, arr2));
system("pause");
return 0;
}
3.*****模拟实现strstr(重新研究此题) 重点寻找子串
//strstr寻找子串
#include
#include
#include
char* My_strstr(char* str1, char* str2) {
assert(str1&&str2);
while (*str1 != *str2)
{
str1++;
}
char *p = str1;
while ((*str1)&&(*str2) && (*str1 == *str2))
{
str1++;
str2++;
}
if (*str2=='\0')
return p;
else
return 0;
}
int main()
{
char arr1[20] = "abcdef";
char arr2[] = "bc";
int ret=My_strstr(arr1, arr2);
if (ret == 0)
printf("没找到\n");
else
printf("找到啦,位置是%p\n", ret);
system("pause");
return 0;
}