[zt]C++⼆维数组讲解、⼆维数组的声明和初始化定义:
int *pia = new int[10]; // array of 10 uninitialized ints
此new表达式分配了⼀个含有 10 个int型元素的数组,并返回指向该数组第⼀个元素的指针,此返回值初始化了指针pia。在⾃由存储区中创建的数组对象是没有名字的,只能通过其地址间接地访问堆中的对象。
注意:C++使⽤new和delete在堆(⾃由存储区)上分配和释放动态数组。
动态数组初始化:
1. 元素只能初始化为元素类型的默认值,⽽不能像数组变量⼀样,⽤初始化列表为数组元素提供各不相同的初值。
2. 对于内置数据类型元素的数组,必须使⽤()来显⽰指定程序执⾏初始化操作,否则程序不执⾏初始化操作:
int *pia = new int[10]; // 每个元素都没有初始化
int *pia2 = new int[10] (); // 每个元素初始化为0
3.类类型元素的数组,则⽆论是否使⽤(),都会⾃动调⽤其默认构造函数来初始化:
string *psa = new string[10]; // 每个元素调⽤默认构造函数初始化
string *psa = new string[10](); // 每个元素调⽤默认构造函数初始化
动态分配空数组:
char *cp = new char[0];
之后,可以动态改变cp的维数。
动态释放:
delete [] pia;
典型使⽤⽰例:
const char *pc = "a very long literal string"; // 处理C风格字符串时使⽤const指针
const size_t len = strlen(pc) +1; // size_t⽤于数组的⼤⼩和下标
for (size_t ix = 0; ix != 1000000; ++ix) {
char *pc2 = new char[len]; // pc2指向的存储空间的内容会动态改变,因此不使⽤const
strncpy (pc2, pc, len); // 使⽤strncpy⽐使⽤strcpy安全
// do something;
delete [] pc2;
}
参考:
⼀、数组定义和初始化
1: ⼀维数组初始化:
2: 标准⽅式⼀:int value[100]; // value[i]的值不定,没有初始化
3: 标准⽅式⼆:int value[100] = {1,2}; // value[0]和value[1]的值分别为1和2,⽽没有定义的value[i>1]
4: // 则初始化为0
5: 指针⽅式:int* value = new int[n]; // 未初始化
6: delete []value; // ⼀定不能忘了删除数组空间
7:
8: ⼆维数组初始化:
9: 标准⽅式⼀:int value[9][9]; // value[i][j]的值不定,没有初始化
10: 标准⽅式⼆:int value[9][9] = {{1,1},{2}};//value[0][0,1]和value[1][0]的值初始化,其他初始化为0
11: 指针⽅式⼀:int (*value)[n] = new int[m][n];
12: delete []value; // n必须为常量,调⽤直观。未初始化
13: 指针⽅式⼆:int** value = new int* [m];
14: for(i) value[i] = new int[n];
15: for(i) delete []value[i];
16: delete []value; // 多次析构,存储⿇烦,未初始化
17: 指针⽅式三:int * value = new int[3][4]; // 数组的存储是按⾏存储的
18: delete []value; // ⼀定要进⾏内存释放,否则会造成内存泄露
19:
20: 多维数组初始化:
21: 指针⽅式:int * value = new int[m][3][4]; // 只有第⼀维可以是变量,其他⼏维必须都是常量,否则会报错
22: delete []value; // ⼀定要进⾏内存释放,否则会造成内存泄露
数组初始化的⼤括号后⾯要加“;”来表⽰结束。
数组访问:
指针形式:如⼆维数组value[i][j]的访问:
*(value[i] + j) 或
(*(value + i))[j]
⼆、数组作为参数传递
1: ⼀维数组参数传递:
2: void Func(int *value);
3: 或者是
4: void Func(int value[]);
5:
6: ⼆维数组传递:
7: 定义是int **value;的传递
8: void Func(int **value);
9: 定义是int (*value)[n] = new int[m][n];的传递
10: void func(int (*value)[n]); // sizeof(p)=4,sizeof(*value)=sizeof(int)*n;
c语言二维数组表示方法三、数组与指针关系
1、数组名的内涵在于其指代实体是⼀种数据结构,这种数据结构就是数组;
2、数组名的外延在于其可以转换为指向其指代实体的指针,⽽且是⼀个指针常量;
3、指向数组的指针则是另外⼀种变量类型,(在win32平台下,长度为4),仅仅意味着数组存放地址。
4、数组名作为函数形参时,在函数体内,其失去了本⾝的内涵,仅仅只是⼀个指针,⽽且在其失去其内涵的同时,它还失去了其常量特性,可以作⾃增、⾃减等操作,可以被修改。
四、数组的存储格式
多维数组在内存中存储时是按照最低维连续的格式存储的,如⼆维数组{{1,2},{3,4}}在内存中的位置是这样顺序的“1,3,2,4”,这跟matlab是有区别的,matlab是按列进⾏存储的。在使⽤指针进⾏索引时很有⽤。
五、字符数组
char类型的数组被称作字符数组,通常⽤来存储字符串。字符串是附加有特殊字符(串尾标志)的字符序列。串终⽌字符表明字符串已经结束,该字符由转义序列‘\0’定义,有时被称为空字符,占⽤⼀个字节,其中8位全为0。这种形式的字符串通常被称为C型字符串,因为以这样的⽅式定义字符串是在C语⾔中推出的,在C++⼀般使⽤string,⽽MFC中则定义了CString类。
字符串中每个字符占⽤⼀个字节,算上最后的空字符,字符串需要的字节数要⽐包含的字节数多⼀个。如:
char movie_star[15] = “Marilyn Monroe”;
这⾥字符串是14个字符,但是要定义15个字符串的数组。也可以不指定字符数组的个数。如:
char movie_star[] = “Marilyn Monroe”;
六、内存泄露
我们定义了⼀个指针,然后给它赋予了⼀个地址值,然后⼜不再使⽤,但是没有delete,那么当给指针赋予其他的地址值时,原来的内存将⽆法释放,这就叫做内存泄露。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论