定义:数组
int *pia = new int[10]; // array of 10 uninitialized ints
此 new 表达式分配了一个含有 10 个 int 型元素的数组,并返回指向该数组第一个元素的指针,此返回值初始化了指针 pia。安全
在自由存储区中建立的数组对象是没有名字的,只能经过其地址间接地访问堆中的对象。数据结构
注意:C++使用new和delete在堆(自由存储区)上分配和释放动态数组。函数
动态数组初始化:学习
1. 元素只能初始化为元素类型的默认值,而不能像数组变量同样,用初始化列表为数组元素提供各不相同的初值。spa
2. 对于内置数据类型元素的数组,必须使用()来显示指定程序执行初始化操做,不然程序不执行初始化操做:.net
int *pia = new int[10]; // 每一个元素都没有初始化 int *pia2 = new int[10] (); // 每一个元素初始化为0
3.类类型元素的数组,则不管是否使用(),都会自动调用其默认构造函数来初始化:指针
string *psa = new string[10]; // 每一个元素调用默认构造函数初始化 string *psa = new string[10](); // 每一个元素调用默认构造函数初始化
动态分配空数组:code
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;
一、数组名的内涵在于其指代实体是一种数据结构,这种数据结构就是数组;
二、数组名的外延在于其能够转换为指向其指代实体的指针,并且是一个指针常量;
三、指向数组的指针则是另一种变量类型,(在win32平台下,长度为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,那么当给指针赋予其余的地址值时,原来的内存将没法释放,这就叫作内存泄露。