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

/*************关于数组名***************/

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

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

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

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

2.取址符号&.

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

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

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

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

/*************关于指针数组***************/

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

1.定义

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

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

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

int x = 5;
ptr[0] = &x;
ptr[1] = &a[2];

2.如何使用?

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

/*************关于数组指针***************/

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

1.定义

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

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

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

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

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

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

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

2.如何使用?

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

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

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

int x = 5;
int * p = &x;
cout << *p << endl;    //输出5

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

/************关于二维数组***************/

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 个字节。

数组指针

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

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

总结:

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

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

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

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

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

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

时间: 2024-08-02 15:10:39

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

C++二级指针第二种内存模型(二维数组)

C++二级指针第二种内存模型(二维数组) 二维数组 二维数组本质上是以数组作为数组元素的数组,即“数组的数组”. 定义 类型说明符 数组名[常量表达式][常量表达式] 例如: float a[3][4],b[5][10]; 二维数组元素地址 #include <iostream> using namespace std; int main() { cout << "Hello world!" << endl; int a[3][4]={ {1,2,3

将树形结构的数组按照顺序遍历为二维数组

/** * 将树形结构的数组按照顺序遍历为二维数组 * renxing,2015年8月7日 11:06:47 */ function arr_child ($array) { static $res; if (!is_array($array)) { return false; } foreach ($array as $k=>$v) { if (is_array($v) && isset($v['child'])) { $child = $v['child']; //将这个数组的子

稀疏数组的经典应用(二维数组与稀疏数组的相互转换)

package com.zhangwl.数据结构.稀疏数组; /** * @ClassName SparseArray * @Description 棋盘游戏演示 * @Author zhangwl * @Date 2019/10/10 22:54 * @Version 1.0 **/public class SparseArray { public static void main(String[] args) { /*创建一个原始的二维数组11 * 11 ,0:表示没有棋子 :1:表示黑子:

c语言中二维数组作函数参数以及二维数组的理解

当二维数组作函数参数接受主调函数中的二维数组时,退化为一个指向数组的指针. 在此引用<c与指针>中的观点:作为函数 参数的多位数组名的穿递方式和一维数组名相同--实际传递的是个指向数组第一个元素的指针.但是,两者之间的区别在于, 多维数组的每个元素本身是另外一个数组,编译器需要知道它的维数,以便为函数形参的下标表达式进行求值.

一维数组、二维数组用数学公式初始化以及二维数组的行坐标可省

<span style="font-size:14px;">#include<stdio.h> #include<stdlib.h> //二维数组赋值 void show2() { int a[3][4]; int k=0; for(int i=0;i<3;i++) { for(int j=0;j<4;j++) { a[i][j]=i*4+(j+1);//数学公式 赋值 // a[i][j]= ++k;//与上面效果一致 printf(&

第二十一节(数组概要, 一维、二维数组的声明和使用,数组的排序,数组的查找,)

一维数组:1:/* 数组: 1. 数组是一种引用类型 2. 数组是一种简单的数据结构,线性的机构 3. 数组是一个容器,可以用来存储其他元素, 4. 数组也是可以存储任意数据类型的元素 5. 数组分为: 一维数组,二维数组,三维数组,多维数组 6. 数组中的存储的元素类型 是统一的 7. 数组的长度是不可变的,数组一旦创建长度就是不可变的,固定的 声明数组语法: <1>. 数组元素的类型[] 变量名称 <2>. 数组元素的类型 变量名称[] */ public class Arra

Unit06: 数组的常用方法_2 、 二维数组 、 String_1

1.数组API 数组=数据+操作数据的API 1. 数组 to String:2种: var str=arr.toString(); -->输出数组中的内容,每个元素用逗号分隔 -->自动调用 var str=arr.join("连接符") ******* -->输出数组中的内容,自定义元素间连接符 批量操作页面元素时,可以用join拼接成innerHTML,一次性修改 何时使用:2种固定套路 1. 将字符组成单词:arr.join("") 2.

十、数组(2):二维数组

1.什么是二维数组? int a[3][5]; 通常理解为a是一个3行5列的矩阵. 2.二维数组的遍历 for( i=0;i<3;i++ ){ for( j=0; j<5;j++){ a[i][j]=i*j; } } --a[i][j]是一个int --表示第i行第j列上的单元. 3.二维数组的初始化 int a[ ][5] = { {0,1,2,3,4}, {2,3,4,5,6}, }; --列数是必须给出的,行数可以由编译器来数 --每行一个{},逗号分隔 --最后的逗号可以存在,有古老的

数组问题 1.行列有序二维数组中查找2.在一组数成对出现的数中有两个数只出现一次3.在移位数组中查找一个数

一.在一个二维数组中,每一行都按从左到右递增的顺序排序,每一列都按从上到下的递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 思路: 首先选取数组中右上角的数字.如果该数字等于要查找的的数字,查找过程结束:如果该数字大于要查找的数字,剔除这个数字所在的列:如果该数字小于要查找的数字,剔除这个数字所在的行.也就是说如果要查找的数字不在数组的右上角,则每一次都在数组的查找范围剔除一行或一列,这样每一步都可以缩小查找的范围. 实现过程如下: 运行结果如下:

php显示判断数组是不是带下标的二维数组

1,代码: <?php header("Content-type:text/html;charset=utf-8"); function va($value){     echo "<pre>";     var_dump($value);     echo "</pre>"; } function edump($value){     va($value);     exit(); } function jdump