• <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>
            隨筆 - 20, 文章 - 0, 評論 - 45, 引用 - 0
            數據加載中……

            memmove、memcpy、strcpy

            strcpy只能處理字符串;如果拷貝帶有特殊字符的串,就只能用memcpy或memmove。
            memcpy和memmove功能基本上差不多,但是當源串和目標串有Overlap時,memmove可以正確處理,memcpy則不行。

            memcpy()和memmove()都是C語言中的庫函數,在頭文件string.h中,其原型分別如下:


            void *memcpy(void *dst, const void *src, size_t count);
            void *memmove(void *dst, const void *src, size_t count);

            它們都是從src所指向的內存中復制count個字節到dst所指內存中,并返回dst的值。當源內存區域和目標內存區域無交叉時,兩者的結果是一樣的,但如果有交叉呢?先看下圖:



            圖的上半部分為源內存區域在目標內存區域右邊,下半部分為源內存區域在目標區域左邊,源內存區域和目標內存區域都有交叉。

            memcpy()是從src的起始部分開始復制,所以雖然第一種情況下沒有問題,但如果遇到第二種情況,則會發生錯誤,如圖所示,后兩個字節在被復制前已經被覆蓋掉了。而memmove()則由于采用了不同的復制機制,所以可以正確處理第二種情況。


            下面是兩個函數的源碼實現:

             1 void * __cdecl memcpy (void * dst, const void * src, size_t count)
             2 {
             3         void * ret = dst;
             4
             6         while (count--) {
             7                 *(char *)dst = *(char *)src;
             8                 dst = (char *)dst + 1;
             9                 src = (char *)src + 1;
            10         }
            11 
            12         return(ret);
            13 }


             1
             void * __cdecl memmove (void * dst, const void * src, size_t count)
             2 {
             3         void * ret = dst;
             4 
             5         if (dst <= src || (char *)dst >= ((char *)src + count)) {
             6                 
             7                 while (count--) {
             8                         *(char *)dst = *(char *)src;
             9                         dst = (char *)dst + 1;
            10                         src = (char *)src + 1;
            11                 }
            12         }
            13         else {
            14                 
            15                 dst = (char *)dst + count - 1;
            16                 src = (char *)src + count - 1;
            17 
            18                 while (count--) {
            19                         *(char *)dst = *(char *)src;
            20                         dst = (char *)dst - 1;
            21                         src = (char *)src - 1;
            22                 }
            23         }
            24 
            25         return(ret);
            26 }

            posted on 2011-04-16 21:50 Kenny Jiang 閱讀(1718) 評論(0)  編輯 收藏 引用 所屬分類: C++

            日韩人妻无码精品久久免费一 | 国产精品久久久久影视不卡| 久久久久久曰本AV免费免费| 久久青青草原精品国产不卡| 亚洲精品午夜国产va久久| 久久亚洲AV成人无码| 久久久久久a亚洲欧洲aⅴ | 亚洲欧洲精品成人久久奇米网| 久久人人爽人人人人片av| 久久精品国产久精国产果冻传媒 | 69SEX久久精品国产麻豆| 亚洲午夜久久久精品影院 | 99久久精品免费看国产一区二区三区| 国产精品丝袜久久久久久不卡 | 亚洲伊人久久综合中文成人网| 狠狠综合久久综合88亚洲| 国产成人久久AV免费| 久久精品国产欧美日韩99热| 国产午夜精品理论片久久影视 | 日韩十八禁一区二区久久 | 国产精品久久波多野结衣| 97香蕉久久夜色精品国产 | 久久精品a亚洲国产v高清不卡| 久久综合狠狠综合久久97色| 成人妇女免费播放久久久| 久久综合亚洲色一区二区三区| 成人国内精品久久久久影院VR| 亚洲AV无一区二区三区久久| 久久精品国产99国产精品亚洲 | 久久性生大片免费观看性| 99久久无色码中文字幕| 狼狼综合久久久久综合网| 色综合久久夜色精品国产| 免费一级欧美大片久久网| 国产精品gz久久久| www亚洲欲色成人久久精品| 欧美一区二区精品久久| 亚洲国产成人久久综合碰碰动漫3d| 精品国产VA久久久久久久冰| 久久久噜噜噜久久中文福利| 亚洲精品白浆高清久久久久久|