版权声明:本文出自阿钟的博客,转载请注明出处:http://blog.youkuaiyun.com/a_zhon/。
一:前面我们介绍了一级指针的相关概念和用发,今天我们就来说一说多级指针。
1.定义多级指针
#include<stdio.h>
#include<stdlib.h>
/**
多级指针
指针指向的还是是内存地址
*/
main(){
//定义一个int类型的变量,并且赋值为100
int i = 100;
//定义一个int类型的一级指针变量p1,并且把i的地址赋值给它 int* p1 = &i; //定义一个int类型的二级指针变量p2,并且把p1的地址赋值给它 int** p2 = &p1; //定义一个int类型的三级指针变量p3,并且把p3的地址赋值给它 int*** p3 = &p2; //定义一个int类型的四级指针变量p4,并且把p3的地址赋值给它 int**** p4 = &p3; //多级指针取值 printf("****p4的值%d\n",****p4); system("pause"); }
多级指针就类似于递归,一级一级一直传递下去。
二:数组的定义,数组的取值
1.先回顾一下 Java中是怎么定义的
int arr[] = { 1, 5, 36, 9, 0 }; //或者[]在左边 int[] arr = { 1, 5, 36, 9, 0 }; //数组的取值 int i = arr[0];
在C中其实和Java也差不多,不同之处在于“[ ]”只能在数组名的右边
int arr2[] = { 1, 5, 36, 9, 0 }; //数组的取值,和Java还是没有差别的,但是C语言中还有另一种方式取值 printf("arr2[0]=%d\n",arr2[0]);
2.C语言中我们可以直接用指针取值,如下:
//打印数组每个元素的地址值
int j;
for(j=0; j<5; j++) {
printf("arr2[%d]地址=%#x\n",j,&arr2[j]); } //使用指针取值 int i; for(i=0; i<5; i++) { printf("arr2[%d]=%d\n",i,*(arr2 + i)); }
为什么可以这样取呢?我们看打印的地址值可以看出,数组是一块连续的内存空间。这里arr2是一个地址值,当循环一次地址值也就加1也就是取的下一个下标的地址值,*(arr2 + i)也就是取地址值对应的值。
3.不是说数组是一块连续的内存空间吗?为什么地址值不是连续的呢,看官莫着急看如下代码就略知一二了:
char arr[] = {'H','e','l','l','o'}; int j; for(j=0; j<5; j++) { printf("arr[%d]地址=%#x\n",j,&arr[j]); }
当我们打印char数组的地址值时,地址确实是一个连续的地址。那我们的int数组为什么相差4呢?原因其实很简单,char在内存中占一个字节所以而int所占的是4个字节。这就是为什么int数组的地址值都相差4了。
4.这里在提一点:就是数组的地址值等于数组第一个元素的地址值
int arr2[] = {1,5,36,9,0}; //取arr2的内存地址值 printf("arr2地址=%#x\n",&arr2); //取arr2[0]内存地址值 printf("arr2[0]=%#x\n",&arr2[0]);
三:让用户从控制台输入一个数组,并打印至控制台
#include<stdio.h>
#include<stdlib.h>
/**
* 用户输入数组
*1.用户输入数组的长度
*2.根据用户输入的长度创建数组 *3.让用户输入数组的值 *4.把数组内容打印出来 */ main() { int length; printf("请输入数组长度:\n"); //获取用户输入数组的长度 scanf("%d",&length); //根据用户输入的长度创建数组 int arr[length]; int i; for(i=0; i<length; i++) { printf("请输入arr[%d]的值:\n",i); //循环获取控制台的内容 scanf("%d",&arr[i]); } //把数组内容打印出来 for(i=0; i<length; i++) { printf("arr[%d]=%d\n",i,arr[i]); } system("pause"); }