C++指针数组、数组指针、数组名及二维数组技巧汇总

这篇文章主要介绍了C++指针数组、数组指针、数组名及二维数组技巧汇总,对于深入理解C++数组与指针来说非常重要,需要的朋友可以参考下。

本文较为详细的分析了关于理解C++指针数组,数组指针,数组名,二维数组的一些技巧。是比较重要的概念,相信对于大家的C++程序设计有一定的帮助作用。

一、关于数组名

假设有数组:


1

int
a[3] = {1, 2, 3}

1.数组名代表数组第一个元素的地址,注意,不是数组地址(虽然值相等),是数组第一个元素地址,a 等同于 &a[0];

a+1是第二个元素的地址。比第一个元素地址a(或者&a[0])超出了一个整型指针的大小,在这里是4个字节(byte)


1

cout << a << endl;//会输出数组第一个元素地址。

2.取址符号&.

&a是数组的地址,注意是数组的地址,表示数组这个整体的地址。不是数组第一个元素的地址(虽然他们的值相同)

&a+1比数组的地址&a超出了一个数组的地址大小,在这里是3*4个字节

int * p = &a;这条语句是不成立的。左边指针变量p时指向整型的指针,而右边是数组(类型是数组)的地址,不是数组元素(类型是整型)的地址,所以不能赋值。

应该赋值给数组指针(下面会讲到)。

关于数组名,切记以上两点。

二、关于指针数组

1.定义

指针数组,就是存放指针的数组,数组里的元素是指针(对比于整型数组,整型数组就是存放整型的数组,数组里的元素是整型)

int *ptr[3];如何理解?按照运算符优先级,[]优先级较大,所以ptr先与[3]结合,表示ptr是一个数组,必然要明确数组的元素类型,所以数组里的元素类型是整型指针(int*),数组的大小不一定需要(定义数组时可以根据初始化的元素个数确定)

ptr[0]就是数组的第零个元素,它是一个整型指针。

示例如下:


1

2

3

4

int
a[3] = {1, 2, 3};

int
x = 5;

ptr[0] = &x;

ptr[1] = &a[2];

2.如何使用?

像一般指针一样使用。*ptr[0]就是第零个元素(一个指针)所指向元素的值,这里是 5。

三、关于数组指针

1.定义

数组指针,就是指向数组的指针,它是一个指针,指向一个数组(对比于整型指针,就是指向整型的指针,它是一个指针,指向一个整型)

int (*ptr)[3]; 如何理解?先看小括号里面,*ptr说明ptr是一个指针,然后跟[]结合表明这个指针指向一个数组,数组的元素是int


1

2

int
a[3] = {1, 2, 3};

int(*ptr)[3] = a;//这条语句不成立。

右边a是数组名,还记得上面说的吗,数组名代表数组第一个元素的地址,就是&a[0],数组名的类型相当于整型指针(不知道事实上是不是)int *,因为它指向了第一个元素,第一个元素是int

左边ptr的类型是int(*)[],是数组指针,指向数组的指针,不是指向整型的指针,不能赋值。


1

2

int
a[3] = {1, 2, 3};

int
(*ptr)[3] = &a;//正确。

因为a是一个数组,&a就是数组的地址,还记得上面说的吗?

2.如何使用?


1

2

3

4

5

int
a[3] = {1, 2, 3};

int
(*ptr)[3] = &a;

 

cout << (*ptr)[0] << endl; 
//输出1

cout << (*ptr)[1] << endl; 
//输出2

这里有一点难以理解。不防对比一下一下代码。


1

2

3

4

int
a[3] = {1, 2, 3};

int
x = 5;

int
* p = &x;

cout << *p << endl; 
//输出5

p是一个指向整型的指针,*p就是所指向的变量(整型x)的值。同理ptr是指向数组的指针,*ptr就是所指向的变量(数组a)的值。(*ptr)[0]就是数组的第零个元素。

四、关于二维数组

1.二维数组是一个数组,它的元素是一维数组。谨记这一点,然后把上面的套进来就行了。


1

int
a[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};

数组名

a是数组第一个(或者说第零个更好)元素的地址,第一个元素是一维数组,a[0] ------> {1, 2, 3}。a+1是第二个元素的地址,就是第二个一维数组的地址,超出了3*4个字节

&a是数组的地址,&a+1 就是超出了一个二维数组的大小,超出了3 * 4 * 3 个字节。

数组指针


1

int
(*ptr)[3] = a; //正确。

因为a表示第一个元素的地址,第一个元素是一个一维数组,所以a表示一个一维数组的地址,一个数组的地址赋值给数组指针,成立。

五、总结:

1.数组名表示数组的第一个元素的地址。

2.&a(a是一个数组)是数组的地址。

3.指针数组是一个数组,它的元素是指针。

4.数组指针是一个指针,它指向一个数组。

5.二维数组的元素是一维数组。

时间: 2024-10-16 07:56:23

C++指针数组、数组指针、数组名及二维数组技巧汇总的相关文章

关于理解指针数组,数组指针,数组名,二维数组的一些技巧。

/*************关于数组名***************/ int a[3] = {1, 2, 3} 1.数组名代表数组第一个元素的地址,注意,不是数组地址(虽然值相等),是数组第一个元素地址,a 等同于 &a[0]; a+1是第二个元素的地址.比第一个元素地址a(或者&a[0])超出了一个整型指针的大小,在这里是4个字节(byte) cout << a << endl;会输出数组第一个元素地址. 2.取址符号&. &a是数组的地址,注意

编程题:指向二维数组元素的指针变量。功能:已知二维数组a[2][3],输入输出全部元素。

#include<stdio.h> void main() { int a[2][3],i,j; int *p; /*用坐标法输入二维数组元素*/ for(i=0;i<2;i++) for(j=0;j<3;j++) scanf("%d",&a[i][j]); /*用指针法输出二维数组元素*/ p=a[0];         /*等价于p&a[0][0];*/ for(;p<a[0]+6;p++)   printf("%4d&quo

数组 两种初始化方式及二维数组

数组: 静态数组  和  动态数组 1.写法: 定义:用来存储一组相同数据类型的元素 * * * * *   数组中存储的元素必须是相同的数据类型 数组的声明  初始化 Int[] a={1,2,3,4}; 数组的初始化: 静态初始化: //方式1 int[] a={'a',2,3,34,3,4,5,6,7,8,7,8,9,0,4,5,6,7,8};//声明的同时初始化 double[] a1={1.2f}; //方式2 int b[]={1,2,3,4}; //方式3: int[] c;  

jQuery写省级联动列表,创造二维数组,以及如何存/调用二维数组中的数据

jQuery写省级联动列表,创造二维数组来存放数据,然后通过each来遍历调用,通过creatTxtNode创建文本节点,通过createElement创建标签option,在通过append将文本写入option,再通过appendTo将文本追加到id为city的市级列表中 代码如下: jquery部分: 1 <script src="js/jquery-1.8.3.js" type="text/javascript" charset="utf-8

PHP二维数组转换成一维数组,一个变量多个二维数组转换成一维数组,PHP二维数组(或任意维数组)转换成一维数组的方法汇总,array_reduce(); array_walk_recursive(); array_map();

方法汇总: 1. array_reduce函数法 //用array_reduce()函数是较为快捷的方法: $result = array_reduce($user, function ($result, $value) { return array_merge($result, array_values($value)); }, array()) 2. array_walk_recursive函数法 //用array_walk_recursive()函数就非常灵活,可以把任意维度的数组转换成一

C二维字符数组的使用及如何获取二维数组的总行数和总列数!

#include <stdio.h> #include <stdlib.h> int main(){ char str[][30] = {"zhangsan","lisi","wangwu"}; char (*p)[30] = str; //定义行指针 printf("%p %p %p 行数:%d 列数:%d\n",str, &str[0], &str[0][0], sizeof(str

在二维数组中查找一个数,二维数组是从左到右,从上到下依次递增

public class FindNum { public static boolean findANum(int[][] array, int target) { int row = array.length;//行数 int cloumn = array[0].length;//列数 int i = 0; int j = cloumn - 1; boolean found = false; while(i <= row-1 && j >= 0) { if(target &l

二维数组名和二级指针

1. 指针 1.1 一个指针包含两方面:a) 地址值:b) 所指向的数据类型. 1.2 解引用操作符(dereference operator)会根据指针当前的地址值,以及所指向的数据类型,访问一块连续的内存空间(大小由指针所指向的数据类型决定),将这块空间的内容转换成相应的数据类型,并返回左值. 有时候,两个指针的值相同,但数据类型不同,解引用取到的值也是不同的,例如, 1 char str[] ={0, 1, 2, 3}; /* 以字符的ASCII码初始化 */ 2 3 char * pc

二维数组与指针

二维数组: int / char / flaot a[n][m]; 可以看做是将一维数组做为基本类型产生的一维数组的数组类型,共n*m个最基本类型.这样看有许多优点(实际上计算机也是这样分配的). 二维数组数组名的注意事项: 1 #include <stdio.h> 2 int main() 3 { 4 int *p,a[3][4]; 5 p = a;//a是二维数组的首地址本质为行指针,原型为 a[][]:无法赋值给普通指针类型 *p: 6 return 0; 7 } 编译就会出现如下错误