永远只在已分配的内存上操作,而不去操作自己不熟悉的内存。
如下代码是实现自我复制功能,但是是未成品:
#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一个充足的内存空间,确保内存操作一定在这个合法的区域内。而最好的办法是,不要自己直接去操作内存,而用系统存在的字符串操作函数来操作字符串。