分类: LINUX
2011-03-29 09:46:33
bzero ,memset ,setmem,bcopy和memcpy、bzero和memset、bcmp和memcmp的差别
=================================================
bzero
原型:
extern void bzero(void *s, int n);
用法:
#include
功能:置字节字符串s的前n个字节为零。
说明:bzero无返回值。
举例: // bzero.c
view plainprint?
1. #include
2. #include
3. main()
4. {
5. struct
6. {
7. int a;
8. char s[5];
9. float f;
10. } tt;
11. char s[20];
12. bzero(&tt,sizeof(tt)); // struct initialization to zero bzero(s,20);
13. clrscr();
14. printf(“Initail Success”);
15. getchar();
16. return 0;
17. }
#include #include main() { struct { int a; char s[5]; float f; } tt;
char s[20]; bzero(&tt,sizeof(tt)); // struct initialization to zero
bzero(s,20); clrscr(); printf(“Initail Success”); getchar(); return 0; }
========================================
memset
原型:
extern void *memset(void *buffer, int c, int count);
用法:
#include
功能:把buffer所指内存区域的前count个字节设置成字符c。
说明:返回指向buffer的指针。
举例: // memset.c
view plainprint?
1. #include
2. #include
3. main()
4. {
5. char *s=”Golden Global View”;
6. clrscr();
7. memset(s,’G',6);
8. printf(“%s”,s);
9. getchar();
10. return 0;
11. }
#include #include main() { char *s=”Golden Global View”; clrscr(); memset(s,’G',6); printf(“%s”,s); getchar(); return 0; }
=======================================
setmem
原型:
extern void setmem(void *buf, unsigned int count, char ch);
用法:
#include
功能:把buf所指内存区域前count个字节设置成字符ch。
说明:返回指向buf的指针。
举例: // setmem.c
view plainprint?
1. #include
2. #include
3. main()
4. {
5. char *s=”Golden Global View”;
6. clrscr();
7. setmem(s,6,’G');
8. printf(“%s”,s);
9. getchar();
10. return 0;
11. }
#include #include main() { char *s=”Golden Global View”; clrscr(); setmem(s,6,’G'); printf(“%s”,s); getchar(); return 0; }
=======================================
附:
bcopy和memcpy、bzero和memset、bcmp和memcmp的差别在哪里?
bcopy、bzero和bcmp是传统BSD的函数,属于POSIX标准;mem*是C90(以及C99)标准的C函数。区别在于,如果你打算把程序弄 到一个符合C90/C99,但是不符合POSIX标准的平台时,后者比较有优势。
NetBSD的代码中有很多地方使用mem*(他们更偏爱mem*,以利于移植),即使内核也是如此,而FreeBSD的内核中则尽量避免使用(希 望尽可能避免在内核中出现较多的C函数)。如果你提交代码的话需要注意这些约定。
在memset和bzero初始化数据间,我很多时候选择bzero, memset的一个缺点是第二个参数和第三个参数需要记忆,需要记住哪个是值和哪个是大小(如果不想查手册的话), 不可以弄错。
bzero()和memset()
今天用到一个字符数组初始化函数,bzero(),因为比较生疏,于是在查本地的一个C/C++函数库的
时候并未见此函数,于是便觉得自己拥有的CHM版
的库函数软件包有点山寨了,可是当自己调试程序的时候却发现此函数始终通不过编译。被逼上网查它们的区别,得答案如下:
C has memset(), the Berkeley UNIX C library has bzero(). They are not
identical, and bzero() pre dates memset() but is not widely available (since
it’s not part of standard C).
在LINUX平台上是支持bzero的,但是其并不在ANSI C中定义,也就是不属于C的库函数.
bcopy、bzero和bcmp是传统BSD的函数,属于POSIX标准,是在linux下的函数;mem*是C90(以及C99)标准的C函数。区别在于,如果你打算把程序弄到一个符合C90/C99,但是不符合POSIX标准的平台时,后者比较有优势。
NetBSD的代码中有很多地方使用mem*(他们更偏爱mem*,以利于移植),即使内核也是如此,而FreeBSD的内核中则尽量避免使用(希望尽可能避免在内核中出现较多的C函数)。如果你提交代码的话需要注意这些约定
memset函数
——memset是对字节进行操 作
功 能: 将s所指向的 某一块内存中的每个字节的内容全部设置为ch指定的ASCII值。即将指定的内存,以字节为单位,置为ch所代表的内存形式。块的大小由第三个参数指定,这个函 数通常为新申请的内存做初始化工作。
用 法: void *memset(void *s, char ch, unsigned n);
原 理:以 字节为单位复制内存的二进制形式,到指定的内存区域。
(注:第二个数字也可以是int型,然后截取该int变 量的最低字节。作为复制的二进制模板。所以第二个字节最常见的是0全部置零 或 -1全部 置1。)
用 途:memset最常见的用途是对struct做初始化工作
memset(结 构体的地址,0,sizeof(结构体)) ;
bzero函数
原型:extern void bzero(void *s, int n);
用法:#include
功能:将以地址s开头的的前n个字节为零。
说明:bzero无返回值。bzero只能在linux下调用
同族——memcrp函数 vs strcry函数
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度。
原型:extern void *memcpy(void *dest, void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。
说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针
strcpy就只能拷贝字符串了,它遇到'\0'就结束拷贝
原型:extern char *strcpy(char *dest,char *src);
功能:把src所指由NULL结束的字符串复制到dest所指的数组中。
说明:src和dest所指内存区域不可以重叠且dest必 须有足够的空间来容纳src的字符串。
bcopy
原型:extern void bcopy(const void *src, void *dest, int n);
用法:#include
功能:将字符串src的前n个字节复制到dest中
说 明:bcopy不检查字符串中的空字节NULL,函数没有返回值。
目标和源的位置与memcpy和strcpy不同。
bcmp
原型:extern int bcmp(const void *s1, const void *s2, int n);
用法:#include
功能:比较字符 串s1和s2的前n个字节是否相等
说明:如果s1=s2或n=0则返回零,否则返回非零值。bcmp不检查NULL。
memcmp
原型:extern int memcmp(void *buf1, void *buf2, unsigned int count);
用法:#include
功能:比较内存区域buf1和buf2的前count个字节。
说明:当buf1
当buf1=buf2时,返回值=0
当buf1>buf2时,返回值>0