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;
}
相关推荐
wearegogog1237 分钟前
C语言中的输入输出函数:构建程序交互的基石
c语言·开发语言·交互
艾莉丝努力练剑12 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
Cx330❀14 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
..过云雨15 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
谱写秋天16 小时前
在STM32F103上进行FreeRTOS移植和配置(STM32CubeIDE)
c语言·stm32·单片机·freertos
我不是板神16 小时前
程序设计|C语言教学——C语言基础2:计算与控制语句
c语言
基于python的毕设16 小时前
C语言栈的实现
linux·c语言·ubuntu
promising-w21 小时前
【嵌入式C语言】六
c语言·开发语言
ankleless21 小时前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
草莓熊Lotso1 天前
《吃透 C++ 类和对象(中):const 成员函数与取地址运算符重载解析》
c语言·开发语言·c++·笔记·其他