C语言的指针(进阶篇章之二)
2016-06-03 12:34
295 查看
指针遇到数组,不得不说的“秘密”
说起数组array[i]来,我们都知道:数组名“array”是数组的唯一标识符,数组名代表数组首元素的地址。而今天的主角——指针,则是用于存储地址,它在C语言使用中和数组名是紧密的联系在一起。
一、数组的访问方式
一般来说采用下标/偏移法和指针法来访问数组元素的。一维数组比较常见,而且简单易懂。(随便提一下:二维数组元素的表示方法是:数组名称[行][列],对于m 行n 列的二维数组,a[0][0] 是数组的第一个元素,a[m-1][n-1] 是最后一个元素。)
我们以二维数组为例–
eg:二维数组array[2][3]中,在内存储中存储形式如下图所示:
#include <stdio.h> int main() { int a[2][3] = {{1,2,3},{10,20,30},{100,200,300}}; for(int i=0; i<3; i++) { for(int j=0; j<4; j++) { printf("%p ",&a[i][j]); } putchar(10); } //研究数组名a的大小 printf("a = %p\n",a); printf("a + 0 = %p\n",a+0); printf("a + 1 = %p\t",a+1); printf("a + 2 = %p\n",a+2); //研究数组a的每个元素的大小 printf("a[0] = %p\n",a[0]); printf("a[1] = %p\t\t",a[1]); printf("a[1] + 1 = %p\t",a[1]+1); //研究二维数组到一维数组的关系化 printf("*(a+1)+1) = %d\t",*(a+1)+1)); printf("*(*(a+1) + 1) = %d\n",*(*(a+1)+1)); printf("&a[1] +1 = %p\n",&a[1]+1); return 0; }
从程序中我们可以总结出:
a //表示是数组下标为0的那一行的首地址
a+1 //表示是数组下标1的那一行的首地址[<=>&a[1] ]
a[1] //<=>a[1]+0,也是a[1][0]元素的地址
a[1]+1 //指的也是a[1][1]元素的地址
*(a+1)+1 //指的也是a[1][1]元素的地址
((a+1)+1) //指的是元素a[1][1]值
*( a[1]+1) //指的是元素a[1][1]值
二、指针与数组参数
指针与数组参数分为四种情况(这里一一列举出来,就不举例子了):【a】实参是数组,形参也是数组
主调函数:
int a[40];
function(a);
被调函数:
function(int a[]) {……}
【b】实参是数组,形参是数组指针
主调函数:
int a[40];
function(a);
被调函数:
function(int *p) {…}
【c】实参是数组指针,形参是数组指针
主调函数: int a[40]; int *p=a; function(p); 被调函数: function(int *q) {......}
【d】实参是数组指针,形参是数组
主调函数: int a[40]; int *p=a; function(p); 被调函数: function(int a[]) {......}
三、指针与字符串
重点的是指针数组和数组指针注:由于还没有说到字符串,这里就先起个头。望见谅。下章讲字符串。谢谢!
【文章来自本人的简书】
http://www.jianshu 4000
.com/writer#/notebooks/4124910/notes/4176907
相关文章推荐
- 非托管C++通过C++/CLI包装调用C# DLL
- C++面试笔记_1
- c语言 sqlite3数据库模块
- C++ 类的静态成员详细讲解
- 【C++错误检查】binary '>>' :
- c++ 修改内存
- c++ int to byte
- windows下C语言多线程编程
- vs添加lib等依赖项
- C++的强制类型转换
- 用C语言实现Ping命令
- 快速离散傅里叶变换(FFT)C++实现
- 最短摘要生成
- C++ Primer 第十四章 重载操作符与转换
- c++中的new是什么东西?
- 平衡二叉树思想及C语言实现
- c++心得之struct和class(结构体和类)
- 学习c++对类的6个成员函数的简单总结
- C++函数前和函数后加const修饰符区别
- C++结构体、联合、枚举与C语言中的区别