wanwan_1996 2017-11-24 07:01 采纳率: 0%
浏览 1133
已采纳

关于malloc、new的一个问题

自己写小项目是发现一个问题。

 #define BUFFER_SIZE 1024 * 1024
@1. char *pbuffer1 = new char(BUFFER_SIZE);

@2. char *pbuffer2 = (char *)malloc(sizeof(char) * BUFFER_SIZE);

在linux下编译时,使用1出现一个警告(overflow in implicit ....),而使用2确完全正常。

这是为什么,来个详细解答?

  • 写回答

1条回答 默认 最新

  • oyljerry 2017-11-24 07:07
    关注

    new是c++语法,它的分配应该是

      char *pbuffer1 = new char[BUFFER_SIZE];
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?
  • ¥15 关于#vue.js#的问题:修改用户信息功能图片无法回显,数据库中只存了一张图片(相关搜索:字符串)
  • ¥15 texstudio的问题,