头文件中<string.h>中,有四个函数,strcpy 拷贝, strcat 链接 ,strcmp 比较,strlen 计算数组中字符个数(不带 '\0',这几个函数在底层是如何实现的?
1.strcpy(brr, arr),意思是将原始数组arr 拷贝给 brr,数组拷贝要求这两个数组互不影响。下述代码可以实现吗?
char ch[] = "hello";
char arr[6];
arr = ch;
封装一个函数,拷贝数组中的字符串,函数的返回值是一个数组,返回值类型为char*,遍历原始数组并赋值。
char* my_strcpy(char* brr, char* arr) {
int i = 0;
while (arr[i] != '\0') {
brr[i] = arr[i];
i++;
}
brr[i] = '\0';
return brr;
}
int main() {
char arr[15] = "hello";
char brr[6];
my_strcpy(brr, arr);
printf("%s", brr);
return 0;
}
注意,原始数组遍历完成后并没有将字符串结尾标记'\0'拷贝给brr
2.strcat(brr,arr),将arr数组链接到brr后面,要求,brr数组空间足够大,能够存储下两个数组的所有元素。my_strcat ,思路,先将 b 数组遍历到'\0'位置,然后,开始arr赋值。
void my_strcat(char*brr,char*arr){
int j = 0, i = 0;
while (brr[j] != '\0') {
j++;
}
/*for (int i = 0; i < strlen(arr); i++) {
brr[j++] = arr[i];
}*/
while (arr[i] != '\0') {
brr[j++] = arr[i++];
}
brr[j] = '\0';
}
int main() {
char arr[] = "hello";
char brr[10] = "123";
my_strcat(brr, arr);
printf("%s\n", brr);
return 0;
}
3. strcmp,字符串数组的大小比较的是首位字符,分五种情况,返回值为整型,大于1,小于-1,等于0。
int my_strcmp(char* arr, char* brr) {
int i=0, j = 0;
while (arr[i] != '\0' && brr[j] != '\0') {
if (arr[i] < brr[j]) {
return -1;
}
else if (arr[i] > brr[j]) {
return 1;
}
else { i++, j++; }
}
if (arr[i] == '\0' && brr[j] != '\0') {
return -1;
}
if (arr[i] != '\0' && brr[j] == '\0') {
return 1;
}
else { return 0; }
}
int main() {
char arr[] = "ab";
char brr[10] = "abc";
int res =my_strcmp(brr, arr);
printf("%d\n", res);
return 0;
}