社区
C语言
帖子详情
关于二维数组与指针的几个搞不太清楚的地方
tuxyin
2010-12-02 09:46:31
int arr[5][4];
问1:
<1> arr
<2> arr[0]
<3> &arr[0][0]
<4> *arr
这几种种情况得到的是同一种结果吗?
问2:(*arr)+n 能得到二维数组所有元素地址吗?
问3:arr+n 等于 *(arr+n) 不?为啥?
问4:*arr[0] 等于 **arr 不?为啥?
...全文
112
8
打赏
收藏
关于二维数组与指针的几个搞不太清楚的地方
int arr[5][4]; 问1: arr arr[0] &arr[0][0] *arr 这几种种情况得到的是同一种结果吗? 问2:(*arr)+n 能得到二维数组所有元素地址吗? 问3:arr+n 等于 *(arr+n) 不?为啥? 问4:*arr[0] 等于 **arr 不?为啥?
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
8 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
wanlongpo
2010-12-04
打赏
举报
回复
int a[4][5];
aining0809
2010-12-03
打赏
举报
回复
我是这样理解的:
首先二维数组是有行列之分的,所以
arr是数组的首地址
&arr[0]是行地址
&arr[0][0]是列地址
其实上面的地址
值
是相同的,只是所解释的含义有所不同罢了。
而[]和*与&互为逆运算,例如*存在,就有可能将(行地址)->(列地址),而&则有可能将(列地址)->(行地址)
再例如:
a[0][0]是一个变量值
&arr[0][0]就是列地址,指向第0行的第一位
*(&a[0][0]):变量值->列地址->变量值
所以,以上问题的答案是
问1:
<1> arr (数组地址)
<2> arr[0] (列地址,&arr[0]是行地址)
<3> &arr[0][0] (列地址)
<4> *arr (行地址)
问2:(*arr)+n 能得到二维数组所有元素地址吗?
虽然是二维数组,但因为物理存储时连续的,所以是可以访问所有元素地址的。
问3:arr+n 等于 *(arr+n) 不?为啥?
值是相等的,但意义不同
arr+n是行地址,*(arr+n)是列地址
问4:*arr[0] 等于 **arr 不?为啥?
完全一致!首先这里得到的是数组值,只是表达的方式不太一样而已。
由列地址arr[0]通过*求的0行0列的值
由arr+0(行地址)-> *(arr+0)(列地址)-> *(*(arr+0)) 求得0行0列的值
----------
语无伦次,希望你能理解!
ForestDB
2010-12-03
打赏
举报
回复
关键:理解“类型”这一概念(原始类型,指针类型,数组类型);
C没有多维数组,只有数组的数组,即数组的元素是数组。
int arr[5][4];
问1:
<1> arr
arr是个数组有5个元素,每个元素又是个数组,有4个int
<2> arr[0]
arr[0]是个有4个int的数组
<3> &arr[0][0]
元素a[0][0]的地址
<4> *arr
这个和<2>一样,不过是用*来解引用的
这几种种情况得到的是同一种结果吗?
“值”相同,类型不同。
问2:(*arr)+n 能得到二维数组所有元素地址吗?
可以也不可以,可以是因为内存是平坦的,数组也是平坦的(而C是不检查越界的);
说不可以是因为由上*arr得到的是第0个int[4],+n得到的就是这个int[4]中的每个元素的地址。
问3:arr+n 等于 *(arr+n) 不?为啥?
不等于,arr是int[5][4]这样的类型,arr+n得到的是第n个元素(int[4]),而*(arr+n)是对int[4]解引用了,即每个int[4]中的第0个int。
问4:*arr[0] 等于 **arr 不?为啥?
等于,两种不同的解引用的方式。
bluewanderer
2010-12-02
打赏
举报
回复
数组的特点就是参与数值运算的时候会转换成对应的指针
char [5][4] -> char (*)[4]
char [4] -> char *
bluewanderer
2010-12-02
打赏
举报
回复
问1:
<1> arr (char (*)[4])
<2> arr[0] (char *)
<3> &arr[0][0] (char *)
<4> *arr (char *)
这几种种情况得到的是同一种结果吗?
前提是参与数值运算,并且不考虑类型,值都是一样的。后三个完全一样。
问2:(*arr)+n 能得到二维数组所有元素地址吗?
能
问3:arr+n 等于 *(arr+n) 不?为啥?
还是参与数值运算的话,并且不考虑类型,值一样
问4:*arr[0] 等于 **arr 不?为啥?
C里a[b]永远等价于*(a + b)
aa1013911535
2010-12-02
打赏
举报
回复
自己试试 啊
bullbat
2010-12-02
打赏
举报
回复
写几行测试代码 在汇编下看看 就明白了
MrEdifier
2010-12-02
打赏
举报
回复
LZ可以测试下,*arr和arr[0][0]值是否相等。这样就知道arr是否是指针的指针了。
免费下载:C语言难点分析整理.doc
1. C 语言中的
指针
和内存泄漏 5 2. C语言难点分析整理 10 3. C语言难点 18 4. C/C++实现冒泡排序算法 32 5. C++中
指针
和引用的区别 35 6. const char*, char const*, char*const的区别 36 7. C中可变参数函数实现 38 8. C程序内存中组成部分 41 9. C编程拾粹 42 10. C语言中实现数组的动态增长 44 11. C语言中的位运算 46 12. 浮点数的存储格式: 50 13. 位域 58 14. C语言函数
二维数组
传递方法 64 15. C语言复杂表达式的执行步骤 66 16. C语言字符串函数大全 68 17. C语言宏定义技巧 89 18. C语言实现动态数组 100 19. C语言笔试-运算符和表达式 104 20. C语言编程准则之稳定篇 107 21. C语言编程常见问题分析 108 22. C语言编程易犯毛病集合 112 23. C语言缺陷与陷阱(笔记) 119 24. C语言防止缓冲区溢出方法 126 25. C语言高效编程秘籍 128 26. C运算符优先级口诀 133 27. do/while(0)的妙用 134 28. exit()和return()的区别 140 29. exit子程序终止函数与return的差别 141 30. extern与static存储空间矛盾 145 31. PC-Lint与C\C++代码质量 147 32. spirntf函数使用大全 158 33. 二叉树的数据结构 167 34. 位运算应用口诀和实例 170 35. 内存对齐与ANSI C中struct内存布局 173 36. 冒泡和选择排序实现 180 37. 函数
指针
数组与返回数组
指针
的函数 186 38. 右左法则- 复杂
指针
解析 189 39. 回车和换行的区别 192 40. 堆和堆栈的区别 194 41. 堆和堆栈的区别 198 42. 如何写出专业的C头文件 202 43. 打造最快的Hash表 207 44.
指针
与数组学习笔记 222 45. 数组不是
指针
224 46. 标准C中字符串分割的方法 228 47. 汉诺塔源码 231 48. 洗牌算法 234 49. 深入理解C语言
指针
的奥秘 236 50. 游戏外挂的编写原理 254 51. 程序实例分析-为什么会陷入死循环 258 52. 空
指针
究竟指向了内存的哪个
地方
260 53. 算术表达式的计算 265 54. 结构体对齐的具体含义 269 55. 连连看AI算法 274 56. 连连看寻路算法的思路 283 57. 重新认识:指向函数的
指针
288 58. 链表的源码 291 59. 高质量的子程序 295 60. 高级C语言程序员测试必过的十六道最佳题目+答案详解 297 61. C语言常见错误 320 62. 超强的
指针
学习笔记 325 63. 程序员之路──关于代码风格 343 64.
指针
、结构体、联合体的安全规范 346 65. C
指针
讲解 352 66. 关于指向
指针
的
指针
368 67. C/C++ 误区一:void main() 373 68. C/C++ 误区二:fflush(stdin) 376 69. C/C++ 误区三:强制转换 malloc() 的返回值 380 70. C/C++ 误区四:char c = getchar(); 381 71. C/C++ 误区五:检查 new 的返回值 383 72. C 是 C++ 的子集吗? 384 73. C和C++的区别是什么? 387 74. 无条件循环 388 75. 产生随机数的方法 389 76. 顺序表及其操作 390 77. 单链表的实现及其操作 391 78. 双向链表 395 79. 程序员数据结构笔记 399 80. Hashtable和HashMap的区别 408 81. hash 表学习笔记 410 82. C程序设计常用算法源代码 412 83. C语言有头结点链表的经典实现 419 84. C语言惠通面试题 428 85. C语言常用宏定义 450
二维数组
与
指针
(详解)
一.2维数组 1.
二维数组
的定义 int a[3][3]; 在这我们定义了一个
二维数组
,拥有3行3列共9个int型存储空间大小。 2.
二维数组
的行地址和各个元素地址的表示 int a[3][4]; 对于数组a,我们可以将a[3][4]分为两部分理解a[3]和[4],对于a[3],我们可以看成是一个一维数组,其元素分别为a[0],a[1],a[2],他们分别表示各行所代表的起始地址,而对于[4]...
c语言二维数与
指针
,
二维数组
与
指针
(教程)
二维数组
与
指针
(教程)
二维数组
与
指针
1.
二维数组
元素在内存中的存放方式在C++中,
二维数组
元素值在内存中是按行的顺序存放的。若定义二维整型数组a[3][3],假设编译系统为数组a分配的内存空间从1000开始到1035为止,则数组中各元素a[0][0]~a[2][2]在内存中按行存放次序如图7.6所示。因此,与一维数组类似,可用
指针
变量来访问
二维数组
元素。【例7.7】用
指针
变量输出
二维数组
各元素...
【C语言】
二维数组
与
指针
我们都知道一维数组,但是关于
二维数组
,我们容易
搞
蒙。有一个特殊的说法:
二维数组
就是父子数组,为了研究
清楚
地址的概念,我们把
二维数组
回归到一维数组去讲解。看这段代码: 通过对
指针
和数组的学习,我们明白了数组名就是地址,所以我们可以把
二维数组
a[3][4]a[3][4]a[3][4] 中的 a[3]a[3]a[3] 看作是父数组,那么它的地址就是数组名 aaa ,也叫行地址,父数组中包含三个元素:a[0]a[0]a[0]、a[1]a[1]a[1]、a[2]a[2]a[2] 。再看上面一幅图片,在每个父
二维数组
指针
表示,C语言
指针
引用
二维数组
详解
指针
变量可以指向一维数组中的元素,当然也就可以指向
二维数组
中的元素。但是在概念和使用方法上,
二维数组
的
指针
比一维数组的
指针
要复杂一些。要理解
指针
和
二维数组
的关系首先要记住一句话:
二维数组
就是一维数组,这句话该怎么理解呢? 假如有一个
二维数组
: int a[3][4] = {{1, 3, 5, 7}, {9, 11, 13, 15}, {17, 19, 21, 23}}; 其中,a 是
二维数组
名...
C语言
70,023
社区成员
243,263
社区内容
发帖
与我相关
我的任务
C语言
C语言相关问题讨论
复制链接
扫一扫
分享
社区描述
C语言相关问题讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章