c++中,new的用法很灵活,这里进行了简单的总结:
" `) X5 t# d/ s# V) V9 N w! J
1. new() 分配这种类型的 一个大小的内存空间, 并以括号中的值来初始化这个变量;
1. new() 分配这种类型的 一个大小的内存空间, 并以括号中的值来初始化这个变量;
2.
new[] 分配这种类型的
n个
大小的内存空间,并用默认构造函数来初始化这些变量;
#include<iostream>
#include<cstring>
using namespace std; ) @8 b' j- i, F W$ q$ Z
int main(){ 7 o8 Z" h1 \4 J8 A8 R
//char* p=new char("Hello"); 6 @0 @4 A8 C% \6 R
//error分配一个char(1字节)的空间,
//用"Hello"来初始化,这明显不对
char* p=new char[6];
//p="Hello";
//不能将字符串直接赋值给该字符指针p,原因是: ' c3 {6 _) l7 P% Q2 u" S
//指针p指向的是字符串的第一个字符,只能用下面的 * I3 m* Z2 d; A+ \" L7 m# t
//strcpy
strcpy(p,"Hello");
cout<<*p<<endl; //只是输出p指向的字符串的第一个字符!
cout<<p<<endl; //输出p指向的字符串!
delete[] p; - q% k E w; Y
return 0;} 7 U) m4 |* B8 e' p: v
输出结果:
H
Hello ; P0 X% Z! [5 V8 j; l! ~; ^& D/ \
3. 当使用new运算符定义一个多维数组变量或数组对象时,它产生一个指向数组第一个元素的指针,返回的类型保持了除最左边维数外的所有维数。例如:
int *p1 = new int[10];
返回的是一个指向int的指针int* + l$ U; a+ [0 U8 K
int (*p2)[10] = new int[2][10];
new了一个二维数组, 去掉最左边那一维[2], 剩下int[10], 所以返回的是一个指向int[10]这种一维数组的指针int (*)[10].
int (*p3)[2][10] = new int[5][2][10]; new了一个三维数组, 去掉最左边那一维[5], 还有int[2][10], 所以返回的是一个指向二维数组int[2][10]这种类型的指针int (*)[2][10].
#include<iostream>
#include <typeinfo>
using namespace std; - @. Q b$ f: [( h
int main() {
int *a = new int[34];
int *b = new int[];
int (*c)[2] = new ; M/ L1 ]3 L) I ]" G1 s" x/ s& H
int[34][2];
int (*d)[2] = new int[][2];
int (*e)[2][3] = new int[34][2][3]; ) s s, _6 b& f4 j/ C- z/ Y/ L- u, g" p
int (*f)[2][3] = new int[][2][3];
a[0] = 1; + p6 N0 A" v" W: j3 e
b[0] = 1; //运行时错误,无分配的内存,b只起指针的作用,用来指向相应的数据 / P9 N _+ _- R. \
c[0][0] = 1;
d[0][0] = 1;//运行时错误,无分配的内存,d只起指针的作用,用来指向相应的数据 - i0 ^: D( C; n- A! V" J
e[0][0][0] = 1;
f[0][0][0] = 1;//运行时错误,无分配的内存,f只起指针的作用,用来指向相应的数据
cout<<typeid(a).name()<<endl; ! u. d" d# q( i% R
cout<<typeid(b).name()<<endl; : B8 L% z- W4 V6 e$ y3 y! [& d
cout<<typeid(c).name()<<endl;
cout<<typeid(d).name()<<endl; . _9 h9 K3 g/ ?
cout<<typeid(e).name()<<endl;
cout<<typeid(f).name()<<endl; . j9 `% R* S) l* a8 u" }; D* ~
delete[] a; delete[] b; delete[] c;
delete[] d; delete[] e; delete[] f; 5 ]5 h0 S" F3 g- r- d. b8 R/ j
} & Y6 r1 l0 j& i% r6 f& C1 A
输出结果:
int * ( }" q# ]" u% v) P! \8 _" Y! ]
int *
int (*)[2]
int (*)[2]
int (*)[2][3] $ v/ u( a: p& [
int (*)[2][3]
#include<cstring>
using namespace std; ) @8 b' j- i, F W$ q$ Z
int main(){ 7 o8 Z" h1 \4 J8 A8 R
//char* p=new char("Hello"); 6 @0 @4 A8 C% \6 R
//error分配一个char(1字节)的空间,
//用"Hello"来初始化,这明显不对
char* p=new char[6];
//p="Hello";
//不能将字符串直接赋值给该字符指针p,原因是: ' c3 {6 _) l7 P% Q2 u" S
//指针p指向的是字符串的第一个字符,只能用下面的 * I3 m* Z2 d; A+ \" L7 m# t
//strcpy
strcpy(p,"Hello");
cout<<*p<<endl; //只是输出p指向的字符串的第一个字符!
cout<<p<<endl; //输出p指向的字符串!
delete[] p; - q% k E w; Y
return 0;} 7 U) m4 |* B8 e' p: v
输出结果:
H
Hello ; P0 X% Z! [5 V8 j; l! ~; ^& D/ \
3. 当使用new运算符定义一个多维数组变量或数组对象时,它产生一个指向数组第一个元素的指针,返回的类型保持了除最左边维数外的所有维数。例如:
int *p1 = new int[10];
返回的是一个指向int的指针int* + l$ U; a+ [0 U8 K
int (*p2)[10] = new int[2][10];
new了一个二维数组, 去掉最左边那一维[2], 剩下int[10], 所以返回的是一个指向int[10]这种一维数组的指针int (*)[10].
int (*p3)[2][10] = new int[5][2][10]; new了一个三维数组, 去掉最左边那一维[5], 还有int[2][10], 所以返回的是一个指向二维数组int[2][10]这种类型的指针int (*)[2][10].
#include<iostream>
#include <typeinfo>
using namespace std; - @. Q b$ f: [( h
int main() {
int *a = new int[34];
int *b = new int[];
int (*c)[2] = new ; M/ L1 ]3 L) I ]" G1 s" x/ s& H
int[34][2];
int (*d)[2] = new int[][2];
int (*e)[2][3] = new int[34][2][3]; ) s s, _6 b& f4 j/ C- z/ Y/ L- u, g" p
int (*f)[2][3] = new int[][2][3];
a[0] = 1; + p6 N0 A" v" W: j3 e
b[0] = 1; //运行时错误,无分配的内存,b只起指针的作用,用来指向相应的数据 / P9 N _+ _- R. \
c[0][0] = 1;
d[0][0] = 1;//运行时错误,无分配的内存,d只起指针的作用,用来指向相应的数据 - i0 ^: D( C; n- A! V" J
e[0][0][0] = 1;
f[0][0][0] = 1;//运行时错误,无分配的内存,f只起指针的作用,用来指向相应的数据
cout<<typeid(a).name()<<endl; ! u. d" d# q( i% R
cout<<typeid(b).name()<<endl; : B8 L% z- W4 V6 e$ y3 y! [& d
cout<<typeid(c).name()<<endl;
cout<<typeid(d).name()<<endl; . _9 h9 K3 g/ ?
cout<<typeid(e).name()<<endl;
cout<<typeid(f).name()<<endl; . j9 `% R* S) l* a8 u" }; D* ~
delete[] a; delete[] b; delete[] c;
delete[] d; delete[] e; delete[] f; 5 ]5 h0 S" F3 g- r- d. b8 R/ j
} & Y6 r1 l0 j& i% r6 f& C1 A
输出结果:
int * ( }" q# ]" u% v) P! \8 _" Y! ]
int *
int (*)[2]
int (*)[2]
int (*)[2][3] $ v/ u( a: p& [
int (*)[2][3]
在这里要注意小括号()和中括号[]用法的区别,否则会出错,我自己曾经就在这个问题上吃过亏,希望大家多注意一下。