C语言中指针与数组的详解及区别
本文是本站小编整理的关于C语言重指针与数组的详解及对比的相关资料,供参考学习,希望对大家有所帮助!想了解更多相关信息请持续关注我们应届毕业生考试网!
C语言 指针与数组的详解及对比
通俗理解数组指针和指针数组
数组指针:
eg:int( *arr)[10];
数组指针通俗理解就是这个数组作为指针,指向某一个变量。
指针数组:
eg:int*arr[10];
指针数组简言之就是存放指针的数组;
——数组并非指针&&指针并非数组
(1)定义一个外部变量:
eg:int value=10; int *p=&value;
举例:当需要在一个函数中用这个变量时:externa int*p;而非extern int p[];
分析:当用:extern int p[];这样的形式时,其实是:由于在定义这个变量的时候,是作为一个指针而定义的,则p指向的`是 value的地址,当p当做一个数组被引入是,它其实存放的是value的地址,而并非指向value,导致调用出现错误。
(2)定义一个外部变量:
eg:int arr[10]={0};
举例:当需要在函数中引入这个外部变量时:extern int arr[10];而非extern int *arr;
分析:当用extern int *arr;这样的方式进行引入是,实际上这样是不对的,在定义这个变量的时候是作为一个整形数组来定义的,但是在声明的时候是用指针来声明的,通过数组声明可以访问到整个数组,但是通过指针实际上声明的指针并非指向数组,而是指向arr[10]数组中首元素arr[0]地址的指针,导致访问出现问题。
——二维数组与指针的关系
定义一个二维数组arr[3][3],由于二维数组在内存中也是按照顺序存储,而并非我们所认为的按照矩阵形式存储的。所以,arr[3]其实就相当与一个数组指针;指向arr[0][0],arr[1][0],arr[2][0].
____数组与指针的其他区别
(1) 指针保存的是数据的地址;
数组是用来保存数据的。
(2)指针访问数据是通过数据的地址进行解引用,间接访问的;
数组访问数据是直接的。
(3)指针通常用于动态数据结构;
数组用于存放固定数目而且类型相同的数据。
(4)指针通常指向匿名数据;
数组通常存放已知的。
-
c语言如何控制硬件
你们知道在C语言中如何控制计算机的硬件吗?下面是应届毕业生小编带来的关于c语言如何控制硬件的内容,欢迎阅读!c语言如何控制硬件?C语言是没办法控制硬件的首先,C语言不能够直接对硬件进行操作。从本质上来说,连汇编语言都不可以。只有机器语言能够直接操作硬件。...
-
C语言自增(++)和自减(--)
C语言源自KenThompson发明的B语言,那么大家知道C语言自增(++)和自减(--)是什么呢?下面一起来看看!一个整数自身加一可以这样写:a+=1;它等价于a=a+1;。但是在C语言中还有一种更简单的写法,就是a++;或者++a;。这种写法叫做自加或自增;意思很明确,就是自身加一。相应...
-
2017年计算机C语言考试编程练习题及答案
江山代有才人出,各领风骚数百年。以下是小编为大家搜索整理的`2017年计算机C语言考试编程练习题及答案,希望能给大家带来帮助!更多精彩内容请及时关注我们应届毕业生考试网!1.从键盘上输入8个浮点数,编程求出其和以及平均值。要求写出求和以及平均值的函数。答:编...
-
C语言合并排序及实例代码
归并排序也称合并排序,其算法思想是将待排序序列分为两部分,依次对分得的两个部分再次使用归并排序,之后再对其进行合并。下面是小编分享的C语言合并排序及实例代码,一起来看一下吧。合并排序仅从算法思想上了解归并排序会觉得很抽象,接下来就以对序列A[0],A[l]…,A...