如下,我知道语法上的含义:
char * ch = new char[10]; 会申请一个有十个char元素的数组,然后把地址存在ch中
char * ch = new char(10); 则会申请一个char的空间,用10去初始化
但是:在使用的时候,new char明明是申请了一个字符空间,为什么赋值字符串不产生越界呢? 那和new char[10]有什么区别呢?不是都可以使用吗?在修改内存值的时候也没有崩溃啊?到底是什么区别啊??
如下,我知道语法上的含义:
char * ch = new char[10]; 会申请一个有十个char元素的数组,然后把地址存在ch中
char * ch = new char(10); 则会申请一个char的空间,用10去初始化
但是:在使用的时候,new char明明是申请了一个字符空间,为什么赋值字符串不产生越界呢? 那和new char[10]有什么区别呢?不是都可以使用吗?在修改内存值的时候也没有崩溃啊?到底是什么区别啊??
a肯定是越界的。只不过你强行写入字符串时,越界的空间可能暂时是空闲的,没有被其它进程占用,所以可以写进去,但这不是肯定可以的,这样的代码是不被允许的,因为越界的空间是开放的,其它代码也可能写这个空间,或者你这个越界赋值已经覆盖了系统其它变量的值了