c/c++内存操作注意

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

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

#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一个充足的内存空间,确保内存操作一定在这个合法的区域内。而最好的办法是,不要自己直接去操作内存,而用系统存在的字符串操作函数来操作字符串。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值