日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

【C/C++ string】之strcpy函数

發布時間:2025/3/21 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【C/C++ string】之strcpy函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目:
? ? 已知strcpy函數的原型是:
? ?? ???char * strcpy(char * strDest,const char * strSrc);
? ? 1.不調用庫函數,實現strcpy函數。
? ? 2.解釋為什么要返回char *。

? ? 解說:
? ? 1.strcpy的實現代碼
  • ? ?? ???char * strcpy(char * strDest,const char * strSrc)
  • ? ?? ???{
  • ? ?? ?? ?? ?? ? if ((strDest==NULL)||(strSrc==NULL)) //[1]
  • ? ?? ?? ?? ?? ?? ?? ?? ?throw "Invalid argument(s)"; //[2]
  • ? ?? ?? ?? ?? ? char * strDestCopy=strDest;??//[3]
  • ? ?? ?? ?? ?? ? while ((*strDest++=*strSrc++)!='\0'); //[4]
  • ? ?? ?? ?? ?? ? return strDestCopy;
  • ? ?? ???}
  • 復制代碼


    ? ? 錯誤的做法:
    ? ? [1]
    ? ? (A)不檢查指針的有效性,說明答題者不注重代碼的健壯性。
    ? ? (B)檢查指針的有效性時使用((!strDest)||(!strSrc))或(!(strDest&&strSrc)),說明答題者對C語言中類型的隱式轉換沒有深刻認識。在本例中char *轉換為bool即是類型隱式轉換,這種功能雖然靈活,但更多的是導致出錯概率增大和維護成本升高。所以C++專門增加了bool、true、false三個關鍵字以提供更安全的條件表達式。
    ? ? (C)檢查指針的有效性時使用((strDest==0)||(strSrc==0)),說明答題者不知道使用常量的好處。直接使用字面常量(如本例中的0)會減少程序的可維護性。0雖然簡單,但程序中可能出現很多處對指針的檢查,萬一出現筆誤,編譯器不能發現,生成的程序內含邏輯錯誤,很難排除。而使用NULL代替0,如果出現拼寫錯誤,編譯器就會檢查出來。
    ? ? [2]
    ? ? (A)return new string("Invalid argument(s)";,說明答題者根本不知道返回值的用途,并且他對內存泄漏也沒有警惕心。從函數中返回函數體內分配的內存是十分危險的做法,他把釋放內存的義務拋給不知情的調用者,絕大多數情況下,調用者不會釋放內存,這導致內存泄漏。
    ? ? (B)return 0;,說明答題者沒有掌握異常機制。調用者有可能忘記檢查返回值,調用者還可能無法檢查返回值(見后面的鏈式表達式)。妄想讓返回值肩負返回正確值和異常值的雙重功能,其結果往往是兩種功能都失效。應該以拋出異常來代替返回值,這樣可以減輕調用者的負擔、使錯誤不會被忽略、增強程序的可維護性。
    ? ? [3]
    ? ? (A)忘記保存原始的strDest值,說明答題者邏輯思維不嚴密。
    ? ? [4]
    ? ? (A)循環寫成while (*strDest++=*strSrc++);,同[1](B)。
    ? ? (B)循環寫成while (*strSrc!='\0') *strDest++=*strSrc++;,說明答題者對邊界條件的檢查不力。循環體結束后,strDest字符串的末尾沒有正確地加上'\0'。

    ? ? 2.返回strDest的原始值使函數能夠支持鏈式表達式,增加了函數的“附加值”。同樣功能的函數,如果能合理地提高的可用性,自然就更加理想。
    ? ? 鏈式表達式的形式如:
    ? ?? ???int iLength=strlen(strcpy(strA,strB));
    ? ? 又如:
    ? ?? ???char * strA=strcpy(new char[10],strB);
    ? ? 返回strSrc的原始值是錯誤的。其一,源字符串肯定是已知的,返回它沒有意義。其二,不能支持形如第二例的表達式。其三,為了保護源字符串,形參用const限定strSrc所指的內容,把const char *作為char *返回,類型不符,編譯報錯。

    上面內容是轉自:http://bbs.chinaunix.net/viewthread.php?tid=25356
    下面是自己的一些思考:
    我想C/C++提供的字符串拷貝函數實現方式應該是下面的方式之一:
    method 1:????

    char?*?strcpy(char?*?strDest,const?char?*?strSrc)
    ????
    {
    ????????????????? char * strDestCopy=strDest;
    ???????
    ????????while?((*strDest++=*strSrc++)!='\0');?
    ?????????????//strDest
    =strDestCopy;//指針重置 不好意思,這里的重置是多余的,原因是雖然strDes的位置移動了,但是這只是在當前函數內發生變化,
    ??????????????? //而在調用函數的地方,指針的位置還是不變。

    ????????????return?strDestCopy;
    ????}
    ?method 2:
    ?char?*?strcpy(char?*?strDest,const?char?*?strSrc)
    ?
    {
    ??????
    int?i=0;
    ??????
    ?while?((strDest[i++]=*strSrc++)!='\0');?
    ??????
    return?strDest;
    ?}
    ?
    method 3:
    ?char?*?strcpy(char?*?strDest,const?char?*?strSrc)
    ?
    {
    ??????
    int?i=0;
    ?????while?((strDest[i++]=strSrc[i])!='\0');?
    ??????
    return?strDest;
    ?}
    這些方式都可實現類似<string.h>中的strcpy(char *, const char *)的功能。通過下標訪問方式不容易出錯,當然指針操作效率會更高。

    轉載于:https://www.cnblogs.com/wintergrass/archive/2011/04/28/2031479.html

    總結

    以上是生活随笔為你收集整理的【C/C++ string】之strcpy函数的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。