现在的位置: 首页 > 综合 > 正文

c/c++内存操作注意

2012年10月24日 ⁄ 综合 ⁄ 共 888字 ⁄ 字号 评论关闭

永远只在已分配的内存上操作,而不去操作自己不熟悉的内存。

如下代码是实现自我复制功能,但是是未成品:

#include <stdio.h>
#include <stdlib.h>
#include <dir.h>
#include <string.h>
#define MAXPATH 256
#define WIN
#ifdef LINUX
#endif
#ifdef WIN
    int copy(char* from,char* to){
        char cmd="copy "; 
        memcpy(cmd+strlen(cmd),from,strlen(from)+1);
        memcpy(cmd+strlen(cmd)," /0",2);
        memcpy(cmd+strlen(cmd),to,strlen(to)+1);
        printf("%s",cmd);
        system(cmd);
    }
#endif
int main(){
    char *buffer;
    getcwd(buffer,MAXPATH);
    printf( "The   current   directory   is:   %s /n",   buffer);
    //printf("buffer is %d/n",&buf);
    //printf("*buffer is %c/n",*buf);
    buffer=strcat(buffer,"//copy.exe");
    copy(buffer,"e://xx");
    return   0;
}

copy函数中的内存操作memcpy,都是为了连接两个字符串。

如上代码中,直接操作cmd的字符串常量"copy ",很容易产生问题,在某些特殊的情况下,可能不报内存错误,可一旦内存操作,违规访问到了不该方位的内存区域,系统会报出内存不可写的错误。毕竟谁也不知道这段代码会覆盖哪些数据。其中一个的办法就是,给cmd一个充足的内存空间,确保内存操作一定在这个合法的区域内。而最好的办法是,不要自己直接去操作内存,而用系统存在的字符串操作函数来操作字符串。

【上篇】
【下篇】

抱歉!评论已关闭.