再系统调用函数中,经常看到这样的情况:
传递结构体和字符串参数时,同时传递长度。
我们可以在程序中获得传入结构体和字符串的长度,为什么还要再传入一个长度?
原因在于:当传入的参数时字符串时我们可以轻易的获得长度,但是这个长度是用SIZEOF 还是STRLEN,其值是否有效?
传入的参数后,不论SIZEOF还是STRLEN其长度变为传输参数的实际长度,而不再是定义变量时内存分配的长度
看下面的例子:
#include<stdio.h>struct A...{//参数中含有二进制数据 int a; char sBuf[5];}a;struct B...{//参数中无二进制数据 char sBuf[5]; char str[5];}b;void test(char *sBuf,int n)...{ printf("%s ",sBuf); printf("n=%d ",n); printf("sizeof=%d,strlen=%d ",sizeof(sBuf),strlen(sBuf)); printf(" ");}void testS(struct A *s,int n,struct B *r,int m)...{ printf("struct A s "); printf("sizeof=%d,n=%d ",sizeof(s),n);//传入后的有效数据长度,定义时分配的内存长度 printf("sizeof(int)+sizeof(s.sBuf)=%d ",sizeof(s->a)+sizeof(s->sBuf)); printf("sizeof(int)+strlen(s.sBuf)=%d ",sizeof(s->a)+strlen(s->sBuf)); printf(" struct B r "); printf("sizeof=%d,m=%d ",sizeof(r),m); printf("sizeof(r.str)+sizeof(r.sBuf)=%d ",sizeof(r->str)+sizeof(r->sBuf)); printf("strlen(r.str)+strlen(r.sBuf)=%d ",strlen(r->str)+strlen(r->sBuf));}int main()...{ int n,m; a.a=5; strcpy(a.sBuf,"abc"); n = sizeof(a); strcpy(b.sBuf,"abc"); strcpy(b.str,"abc"); m = sizeof(b); testS(&a,n,&b,m); char sBuf[5]; strcpy(sBuf,"abcd"); n = strlen(sBuf); test(sBuf,n); /**//* sBuf[0] = 56; sBuf[1] = 56; sBuf[2] = 56; sBuf[3] = 56; */ sBuf[0] = 'a'; sBuf[1] = 'b'; sBuf[2] = 'c'; sBuf[3] = 'd'; n = strlen(sBuf); test(sBuf,n); n = sizeof(sBuf); test(sBuf,n); return 1;}执行结果:
struct A s
sizeof=4,n=12
sizeof(int)+sizeof(s.sBuf)=9
sizeof(int)+strlen(s.sBuf)=7
struct B r
sizeof=4,m=10
sizeof(r.str)+sizeof(r.sBuf)=10
strlen(r.str)+strlen(r.sBuf)=6
abcd
n=4
sizeof=4,strlen=4
abcd
n=4
sizeof=4,strlen=4
abcd
n=5
sizeof=4,strlen=4