码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-11-23 06:36:19      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:面试题   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语言:模拟实现内存放置函数memset()

标签:面试题   c语言   模拟实现内存放置函数memset()   字符串库函数的实现   

原文地址:http://10740184.blog.51cto.com/10730184/1715689

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!