strcpy之代码的健壮性与可维护性

  strcpy   函数的原型是: char * strcpy(char * strDest,const char * strSrc);

   功能:把从strSrc地址开始且含有NULL结束符的字符串复制到以strDest开始的地址空间,返回指向strDest的指针。

   说明:strSrc和strDest所指内存区域不可以重叠strDest必须有足够的空间来容纳strSrc的字符串。

    与strncpy   函数进行对比:

  strncpy  函数的原型是: char * strncpy( char *dest, char *src, size_t num );

  下面的例子可以看出strcpy和strncpy的区别:

     char* p="how are you ?";

     char name[10];

     strcpy(name,p); //目标串长度小于源串,错误

     strncpy(name,p,sizeof(name)); //源串长度大于指定拷贝的长度sizeof(name),注意在这种情况下不会自动在目标串后面加'\0'

      name[sizeof(name)-1]='\0'; //和上一步组合,弥补结果

 

实现strcpy函数:

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

     char *strDestCopy = strDest;         

       if ( (NULL == strDest) || (NULL==strSrc) )      

          throw "Invalid argument(s) ";          

     while ( (*strDestCopy++ = *strSrc++) != '\0' );       

     return strDest;     

}

说明:

1.为了代码的健壮性,需注重指针的有效性。    

     指针保存0值,表示它不指向任何对象。可以使用C++语言从C语言中继承下来的预处理器变量NULL,该变量在cstdlib头文件定义,其值为0.如果在代码中使用了这个预处理器变量,则编译器会自动被数值0替换。预处理器变量不是在std命名空间中定义的,因此其名字应为NULL,而非std::NULL。    

     不用((!strDest)||(!strSrc))或(!(strDest&&strSrc)),原因为:用作条件的表达式被隐式转换为bool型,这种功能虽然灵活,但更多的是导致出错概率增大和维护成本升高。所以C++专门增加了bool、true、false三个关键字以提供更安全的条件表达式。  

     检查指针的有效性时不用((strDest==0)||(strSrc==0)),如果直接使用字面常量(如本例中的0)就会减少程序的可维护性。使用常量(比如NULL)的好处:可维护性强,如果程序中多次出现,某次书写笔误,编译器就会检测出来。

2.throw部分,抛出异常代替返回值,使错误不会被忽略、增强程序的可维护性。如果触发throw,就会出现debug error的对话。

 

posted @ 2014-03-27 11:40  Xylophone  Views(427)  Comments(0Edit  收藏  举报