关于strcpy

来源:互联网 发布:网络运营推广岗位职责 编辑:程序博客网 时间:2024/06/08 16:30

http://blog.sina.com.cn/s/blog_4fee13cd01000cix.html


strcpy得到了很多面试人员的偏爱,其很大的体现出了C语言基本功.

下面是strcpy原函数

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

{

   assert((strDest!=NULL) && (strSrc!=NULL));  

    char*address =strDest;                    

    while((*strDest++ = * strSrc++) !=‘\0’)      

      NULL ;

    returnaddress;                           

}

有几个问题值得思考并注意:

1.用指针作为形参,在程序开始前应判断指针变量的合法性,利用断言assert

2.只作为输入参数,为了防止被编程人员恶意修改,应加入常量声明const

3.函数返回类型为,char*,其目的是为了方便实现链表表达式.在调用函数的过程中已经实现了把strSrc的内容复制到strDest

4.应注意对原始位置的保留.

5.该函数调用完成时是遇到'\0'结束符

 

下面是几个找错题:

试题1:

void test1()
{
   char string[10];
   char* str1 = "0123456789";

    strcpy( string, str1 );
}

试题2:

void test2()
{
   char string[10],str1[10];
    int i;

    for(i=0; i<10; i++)
    {
       str1[i] = 'a';

    }

    strcpy( string, str1 );
}

试题3:

void test3(char* str1)
{
   char string[10];

   if( strlen( str1 ) <= 10)
    {
           strcpy( string, str1 );
    }
}

 

试题1字符串str1需要11个字节才能存放下(包括末尾的’\0’),而string只有10个字节的空间,strcpy会导致数组越界;从第5条可以看出,函数调用完成时已经将'\0'一同赋给了目的地址.

 

试题2,问题很严重,对string[10]数组的赋值本身没有错误,但很明显程序期望对string按字符串操作,这就需要额外的赋给一个'\0'结束符;另外如果没有'\0'结束标志,调用strcpy将不会结束,造成程序的不确定性,很危险.

 

试题3,一定要注意strlen(pstr),它和strcpy不同,遇到'\0'时结束,但并不计算\0'在内.所以应改为if(strlen( str1 ) <=10),另外要注意字符串首地址,数组,各种类型的指针作为形参,都退化为指针.即

void test3(char* str1)
{

sizeof(str1)只和编译器和CPU类型有关,32位CPU为4
}


原创粉丝点击