原型:
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都不一定是数组,任意的可读写的空间均可。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/182264.html原文链接:https://javaforall.cn