• 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. 请问这个git上开源的node项目怎样才能在windows用Npm跑起来

    这个项目https://github.com/wechaty/we...以前都是用人家弄好的手脚架搞得es6,搞了2天搞起了es6还报错,错误信息在下面,然后我想请教大神:1我到底应该怎么弄才能在wi ...

  2. 求从第一列走到第n列的最短路径

    11 14 23 12 18 21 13 10 28 15 29 17 无 无 25 如上表所示.求从第一列到第n列的最短路径,行数不定,列数不定.这种情况下用什么算法比较好 可能说的不大清楚,例如有 ...

  3. PostgreSQL Replication之第六章 监控您的设置(2)

    6.2 检查pg_stat_replication 检查归档以及 archive_command主要用于即时恢复( PITR,Point-In-Time- Recovery).如果您想监控一个基于流的 ...

  4. UVa 1599 Ideal Path【BFS】

    题意:给出n个点,m条边,每条边上涂有一个颜色,求从节点1到节点n的最短路径,如果最短路径有多条,要求经过的边上的颜色的字典序最小 紫书的思路:第一次从终点bfs,求出各个节点到终点的最短距离, 第二 ...

  5. Benelux Algorithm Programming Contest 2014 Final(第二场)

    B:Button Bashing You recently acquired a new microwave, and noticed that it provides a large number ...

  6. UI Framework-1: views Windowing

    views Windowing views provides support for creating dialog boxes and other kinds of windows through ...

  7. 第一章、zabbix安装

    前言: 注意:本文不涉及性能测试.性能优化中的监控,所有文字的出发点都是日常运维监控. 在开始之前,我们还是先统一下认识:要监控一个对象,需要掌握哪些东西呢? 监控对象的理解:要监控的对象你是否了解呢 ...

  8. YOLOv3学习笔记

    Darknet/Yolo官网:https://pjreddie.com/darknet/yolo/ GitHub程序:https://github.com/AlexeyAB/darknet 关于程序程 ...

  9. 【Henu ACM Round#17 F】Upgrading Array

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 如果我们对某一个位置i操作两次的话. 显然结果就和操作一次一样. 因为第一次操作过后1..i这些数字就变成是互质的了. gcd为1. ...

  10. UITextView自己定义键盘和系统键盘

    UITextView有inputView 和 inputAccessoryView 两个属性,都指定了对应的视图. inputAccessoryView 对象显示在 inputView 对象的上面.与 ...