1.memcpy函数
(1)函数的模拟实现,这个函数的作用就是把arr1拷贝到arr2里面,单位是字节,20字节就是5整
数,所以输出的就是1234500000;
(2)之所以强制类型转换成为char*是因为这个类型的单位是字节,他的力度更加的细致;
(3)循环里面的加上1就会只移动一个字节,4次循环才拷贝1个整数;
2.memmove函数
主函数
int main()
{int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };mymemmove(arr1, arr1+2, 20);int i = 0;for (i = 0; i < 10; i++){printf("%d ", arr1[i]);}return 0;
}
函数实现
void* mymemmove(void* dest, const void* src, size_t num)
{void* ret = dest;assert(dest && src);if (dest < src){while (num--){*(char*)dest = *(char*)src;dest = (char*)dest + 1;src = (char*)src + 1;}}else{while (num--){*((char*)dest + num) = *((char*)src + num);}}return ret;
}
(1)这个函数在memcpy函数的基础上进行了优化,可以对自己和自己进行拷贝;
(2)这个函数要分为从后向前拷贝还是从前向后拷贝,因为不同的位置,拷贝的方式可能导致原
来的数据被覆盖掉
(3)这里的逻辑就是目的地在源头的前面就从前向后进行,目的地在源头的后面就从后向前进行
这个在后面是之间有交集,如果毫不相干的话就2种方式都可以;else里面的加上num就是找到最
后的位置向前拷贝;
3.memset函数
(1)函数就是实现重置,以字节作为单位,给的参数是起始地址arr,1是把范围内的元素都从0变成1,40就是范围,即40个字节,也就是10个整数,就是整个数组;
4.memcmp函数
(1)字符串的比较:⽐较从ptr1和ptr2指针指向的位置开始,向后的num个字节;我们这里相当于
全部比较;
(2)前面的2个参数分别是指向的地址,从这2个位置开始比较;