【面试题】C语言:模拟实现内存放置函数memset()

    模拟实现内存放置函数memset()

    

    我们查看库函数可知,函数原型为:

    void * __cdecl memset ( void *dst, int val, size_t count),我们常用于将数组arr向后几个字节初始化置为0,而并不怎么用于置为其他元素,如1。这是因为:


     val = 1,是int型,将它赋给char型dest,则只把低八位赋给dest,下次再接着循环,每次都只把一个字节长度的1赋给dest。如此重复count次,结束。在输出过程中,而arr是int型,一个int型是4个char型,即每次输出的结果都是:1000  0000   1000  0000  1000 0000  1000  0000这个十进制的值。


    代码如下:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>


void *my_memset(void *p1, int val, size_t count)
{
    char *dest = (char *)p1;
    char *ret = dest;
    while(count--) 
    {
        *dest = val;
        dest = dest + 1;
    }
    return ret;
}

int main()
{
    int arr[] = { 1, 3, 5, 6, 8, 9 };
    int i = 0;
    int *ret = my_memset(arr, 1, 16);
    for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
    {
        printf("%d ", *(ret + i));
    }
    system("pause");
    return 0;
}


你可能感兴趣的:(面试题,C语言,字符串库函数的实现)