41.内存函数实现(memcpy,memset,memmove,memicmp,memchr.memccpy)
- memcpy
#include <stdio.h>
#include <stdlib.h>
#include <memory.h> void * mymemcpy(void* _Dst, void const* _Src, size_t _Size)
{
if (_Dst == NULL || _Src == NULL)
{
return NULL;
} //转化成char类型,一次前进一个字节
char *dst = _Dst;
char *src = _Src; for (int i = ; i < _Size; i++)
{
dst[i] = src[i];
} return _Dst;
} void main()
{
int a[] = { ,,,,,,,,, };
int *p = malloc(sizeof(int) * );
int *tmp = mymemcpy(p, a, ); for (int i = ; i < ; i++)
{
printf("%d\n" ,p[i]);
} char str[] = "hello world";
char mystr[];
mymemcpy(mystr, str, strlen(str) + ); printf("%s\n", mystr); system("pause");
} - memset
void *mymemset(void *_Dst, int _Val, size_t _Size)
{
if (_Dst == NULL || _Val == NULL)
{
return;
} for (int i = ; i < _Size; i++)
{
((char *)_Dst)[i] = _Val;
} return _Dst;
} - memmove
void * mymemmove(void *_Dst, const void *_Src, size_t _Size)
{
if (_Dst == NULL || _Src == NULL)
{
return NULL;
} void *psrc = malloc(_Size);//分配内存
memcpy(psrc, _Src, _Size);
memcpy(_Dst, psrc, _Size);
free(psrc);
return _Dst;
} - memicmp(比较指定字符串前n个字符串)
int mymemicmp(const void *_Buf1, const void *_Buf2, size_t _Size)
{
//保存变量
char *buf1 = _Buf1;
char *buf2 = _Buf2; //结束标识
char *end = buf1 + _Size; while ((*buf1 == *buf2) && buf1 != end)
{
buf1++;
buf2++;
} if (buf1 == end)
{
return ;
}
else
{
return *buf1 - *buf2 > ? : -;
}
} - memchr(寻找一个字符串中是否有指定字符)
void *mymemchr(void *start, char ch, int maxlength)
{
char *p = NULL;
for (int i = ; i < maxlength; i++)
{
if (((char *)start)[i] == ch)
{
p = (char *)start + i;
break;
}
}
return p;
} - memccpy(复制n个字符,遇到指定值退出)
void * mymemccpy(void * _Dst, const void *_Src, int _Val,size_t _MaxCount)
{
char *dst = _Dst;
char *src = _Src; for (int i = ; i < _MaxCount; i++)
{
dst[i] = src[i];
if (dst[i] == _Val)
{
break;
}
}
}
41.内存函数实现(memcpy,memset,memmove,memicmp,memchr.memccpy)的更多相关文章
- [整理]内存重叠之memcpy、memmove
函数原型: void *memcpy( void *dest, const void *src, size_t count ); void *memmove( void* dest, const vo ...
- memcpy、memmove、memset及strcpy函数实现和理解
memcpy.memmove.memset及strcpy函数实现和理解 关于memcpy memcpy是C和C++ 中的内存拷贝函数,在C中所需的头文件是#include<string.h> ...
- C语言-内存函数的实现(一)之memcpy
C语言中的内存函数有如下这些 memcpy memmove memcmp memset 下面看看memcpy函数 memcpy 我们想想,之前有那个字符串拷贝的函数,即strcpy函数.都有拷贝的函数 ...
- memcpy、memmove、memset、memchr、memcmp、strstr详解
第一部分 综述 memcpy.memmove.memset.memchr.memcmp都是C语言中的库函数,在头文件string.h中.memcpy和memmove的作用是拷贝一定长度的内存的内容,m ...
- C语言-内存函数的实现(二)之memmove
C语言中的内存函数有如下这些 memcpy memmove memcmp memset 下面看看memmove函数 memmove 为什么会需要memmove函数? int main() { int ...
- strcpy()、memcpy()、memmove()、memset()的内部实现
一直想知道 strcpy().memcpy().memmove().memset()的内部实现 strcpy(), 字符串拷贝. char *strcpy(char *strDest, const c ...
- c++中内存拷贝函数(C++ memcpy)详解
原型:void*memcpy(void*dest, const void*src,unsigned int count); 功能:由src所指内存区域复制count个字节到dest所指内存区域. 说明 ...
- C语言标准库函数memcpy和memmove的区别以及内存重叠问题处理
①memcpy()和memmove()都是C语言中的标准库函数,定义在头文件string.h中,作用是拷贝一定长度的内存的内容,原型分别如下: void *memcpy(void *dst, cons ...
- 关于memcpy和memmove的一点说明
今天看到书上降到memcpy和memmove的区别才突然发现原来两者之间有如此区别,以前只知道这两个函数是 实现同样的功能,没有接触到其不同. memcpy和memmove在MSDN的定义如下: 从两 ...
随机推荐
- SharePoint 2010 开发人员学习指南
kaneboy 翻译,一切内容版权归 Microsoft.1. SharePoint 开发起步教程 这是一个为准备进入到 SharePoint 开发领域的 .NET 开发人员所准备的免费在线学习课程. ...
- HDU 4786Fibonacci Tree(最小生成树)
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...
- python3.x 学习笔记1(基础知识)
1.python模块: 标准库和第三方库,第三方库需要下载安装 2.模块sys: 命令 功能 sys.stdin 标准输入流sys.stdout 标准输出流sys.stderr ...
- PostgreSQL Replication之第五章 设置同步复制(1)
到目前为止,我们已经处理了基于文件的复制(或日志传送)和简单的基于流复制的设置.在两种情况中,在master上事务被提交之后,数据被提交,由slave接收.在master提交和slave实际上完全地接 ...
- 《剑指offer》二叉树的镜像
一.题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 二.输入描述 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 三.输出描述 镜像二叉树 8 / \ 10 ...
- RSA不对称加密
package sinRsa; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io ...
- [BJOI2014]大融合 LCT维护子树信息
Code: #include <cstdio> #include <algorithm> #include <cstring> #include <strin ...
- 分享一个简单好用的ipv6正则表达式
网上找了好几个,都不太好使.比较严谨的又运行缓慢,而且文本中多处含ipv6的时候,又提取不出全部的ipv6. 故分享一个不太严谨效率又高的ipv6正则表达式: ([a-f0-9]{1,4}(:[a-f ...
- Xshell查看日志的基础使用
2018\11\26 下载安装不多说,官网免费版即可,附上链接:https://www.netsarang.com/products/xsh_overview.html 打开后新建连接,输入主机ip即 ...
- HDU 4960 Another OCD Patient 简单DP
思路: 因为是对称的,所以如果两段是对称的,那么一段的前缀和一定等于另一段的后缀和.根据这个性质,我们可以预处理出这个数列的对称点对.然后最后一个对称段是从哪里开始的,做n^2的DP就可以了. 代码: ...