Strcat函數原型如下:


 Strcat函數原型如下:

 注:實參strDest需要有足夠空間容納strSrc,否則報錯

  char *strcat(char *strDest, const char *strSrc) //將源字符串加const,表明其為輸入參數

 

  {

 

  char *address = strDest; //該語句若放在assert之后,編譯出錯

 

  assert((strDest != NULL) && (strSrc != NULL)); //對源地址和目的地址加非0斷言

 

  while(*strDest) //是while(*strDest!=’\0’)的簡化形式

 

  { //若使用while(*strDest++),則會出錯,因為循環結束后strDest還會執行一次++,那么strDest

 

  strDest++; //將指向'\0'的下一個位置。/所以要在循環體內++;因為要是*strDest最后指

 

  } //向該字符串的結束標志’\0’。

 

  while(*strDest++ = *strSrc++)

 

  {  

*p++等價於*(p++)。至於為什么會等價呢?根據c語言的優先級。*與++的優先級同處在第二級別上。他們的優先級是一樣的,又因為處在第二級別的優先級運算符是結合方向是從右到左,所以當出現*p++這樣的表達式的時候,根據優先級別相同,並且結合方向是從右到左,所以就等價於*(p++)了。那么也就是,先將p指針移動到下個p指針所指向元素的地址的下一個地址,然后再對那個地址取值。(*p)++是取p所指向地址的值,然后再將這個值+1
 

  NULL; //該循環條件內可以用++,

 

  } //此處可以加語句*strDest=’\0’;無必要

 

 

或者

while(*strSrc)

    {

        *strDest=*strSrc;

        strDest++;

        strSrc++;

    不能用    strDest=strSrc;

                這樣改變指針指向,斷開了形參與實參之間的聯系,實參的值不會受到影響

    }

 

  return address; //為了實現鏈式操作,將目的地址返回

 

  }

 

 

實例:

char *p1,*p2,str[20]="xyz";

    p1="abcd";

    p2="ABCD";

    

    strcpy(str+1, strcat(str+1, p2+1));//strcat實現兩個字符串從第一個參數的內存起始位置,連接(catenate鏈接),注意第一個參數要有空間容納第二個參數,否則會報錯。

    printf("%s",str);

 

結果:xbcdBCD


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM