• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            旅途

            如果想飛得高,就該把地平線忘掉

            strcpy

            試題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會導致數組越界;

               對試題2,如果面試者指出字符數組str1不能在數組內結束可以給3分;如果面試者指出strcpy(string, str1)調用使得從str1內存起復制到string內存起所復制的字節數具有不確定性可以給7分,在此基礎上指出庫函數strcpy工作方式的給10 分;

              對試題3,if(strlen(str1) <= 10)應改為if(strlen(str1) < 10),因為strlen的結果未統計’\0’所占用的1個字節。

              剖析:

              考查對基本功的掌握:

              (1)字符串以’\0’結尾;

              (2)對數組越界把握的敏感度;

              (3)庫函數strcpy的工作方式,如果編寫一個標準strcpy函數的總分值為10,下面給出幾個不同得分的答案:

              2分

            void strcpy( char *strDest, char *strSrc )
            {
              while( (*strDest++ = * strSrc++) != ‘\0’ );
            }

              4分

            void strcpy( char *strDest, const char *strSrc )
            //將源字符串加const,表明其為輸入參數,加2分
            {
              while( (*strDest++ = * strSrc++) != ‘\0’ );
            }

              7分

            void strcpy(char *strDest, const char *strSrc)
            {
             //對源地址和目的地址加非0斷言,加3分
             assert( (strDest != NULL) && (strSrc != NULL) );
             while( (*strDest++ = * strSrc++) != ‘\0’ );
            }

              10分

            //為了實現鏈式操作,將目的地址返回,加3分!

            char * strcpy( char *strDest, const char *strSrc )
            {
             assert( (strDest != NULL) && (strSrc != NULL) );
             char *address = strDest;
             while( (*strDest++ = * strSrc++) != ‘\0’ );
              return address;
            }

              從2分到10分的幾個答案我們可以清楚的看到,小小的strcpy竟然暗藏著這么多玄機,真不是蓋的!需要多么扎實的基本功才能寫一個完美的strcpy??!
            (4)對strlen的掌握,它沒有包括字符串末尾的'\0'。

             讀者看了不同分值的strcpy版本,應該也可以寫出一個10分的strlen函數了,完美的版本為: int strlen( const char *str ) //輸入參數const

            {
             assert( strt != NULL ); //斷言字符串地址非0
             int len;
             while( (*str++) != '\0' )
             {
              len++;
             }
             return len;
            }

            posted on 2007-10-29 00:56 旅途 閱讀(752) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            99麻豆久久久国产精品免费| 久久免费99精品国产自在现线| 亚洲午夜无码AV毛片久久| 欧美黑人激情性久久| 日韩人妻无码精品久久免费一 | 欧美精品久久久久久久自慰| 高清免费久久午夜精品| 久久激情亚洲精品无码?V| 综合久久给合久久狠狠狠97色 | 一本大道加勒比久久综合| 久久这里只有精品视频99| 久久午夜无码鲁丝片| 久久精品综合一区二区三区| 少妇久久久久久被弄高潮| 91久久精品国产成人久久| 丁香色欲久久久久久综合网| 国产精品久久久久久久午夜片 | 狠狠色婷婷久久一区二区| 久久免费小视频| 热re99久久精品国99热| 青青热久久国产久精品| 青青草国产精品久久久久| 久久久无码精品亚洲日韩蜜臀浪潮| 久久国产一片免费观看| 99久久精品免费看国产免费| 久久精品无码一区二区无码| 污污内射久久一区二区欧美日韩| 91精品国产91久久久久久青草| 久久精品无码专区免费青青| 久久精品国产亚洲AV忘忧草18| 亚洲乱亚洲乱淫久久| 国产91色综合久久免费分享| 一本一道久久a久久精品综合| 久久久久亚洲av成人无码电影| 好属妞这里只有精品久久| 72种姿势欧美久久久久大黄蕉| 亚洲午夜久久久影院| 奇米综合四色77777久久| 一本色道久久综合亚洲精品| 无码国内精品久久人妻| 久久精品麻豆日日躁夜夜躁|