20.指针相关知识点1

指针相关知识点1

1.定义一个指针变量指向数组

  • 指向数组首元素的地址

  • 指向数组起始位置:等于数组名

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p;
    	
    	p = &arr[0];//数组的首地址就是首个元素的地址
    	//p = arr;//数组名就是数组的首地址
    	
    	printf("首元素:%d\n",*p);  
    }

2.指针偏移遍历数组

  • 指针增量和数组的关系

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p;
    	
    	p = &arr[0];
    	printf("0元素:%d\n",*p);
    	printf("1元素:%d\n",*(p+1));//P+1:地址偏移了一个类型的字节数
    	printf("1元素:%d\n",*(p+2));    
    }
  • 指针的方式来遍历数组

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p;
    	p = arr;
    	for(int i = 0;i<3;i++){
    		printf("%d\n",*(p+i));
    	}
    	
    }
  • 指针的方式来打印地址

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p;
    	p = arr;
    	for(int i = 0;i<3;i++){
    		printf("%p\n",(p+i));
    	}
    	
    }
  • 通过指针引用数组元素

    • 下表法
    • 指针法
      • 偏移
      • 去内容
    • 两种方式的对比

3.指针偏移的补充

  • 再次进行循环记得回到数组首地址

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p;
    	p = arr;
    	for(int i = 0;i<3;i++){
    		printf("%d\n",*p);
    		p++;
    	}
    	
    	p = arr;//再次通过指针变量进行遍历输出
    			//记得重新让指针回到数组的首元素
    	for(int i = 0;i<3;i++){
    		printf("%d\n",*p);
    		p++;
    	}
    		
    }

4.指针和数组名的见怪不怪

  • 指针当作数组名,下标访问

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p = arr;
    	printf("数组的首地址:%d\n",*p);//数组的首地址
    	printf("下标访问:%d",p[2]);//下标访问
    }
  • 循环遍历下标访问

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p = arr;
    	for(int i = 0;i<3;i++){
    		printf("%d\n",p[i]);
    	}
    }
  • 数组名拿来加

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p = arr;
    	for(int i = 0;i<3;i++){
    		//printf("%d\n",*(p+i));
    		printf("%d\n",*(arr+i));
    	}
    }
  • 数组名和指针的区别

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p = arr;
    	for(int i = 0;i<3;i++){
    		printf("%d\n",*p++);
    	}
    }
  • 注意的点

    1. 指针常量不能++:原因是地址在内存空间已经固定住了

      • 比如说数组
    2. 指针变量可以++:变量→保存的地址是可以改的

    c 复制代码
    #include <stdio.h>
    
    int main(){
    	int arr[3] = {1,2,3};
    	int *p = arr;
    	printf("sizeof is %d\n",sizeof(arr));//3*4=12
    	printf("sizeof is %d\n",sizeof(p));//操作系统8个字节表示一个地址(操作系统的不同会有变化)
    	printf("sizeof is %d\n",sizeof(int *));//只要是指针都是8个字节(操作系统的不同会有变化)								  	
    }

5.函数、指针、数组的结合

c 复制代码
#include <stdio.h>

void init(int *arr,int size){
	int i;
	for(i=0;i<size;i++){
		printf("请输入第%i个元素的数据:\n",i+1);
		scanf("%d",&arr[i]);
	}
}
void print(int *arr,int size){
	int i;
	for(i=0;i<size;i++){
		printf("%d ",arr[i]);

	}
}

int main(){
	int arry[5];
	int size = sizeof(arry)/sizeof(arry[0]);
	
	init(arry,size);
	//传递的实际参数
	//数组首地址:数组名,首个元素的地址
    
	print(&arry[0],size);
	return 0;
}
相关推荐
散峰而望8 小时前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github
是苏浙11 小时前
零基础入门C语言之C语言实现数据结构之单链表经典算法
c语言·开发语言·数据结构·算法
71-313 小时前
C语言练习题——判断水仙花数(0-100000)
c语言·笔记·学习
jzhwolp14 小时前
从基本链表到侵入式链表,体会内核设计思路
c语言·后端·设计模式
biter down15 小时前
c语言18:结构体位段联合体
c语言·开发语言
程序员buddha16 小时前
C语言操作符详解
java·c语言·算法
云知谷18 小时前
【经典书籍】《代码整洁之道》第六章“对象与数据结构”精华讲解
c语言·开发语言·c++·软件工程·团队开发
树在风中摇曳19 小时前
C语言 | 文件操作详解与实战示例
c语言·开发语言
雨落在了我的手上20 小时前
C语言入门(十六):指针(2)
c语言
say_fall20 小时前
C语言编程实战:每日刷题 - day 1
c语言·开发语言·学习