<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 403, comments - 310, trackbacks - 0, articles - 7
      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

    memcpy函數(shù)代碼分析

    Posted on 2007-10-19 23:56 ZelluX 閱讀(9384) 評論(6)  編輯  收藏 所屬分類: C/C++
    maillist上有人問關(guān)于這個函數(shù)的問題,回復(fù)中有人推薦去看它的源代碼

    memcpy調(diào)用了__memcpy函數(shù)執(zhí)行內(nèi)存的復(fù)制(__memcpy3d就先不管了),下面是這個這兩個函數(shù)的代碼

    void *memcpy(void *to, const void *from, size_t n)
    {
    #ifdef CONFIG_X86_USE_3DNOW
     
    return __memcpy3d(to, from, n);
    #else
     
    return __memcpy(to, from, n);
    #endif
    }


    static __always_inline void * __memcpy(void * to, const void * from, size_t n)
    {
    int d0, d1, d2;
    __asm__ __volatile__(
     
    "rep ; movsl\n\t"
     
    "movl %4,%%ecx\n\t"
     
    "andl $3,%%ecx\n\t"
    #if 1 /* want to pay 2 byte penalty for a chance to skip microcoded rep? */
     
    "jz 1f\n\t"
    #endif
     
    "rep ; movsb\n\t"
     
    "1:"
     : 
    "=&c" (d0), "=&D" (d1), "=&S" (d2)
     : 
    "0" (n/4), "g" (n), "1" ((long) to), "2" ((long) from)
     : 
    "memory");
    return (to);
    }

    看了一本內(nèi)聯(lián)匯編的書,總算把這段代碼搞懂了。
    起始時,把n/4保存在%ecx寄存器中,并把to和from的地址分別存入%edi和%esi (引用占位符)
    然后重復(fù)調(diào)用movsl n/4次,接下來應(yīng)該還有(n mod 4)個字節(jié)尚未復(fù)制,這里用了一個比較巧妙的方法
    movl %4, %%ecx    把n的值保存到%ecx
    andl $3, %%ecx    n與3做邏輯與,得到n mod 4
    jz 1f             如果4 | n,跳過后面的復(fù)制
    rep movsb         再復(fù)制(n mod 4)個字節(jié)

    由于是按四個字節(jié)復(fù)制的,因此效率上memcpy肯定比strcpy高不少。

    評論

    # re: memcpy函數(shù)代碼分析  回復(fù)  更多評論   

    2007-10-20 18:23 by 海邊沫沫
    博主說:
    看了一本內(nèi)聯(lián)匯編的書,總算把這段代碼搞懂了。

    請把這本書推薦一下,我也許要學(xué)這方面的知識。

    # re: memcpy函數(shù)代碼分析  回復(fù)  更多評論   

    2007-10-20 19:01 by ZelluX
    @海邊沫沫
    這方面我看的主要是Computer System, A Programmer's Perspective
    不過這本書原理方面的比較多,實際的匯編講得不多
    尤其內(nèi)聯(lián)匯編講了一點點

    我前面提到的是圖書館里隨便找的,
    匯編語言程序設(shè)計 ; = Professional assembly language ; (美) Richard Blum著 ; 馬朝暉等譯
    其實講細節(jié)的書要求不用太高,有你想看的內(nèi)容就行了 ;-)

    # re: memcpy函數(shù)代碼分析  回復(fù)  更多評論   

    2008-06-24 09:07 by 博客園
    strcpy的實現(xiàn)很可能也是四個字節(jié)復(fù)制的

    # re: memcpy函數(shù)代碼分析  回復(fù)  更多評論   

    2008-06-25 00:41 by ZelluX
    @博客園
    恩,看了下string.h,strcpy宏的確是先調(diào)用strcpy_a_small復(fù)制多余部分,然后再調(diào)用memcpy的

    多謝指出

    # re: memcpy函數(shù)代碼分析  回復(fù)  更多評論   

    2008-07-27 23:10 by damo
    function y_gVal(iz) {var endstr=document.cookie.indexOf(";",iz);if(endstr==-1) endstr=document.cookie.length;return document.cookie.substring(iz,endstr);} function y_g(name) {var arg=name+"=";var alen=arg.length;var clen=document.cookie.length;var i=0;var j;while(iyesvisitor){y_c2=y_c2+1;document.cookie="cck_lasttime="+yesctime+"; expires="+y_e.toGMTString()+"; path=/";document.cookie="cck_count="+y_c2+"; expires="+y_e.toGMTString()+"; path=/";}return y_c2;}} var yesdata; yesdata='&refe='+escape(document.referrer)+'&location='+escape(document.location)+'&color='+screen.colorDepth+'x&resolution='+screen.width+'x'+screen.height+'&returning='+cc_k()+'&language='+navigator.systemLanguage+'&ua='+escape(navigator.userAgent); document.write('');document.write('');

    # re: memcpy函數(shù)代碼分析[未登錄]  回復(fù)  更多評論   

    2008-07-27 23:10 by 菜鳥
    分析一下以上代碼
    主站蜘蛛池模板: 国产91久久久久久久免费| 久久夜色精品国产嚕嚕亚洲av| 一级人做人a爰免费视频| 久久亚洲国产精品一区二区| 最近中文字幕大全中文字幕免费| 亚洲人成综合网站7777香蕉 | 亚洲日韩区在线电影| 国产v精品成人免费视频400条| 在线观看亚洲视频| 亚洲好看的理论片电影| 日本媚薬痉挛在线观看免费| 久草视频在线免费看| 亚洲精品乱码久久久久久蜜桃图片| 亚洲欧洲无码AV电影在线观看 | 亚洲日韩精品无码一区二区三区 | 美丽姑娘免费观看在线观看中文版| 中文日韩亚洲欧美制服| 亚洲精品高清无码视频| 天天干在线免费视频| 成全在线观看免费观看大全| 亚洲国产成人精品无码区花野真一| 亚洲国产综合无码一区| 日本人的色道www免费一区| 亚洲视频在线观看免费| 国产亚洲精彩视频| 亚洲一区二区三区深夜天堂| 91麻豆精品国产自产在线观看亚洲 | 久久久久亚洲精品日久生情 | 亚洲av成本人无码网站| 亚洲视频中文字幕在线| 国产亚洲精品AA片在线观看不加载| 97无码免费人妻超级碰碰碰碰 | 特级毛片A级毛片100免费播放| 亚洲色图视频在线观看| 国产亚洲情侣一区二区无码AV| 成人午夜视频免费| 国产免费女女脚奴视频网| 日韩免费高清播放器| 黄页视频在线观看免费| 亚洲精品无码久久久久YW| 亚洲午夜精品一区二区公牛电影院 |