深入理解memmove()與memcpy()的區(qū)別以及實(shí)現(xiàn)方法
更新時間:2013年05月29日 16:51:44 作者:
本篇文章是對memmove()與memcpy()的區(qū)別以及實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下

代碼如下所示:
復(fù)制代碼 代碼如下:
// MemMove.cpp : 定義控制臺應(yīng)用程序的入口點(diǎn)。
//
#include "stdafx.h"
#include <iostream>
using namespace std;
復(fù)制代碼 代碼如下:
void* memmove(void* dest, const void* src, size_t n)
{
if (n <= 0)
{
cout << "Invalid count number." << endl;
}
if (dest == NULL || src == NULL)
{
cout << "The dest or src address is null." << endl;
}
if (dest == src)
{
cout << "The dest equals src." << endl;
}
if ((char*)dest <= (char*)src || (char*)dest >= (char*)src + n)
{//對應(yīng)圖中2,3,4三種情況,賦值過程中,src中未使用的不會被覆蓋
char* de = (char*)dest;
const char* sr = (const char*)src;
while (n--)
{
*de++ = *sr++;
}
}
else
{//對應(yīng)圖中的第一種情況
char* de = (char*)dest + n -1;
const char* sr = (const char*)src + n - 1;
while (n--)
{
*de-- = *sr--;
}
}
return dest;
}
復(fù)制代碼 代碼如下:
void* memmcpy(void* dest, const void* src, size_t n)
{
if (n <= 0)
{
cout << "Invalid count number." << endl;
}
if (dest == NULL || src == NULL)
{
cout << "The dest or src address is null." << endl;
}
if (dest == src)
{
cout << "The dest equals src." << endl;
}
char* de = (char*)dest;
const char* sr = (const char*)src;
while (n--)
{
*de++ = *sr++;
}
return dest;
}
復(fù)制代碼 代碼如下:
int _tmain(int argc, _TCHAR* argv[])
{
char* p = "hello,world";
char dest[12] = {0};
char *q = (char*)memmove(dest,p,5);
cout << dest << endl;
cout << q << endl;
return 0;
}
相關(guān)文章
C語言數(shù)組應(yīng)用實(shí)現(xiàn)三子棋游戲
這篇文章主要為大家詳細(xì)介紹了C語言數(shù)組應(yīng)用實(shí)現(xiàn)三子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06
C++ 基于BFS算法的走迷宮自動尋路的實(shí)現(xiàn)
這篇文章主要為大家介紹了C++ 基于BFS算法實(shí)現(xiàn)走迷宮自動尋路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11
C語言中魔性的float浮點(diǎn)數(shù)精度問題
這篇文章主要介紹了魔性的float浮點(diǎn)數(shù)精度問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

