原型:
extern void bzero(void * s,int n)
函数说明:bzero()会将参数s 所指的内存区域前n 个字节,全部设为零值。
附加说明:添加头文件<strings.h>,bzero()不是ANSI C函数,建议使用ANSI C中的memset 取代,相当于调用memset(void* s, 0 , int n )。
void memset(void * s, int c, size_t len):把目标字节串制定数目的字节置为c的值
例子:
#include <stdio.h>
#include <strings.h>
int main( void )
{ struct{int a;char s[5];float f;}tt; char s[20];bzero( &tt, sizeof( tt ) );//等价于memset(&tt,0,sizeof(tt));bzero( s, 20 );//等价于memset(s,0,20); printf( "Initial success." );getchar();return 0;
}
另外还有个字节操纵函数:
void *memcopy( void *dest ,const void * src ,size_t n)
const是指指针指向的内容不能被修改
把src指向的内容复制到dest指向的内容,复制的长度是n,返回值函数返回一个指向dest的指针。
需要说明的是:
1.source和destin所指内存区域不能重叠,函数返回指向destin的指针。重叠了就不能处理
2.与strcpy相比,memcpy并不是遇到'\0'就结束,而是一定会拷贝完n个字节。
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度;
例如:
char a[100], b[50];
memcpy(b, a,sizeof(b)); //注意如用sizeof(a),会造成b的内存地址溢出。
strcpy就只能拷贝字符串了,它遇到'\0'就结束拷贝;例:
char a[100], b[50];
strcpy(a,b);
3.如果目标数组destin本身已有数据,执行memcpy()后,将覆盖原有数据(最多覆盖n)。如果要追加数据,则每次执行memcpy后,要将目标数组地址增加到你要追加数据的地址。
//注意,source和destin都不一定是数组,任意的可读写的空间均可。