//1.strcpy(拷贝) char* my_strcpy(char*dst, const char*src) { assert(dst); assert(src); char* cp = dst; while (*cp++ = *src++) { ; } return dst; } //2.strcat(连接) char* my_strcat(char*dst, const char*src) { assert(dst); assert(src); char* cp = dst; while (*cp != '\0') { cp++; } while (*cp++ = *src++) { ; } return dst; } //3.strcmp(比较) int my_strcmp(const char*dst, const char*src) { assert(dst); assert(src); int ret = 0; while (!(ret=*(unsigned char*)dst - *(unsigned char*)src) && *dst) { dst++; src++; } if (ret > 0) { ret = 1; } else if (ret < 0) { ret = -1; } return ret; } //4.strstr (寻找子串) char* my_strstr(const char*dst, const char*src) { char* cp = (char*)src; char*s1; char*s2; if (!*dst) { return ((char*)src); } while (*cp) { s1 = cp; s2 = (char*)dst; while (!(*s1-*s2)&&*s1&&s2) { s1++; s2++; } if (!*s2) { return (cp); } cp++; } return (NULL); } //5.memcpy(内存拷贝,不重叠) void* my_memcpy(void *dst, const void*src, size_t count) { assert(dst); assert(src); char*ret = (char*)dst; while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } return ret; } //6.memmove(内存移动,实现重叠拷贝) //内存移动有两种情况:如有一字符串:abcdefgh ,若dst<src,即dst在src前面,则没有重叠。 //若dst>src,即dst在src后面,此时若srt+count<dst,则没有重叠。 //若dst>src,即dst在src后面,此时若srt+count>dst,则有重叠,此时需从后向前,由src+count开始拷贝到dst+count。 void *my_memmove(void*dst, const void*src, size_t count) { assert(dst); assert(src); void *ret = dst; if ((dst < src) || ((char*)src + count) < (char*)dst) //内存不重叠,顺着按顺序拷贝 { while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } } else //内存有重叠,则倒着拷贝 { dst = (char*)dst + count - 1; src = (char*)src + count - 1; while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst - 1; src = (char*)src - 1; } } return ret; } //7.memset(内存设置) void* my_memset(void*dst, int val, size_t count) { void*start = dst; while (count--) { *(char*)dst = (char)val; dst = (char*)dst + 1; } return start; }
模拟实现部分库函数(strcpy,strcmp,strcat,strstr,memcpy,memmove,memset)
原创
©著作权归作者所有:来自51CTO博客作者睿蕤芮的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:new 与malloc的区别
下一篇:智能指针的原理和简单实现
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
【C语言加油站】qsort函数的模拟实现
【C语言加油站】qsort函数的模拟实现本文详细介绍了使用冒泡排序的逻辑模拟实现可以排序任意类型数组的qsort函数……
C语言 qsort排序函数 冒泡排序 回调函数 void*指针 -
模拟实现memset,memcpy,memmove函数
模拟实现memset,memcpy,memmove函数memset功能是将s所指向的某一
#include i++ 内存区域