本文主要是介绍C++|动手实现strcpy、memcpy、memmove,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
strcpy
手写一个字符串拷贝函数:
char* my_strcpy(char* dest, const char* src) {char* dest_ptr = dest;while (*src != '\0') *dest_ptr++ = *src++;*dest_ptr = '\0';return dest;
}
- 确定好函数原型,函数返回目标字符串 dest 的地址,复制原字符串
const char *src
到目标字符串char* dest
; - 保存目标地址的起始位置:保存其实位置,因为我们待会儿还得把他返回呢。
- 逐字符复制:有个小技巧
*dest_ptr = *src++;
- 添加空字符结尾:千万别忘
- 返回目的地址:
return dest
memcpy
如果源内存区域和目的内存区域有重叠,memcpy 的行为是未定义的。在这种情况下,应该使用 memmove 函数,它能够正确处理重叠的内存区域。
memcpy 的使用场景一般在初始化数组、复制结构体或对象等。
void* my_memcpy(void* dest, const void* src, size_t count) {if (dest == NULL || src == NULL) return NULL;char* d = (char*)dest;char* s = (char*)src;while (count--) {*d++ = *s++;}return dest;
}
- 函数原型:需要注意的是,内存区域可能是任何类型
- 空哦指针检查
- 类型转换,都转换为char*类型,以便逐字节操作内存
- 逐字节复制
- 返回目标地址
memmove
memmove主要就是为了解决内存重叠现象。在内存重叠时我们应该使用memmove,因为它从后向前拷贝,可以避免任何src和dest的重叠情况下的内存数据拷贝。
#include <stddef.h> // for size_tvoid* my_memmove(void* dest, const void* src, size_t count) {if (dest == NULL || src == NULL) return NULL; // 检查空指针char* d = (char*)dest;const char* s = (const char*)src;if (d < s) {// 如果目标地址在源地址之前,可以从前往后复制while (count--) {*d++ = *s++;}} else {// 如果目标地址在源地址之后,从后往前复制d += count;s += count;while (count--) {*(--d) = *(--s);}}return dest;
}
memmove、memcpy源代码
/* Public domain. */
#include <stddef.h>void *
memcpy (void *dest, const void *src, size_t len)
{char *d = dest;const char *s = src;while (len--)*d++ = *s++;return dest;
}//* Public domain. */
#include <stddef.h>void *
memmove (void *dest, const void *src, size_t len)
{char *d = dest;const char *s = src;if (d < s)while (len--)*d++ = *s++;else{char *lasts = s + (len-1);char *lastd = d + (len-1);while (len--)*lastd-- = *lasts--;}return dest;
}
这篇关于C++|动手实现strcpy、memcpy、memmove的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!