题目:

已知strcpy函数的原型是:


 


char * strcpy(char * strDest,const char * strSrc);


 


1.不调用库函数,实现strcpy函数。


 


2.解释为什么要返回char *。

解说:

1.strcpy的实现代码


 


char * strcpy(char * strDest,const char * strSrc)


 


{


 


char * strDestCopy=strDest; //[3]


 


if ((strDest==NULL)||(strSrc==NULL)) //[1]


 


throw "Invalid argument(s)"; //[2]


 


while ((*strDest++=*strSrc++)!='\0'); //[4]


 


return strDest;


 


}


 


错误的做法:


 


[1]


 


(A)不检查指针的有效性,说明答题者不注重代码的健壮性。


 


  (B)检查指针的有效性时使用((!strDest)||(!strSrc))或(!(strDest&&strSrc)),说明答题者对C语言中类型的隐式转换没有深刻认识。在本例中char *转换为bool即是类型隐式转换,这种功能虽然灵活,但更多的是导致出错概率增大和维护成本升高。所以C++专门增加了bool、true、false三个关键字以提供更安全的条件表达式。


 


(C)检查指针的有效性时使用((strDest==0)||(strSrc==0)),说明答题者不知道使用常量的好处。直接使用字面常量(如本例中的0)会减少程序的可维护性。0虽然简单,但程序中可能出现很多处对指针的检查,万一出现笔误,​​编译器​​不能发现,生成的程序内含逻辑错误,很难排除。而使用NULL代替0,如果出现拼写错误,编译器就会检查出来。

 

指针有效性的有效性检测的必要性!!

 

•指针的危险

 

   long *fellow;

  *fellow=22322;

  fellow确实是一个指针,但它指向哪里呢?上述代码没有将地址赋给fellow,那么22322将被放哪,我们并不知道。由于fellow没有被初始化,它可能 有任何值。不管值是什么,程序都将它解释为存储

22322的地址。如果fellow的值碰巧为0060,计算机将把数据放在地址0060上,即使这个地址恰巧是程序代码所在的地址,这种错误可能会导致一些最隐匿、最难以跟踪的bug。

解决办法:一定要在对指针应用*运算符之前,将指针初始化为一个确定的、适当的地址。这是使用指针的金科玉律。

所以指针有效性的检测的意义在于,不会将指针初始化在一个 程序代码所在的地方,避免了指针给程序所在的地方赋值造成程序的buge。