memmove函数分析
2014-11-26 09:46
232 查看
memmove函数考虑到复制过程中出现内存重叠的情况,
其函数原型为void * MemMove(void * pDst, const void * pSrc, int nLength)
当出现内存重叠时,必须设计复制过程, 避免数据被破坏。
目标地址的内存空间首部和源地址内存空间的尾部有重叠,需要从源地址尾部开始复制, 其余时候都可以从前往后拷。
void * MemMove(void * pDst, const void * pSrc, int nLength)
{
char * pcDst = (char *)pDst;
char * pcSrc = (char *)pSrc;
if (pDst == NULL || pSrc == NULL )
{
throw string("error");
pDst = NULL ;
return NULL;
}
else if ( pcDst < pcSrc + nLength && pcDst > pcSrc)
{
pcDst += nLength-1;
pcSrc += nLength-1;
while (nLength--)
{
*pcDst-- = * pcSrc--;
}
}
else
{
while (nLength--)
{
*pcDst++ = * pcSrc++;
}
}
return pDst;
}
其函数原型为void * MemMove(void * pDst, const void * pSrc, int nLength)
当出现内存重叠时,必须设计复制过程, 避免数据被破坏。
目标地址的内存空间首部和源地址内存空间的尾部有重叠,需要从源地址尾部开始复制, 其余时候都可以从前往后拷。
void * MemMove(void * pDst, const void * pSrc, int nLength)
{
char * pcDst = (char *)pDst;
char * pcSrc = (char *)pSrc;
if (pDst == NULL || pSrc == NULL )
{
throw string("error");
pDst = NULL ;
return NULL;
}
else if ( pcDst < pcSrc + nLength && pcDst > pcSrc)
{
pcDst += nLength-1;
pcSrc += nLength-1;
while (nLength--)
{
*pcDst-- = * pcSrc--;
}
}
else
{
while (nLength--)
{
*pcDst++ = * pcSrc++;
}
}
return pDst;
}
相关文章推荐
- Oracle 分析函数的使用
- BO2K源码分析(一 WinMain()函数)
- Oracle 9i 分析函数参考手册
- Oracle 9i 分析函数参考手册
- WinCE 开始菜单StartMenu_Create()函数代码分析
- [原创]MFC框架程序WINMAIN函数分析(一)
- IP函数分析_APUE
- Oracle分析函数学习笔记3
- oracle分析函数(二)
- BO2k源代码分析(一)----WinMain()函数
- Intel平台下linux中 ELF文件动态链接的加载、解析及实例分析(二): 函数解析与卸载
- 【分析】利用格式化串覆盖*printf()系列函数本身的返回地址
- 【分析】C++中通过溢出覆盖虚函数指针列表执行代码
- VC环境下对函数调用的汇编分析【原创】
- 性能测试-函数性能分析篇
- VxWorks romStar函数分析
- Win32程序函数调用时堆栈变化情况分析(zt)
- 语法分析表产生器的代码之一:主函数main.cpp
- Oracle 分析函数使用介绍
- WinCE 开始菜单StartMenu_Create()函数代码分析