标签:面试题 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() 字符串库函数的实现
原文地址:http://10740184.blog.51cto.com/10730184/1715689