<menu id="w8yyk"><menu id="w8yyk"></menu></menu>
  • <dd id="w8yyk"><nav id="w8yyk"></nav></dd>
    <menu id="w8yyk"></menu>
    <menu id="w8yyk"><code id="w8yyk"></code></menu>
    <menu id="w8yyk"></menu>
    <xmp id="w8yyk">
    <xmp id="w8yyk"><nav id="w8yyk"></nav>
  • 網站首頁 > 物聯資訊 > 技術分享

    memmove 和 memcpy的區別

    2016-09-28 00:00:00 廣州睿豐德信息科技有限公司 閱讀
    睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接 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); 

    他們的作用是一樣的,唯一的區別是,當內存發生局部重疊的時候,memmove保證拷貝的結果是正確的,memcpy不保證拷貝的結果的正確。
    RFID設備管理軟件

    第一種情況下,拷貝重疊的區域不會出現問題,內容均可以正確的被拷貝。
    第二種情況下,問題出現在
    右邊的兩個字節,這兩個字節的原來的內容首先就被覆蓋了而且沒有保存。所以接下來拷貝的時候,拷貝的是已經被覆蓋的內容,顯然這是有問題的。
    實際上,
    memcpy只是memmove的一個子集

    二者的c語言實現很簡單,有興趣的朋友可以去看看。在實際情況下,這兩個函數都是用匯編實現的。

    memmove在copy兩個有重疊區域的內存時可以保證copy的正確,而memcopy就不行了,
    但memcopy比memmove的速度要快一些,如:
    char s[] = "1234567890";
    char* p1 = s;
    char* p2 = s+2;
    memcpy(p2, p1, 5)與memmove(p2, p1, 5)的結果就可能是不同的,memmove()可以將p1的頭5個字符"12345"正確拷貝至p2,而memcpy()的結果就不一定正確了

    memcpy()、 memmove()和memccpy()
    -------------------------------------------------------
        這三個函數的功能均是將某個內存塊復制到另一個內存塊。前兩個函數的區別在于它們處理內存區域重疊(overlapping)的方式不同。第三個函數的功能也是復制內存,但是如果遇到某個特定值時立即停止復制。
        對于庫函數來說,由于沒有辦法知道傳遞給他的內存區域的情況,所以應該使用memmove()函數。通過這個函數,可以保證不會出現任何內存塊重疊問題。而對于應用程序來說,因為代碼“知道”兩個內存塊不會重疊,所以可以安全地使用memcpy()函數。
    原型:extern void *memccpy(void *dest, void *src, unsigned char ch, unsigned int count);
      用法:#include <string.h>
      功能:由src所指內存區域復制不多于count個字節到dest所指內存區域,如果遇到字符ch則停止復制。
      說明:返回指向字符ch后的第一個字符的指針,如果src前n個字節中不存在ch則返回NULL。ch被復制。
    char s[]="Goldenx Global View";
    char d[20];
    char *p;
    p=(char *)memccpy(d,s,'x',strlen(s));
    if(p)
    {
       *p='\0'; // MUST Do This
       printf("Char found: %s.\n",d);
    }
    else
       printf("Char not found.\n");

    關于memmove的實現:

    點擊(此處)折疊或打開

    1. void *mymemmove(void *dest, const void *src, size_t n)
    2. {
    3.     char temp[n];
    4.     int i;
    5.     char *d = dest;
    6.     const char *s = src;
    7.     for (i = 0; i < n; i++) 
    8.         temp[i] = s[i];
    9.     for (i = 0; i < n; i++) 
    10.         d[i] = temp[i];
    11.     return dest;
    12. }
    關于memcpy的實現:

    點擊(此處)折疊或打開

    1. void *mymemcpy(void *dest, const void *src, size_t n)
    2. {
    3.     char *d = dest;
    4.     const char *s = src;
    5.     int *di;
    6.     const int *si;
    7.     int r = n % 4;
    8.     
    9.     while (r--)
    10.         *d++ = *s++;
    11.     di = (int *)d;
    12.     si = (const int*)s;
    13.     n /= 4;
    14.     while (n--)
    15.         *di++ = *si++;
    16.     return dest;
    17. }
     RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成
    最近免费观看高清韩国日本大全