关闭

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

53人阅读 评论(0) 收藏 举报
分类:

    模拟实现内存放置函数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这个十进制的值。


    代码如下:


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


int main()
{
    char arr[] = "almost every programmer should know memset!";
    char* ret = memset(arr, '-', 6);
    printf("%s", ret);
    system("pause");
    return 0;
}


本文出自 “Han Jing's Blog” 博客,请务必保留此出处http://10740184.blog.51cto.com/10730184/1715689

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:49027次
    • 积分:601
    • 等级:
    • 排名:千里之外
    • 原创:174篇
    • 转载:9篇
    • 译文:0篇
    • 评论:2条
    关于博主
    github:https://github.com/hanxiaojing Email: hanjing_1995@163.com 原51.cto: http://10740184.blog.51cto.com 欢迎来访~
    文章分类
    最新评论