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;
}
相关推荐
总爱写点小BUG3 小时前
打印不同的三角形(C语言)
java·c语言·算法
xie_pin_an7 小时前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
再睡一夏就好7 小时前
深入解析Linux页表:从虚拟地址到物理内存的映射艺术
linux·运维·服务器·c语言·c++·页表·缺页异常
LinHenrY12278 小时前
初识C语言(编译和链接)
c语言·开发语言·蓝桥杯
l1t8 小时前
利用小米mimo为精确覆盖矩形问题C程序添加打乱函数求出更大的解
c语言·开发语言·javascript·人工智能·算法
松涛和鸣9 小时前
34、 Linux IPC进程间通信:无名管道(Pipe) 和有名管道(FIFO)
linux·服务器·c语言·网络·数据结构·数据库
秦苒&9 小时前
【C语言】详解数据类型和变量(一):数据类型介绍、 signed和unsigned、数据类型的取值范围、变量、强制类型转换
c语言·开发语言·c++·c#
LinHenrY12279 小时前
初识C语言(文件操作)
c语言·windows·microsoft
智者知已应修善业9 小时前
【删除有序数组中的重复项 II之O(N)算法】2024-1-31
c语言·c++·经验分享·笔记·算法
代码游侠10 小时前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法