• 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)的更多相关文章

  1. [整理]内存重叠之memcpy、memmove

    函数原型: void *memcpy( void *dest, const void *src, size_t count ); void *memmove( void* dest, const vo ...

  2. memcpy、memmove、memset及strcpy函数实现和理解

    memcpy.memmove.memset及strcpy函数实现和理解 关于memcpy memcpy是C和C++ 中的内存拷贝函数,在C中所需的头文件是#include<string.h> ...

  3. C语言-内存函数的实现(一)之memcpy

    C语言中的内存函数有如下这些 memcpy memmove memcmp memset 下面看看memcpy函数 memcpy 我们想想,之前有那个字符串拷贝的函数,即strcpy函数.都有拷贝的函数 ...

  4. memcpy、memmove、memset、memchr、memcmp、strstr详解

    第一部分 综述 memcpy.memmove.memset.memchr.memcmp都是C语言中的库函数,在头文件string.h中.memcpy和memmove的作用是拷贝一定长度的内存的内容,m ...

  5. C语言-内存函数的实现(二)之memmove

    C语言中的内存函数有如下这些 memcpy memmove memcmp memset 下面看看memmove函数 memmove 为什么会需要memmove函数? int main() { int ...

  6. strcpy()、memcpy()、memmove()、memset()的内部实现

    一直想知道 strcpy().memcpy().memmove().memset()的内部实现 strcpy(), 字符串拷贝. char *strcpy(char *strDest, const c ...

  7. c++中内存拷贝函数(C++ memcpy)详解

    原型:void*memcpy(void*dest, const void*src,unsigned int count); 功能:由src所指内存区域复制count个字节到dest所指内存区域. 说明 ...

  8. C语言标准库函数memcpy和memmove的区别以及内存重叠问题处理

    ①memcpy()和memmove()都是C语言中的标准库函数,定义在头文件string.h中,作用是拷贝一定长度的内存的内容,原型分别如下: void *memcpy(void *dst, cons ...

  9. 关于memcpy和memmove的一点说明

    今天看到书上降到memcpy和memmove的区别才突然发现原来两者之间有如此区别,以前只知道这两个函数是 实现同样的功能,没有接触到其不同. memcpy和memmove在MSDN的定义如下: 从两 ...

随机推荐

  1. SharePoint 2010 开发人员学习指南

    kaneboy 翻译,一切内容版权归 Microsoft.1. SharePoint 开发起步教程 这是一个为准备进入到 SharePoint 开发领域的 .NET 开发人员所准备的免费在线学习课程. ...

  2. HDU 4786Fibonacci Tree(最小生成树)

    Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...

  3. python3.x 学习笔记1(基础知识)

    1.python模块: 标准库和第三方库,第三方库需要下载安装 2.模块sys: 命令 功能 sys.stdin 标准输入流sys.stdout  标准输出流sys.stderr           ...

  4. PostgreSQL Replication之第五章 设置同步复制(1)

    到目前为止,我们已经处理了基于文件的复制(或日志传送)和简单的基于流复制的设置.在两种情况中,在master上事务被提交之后,数据被提交,由slave接收.在master提交和slave实际上完全地接 ...

  5. 《剑指offer》二叉树的镜像

    一.题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 二.输入描述 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 三.输出描述 镜像二叉树 8 / \ 10 ...

  6. RSA不对称加密

    package sinRsa; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io ...

  7. [BJOI2014]大融合 LCT维护子树信息

    Code: #include <cstdio> #include <algorithm> #include <cstring> #include <strin ...

  8. 分享一个简单好用的ipv6正则表达式

    网上找了好几个,都不太好使.比较严谨的又运行缓慢,而且文本中多处含ipv6的时候,又提取不出全部的ipv6. 故分享一个不太严谨效率又高的ipv6正则表达式: ([a-f0-9]{1,4}(:[a-f ...

  9. Xshell查看日志的基础使用

    2018\11\26 下载安装不多说,官网免费版即可,附上链接:https://www.netsarang.com/products/xsh_overview.html 打开后新建连接,输入主机ip即 ...

  10. HDU 4960 Another OCD Patient 简单DP

    思路: 因为是对称的,所以如果两段是对称的,那么一段的前缀和一定等于另一段的后缀和.根据这个性质,我们可以预处理出这个数列的对称点对.然后最后一个对称段是从哪里开始的,做n^2的DP就可以了. 代码: ...