近日,项目之中需要用到网络编程的知识,阅读《UNIX网络编程卷1:套接字联网API》之后。发现:在对socket地址结构执行 清0 操作时,全部都是bzero(),而不是耳熟能详的memset()。为什么呢?
总结如下:
1、bzero()好记忆:2个参数;
2、memset()易出错:3个参数,且第二、三个参数易记混淆,如若出现位置互换的情况,C编译器并不能察觉;
使用
1、bzero()
函数原型:extern void bzero(void *s, int n)
头文件:<string.h>
功能:置字节字符串s的前n个字节为零且包括‘\0’
说明:无返回值
2、memset()
函数原型:extern void *memset(void *buffer, int c, int count)
头文件:<string.h>
功能:把buffer所指内存区域的前count个字节设置成c的值。
举例
#include <string.h> void main(int argc, char *argv[]) { struct sockaddr_in servaddr; // 套接字地址结构 bzero( &servaddr, sizeof(servaddr) ); // memset( &servaddr, 0, sizeof(servaddr) ); /* bzero( &servaddr, 5 ); memset( &servaddr, 0, 5 ); // 假如 0 和 5 位置记错了,C编译器并不会报错(参数类型相同) */ }
区别
1、bzero()不是ANSI C函数,其起源于早期的Berkeley网络编程代码,但是几乎所有支持套接字API的厂商都提供该函数;
2、memset()为ANSI C函数,更常规、用途更广;