标签:面试题 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