C语言初阶指针指针类型指针运算指针数组二级指针

1.指针是什么

 **指针也就是内存地址,指针变量是用来存放内存地址的变量,不同类型的指针变量所占用的存储单元长度是相同的,而存放数据的变量因数据的类型不同,所占用的存储空间长度也不同。有了指针以后,不仅可以对数据本身,也可以对存储数据的变量地址进行操作。**
 *指针是个变量,存放内存单元的地址*
#include<stdio.h>
int main()
{
int a =10;  //开辟内存
int *p = &a;  //对变量a取地址,将a的地址放在p变量中,p就是一个指针变量
return 0;}

指针是用来存放地址的,地址是唯一标示一块地址空间的。
指针的大小在32位平台是4个字节,在64位平台是8个字节。

2. 指针和指针类型

2.1 指针变量相应的类型

char  *pc = NULL;  //char*类型存放char类型变量的地址
int   *pi = NULL;  //int*类型存放int类型变量的地址
short *ps = NULL;  //short*类型存放short类型变量的地址
long  *pl = NULL;  //long*类型存放long类型变量的地址
float *pf = NULL;  //float*类型存放float类型变量的地址
double *pd = NULL; //double*类型存放double类型变量的地址

2.2指针 ± 整数

#include<stdio.h>
int main()
{
int n=10;
char *pc=(char*)&n;
int pi=&n;

printf("%p\n",&n);
printf("%p\n",pc);
printf("%p\n",pc+1);
printf("%p\n",pi);
printf("%p\n",pi+1);

return 0;
}

在这里插入图片描述
指针的类型决定了指针向前(后)一步要走多大;所指的是类型的大小

2.3 指针的解引用

若 d=100,当我们对d间接使用访问操作符时,他表示访问内存位置100并查看哪里的值。
指针的类型决定了,对指针解引用的时候有多大的权限能操作几个字节比如: char 的指针解引用就只能访问一个字节,而 int 的指针的解引用就能访问四个字节。**

3.野指针

概念:野指针就是指针指向的位置是不可知的( 随机的,不正确的,没有明确限制的)

  1. 指针未初始化(当指针指向的范围超出数组arr的范围时,p就是野指针)
  2. 指针越界访问
  3. 指针指向的空间释放

4.指针运算

4.1 指针 ± 整数

#define N_VALUES 5

float values[N_VALUES];
float *vp;
for (vp = &values[0]; vp < values[]N_VALUES;)
{
	*vp++ = 0;;
}

在同一数组,指针相减结果是两指针经历元素个数,但是经历元素个数与指针类型有关
指针±整数 标准定义这种形式只能用于指向数组中某个元素的指针
并且这类表达式的结果类型也是指针。这种形式也适用于使用malloc函数动态分配获得的内存。
运算结果会根据合适的大小来改变(是指指针所指向的类型)

4.2 指针- 指针

int mtstrlen(char *s)
{
   char*p=s;
   while(*p != '\0')
   p++;
   return p-s;

只有当两个指针都指向同一个数组中的元素时,才允许从一个指针减去另一个指针
如果两个指针所指向的不是同一个数组中的元素,那么它们之间相减的结果是未定义的

4.3 指针的关系运算

但是根据标准规定:允许指向数组元素的指针与数组最指向一个元素后面内存位置的指针进行比较,不允许指向数组元素的指针与数组最指向第一个元素前面内存位置的指针进行比较

5.指针和数组

5.1 数组名

数组名表示数组首元素的地址

#include<stdio.h>
int main()
{  
int arr[10]={1,2,3,4,5,6,7,8,9,10}
printf("%p",arr);
printf("%p",&arr[0]);
return 0;

}

在这里插入图片描述
可以通过指针访问数组

int main()
{
	int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
	int *p = arr;
	int sz = sizeof(arr) / sizeof(arr[0]);
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d", *(p + i));
	}
	
	return 0;
	
}

在这里插入图片描述

6.二级指针

a的地址存放在pa中,pa的地址存放在ppa中,则pa是一级指针,ppa是二级指针。

  • *ppa通过对ppa中的地址进行解引用,这样找到的是pa,*ppa其实就是访问pa
int b = 20; 
*ppa = &b;//等价于 pa = &b; *ppa其实就是pa
  • ppa先通过ppa找到pa进行解引用操作:*pa就是a
**ppa = 30;
//等价于*pa = 30;
//等价于a = 30;

7.指针数组

概念:指针数组是数组,是存放指针的数组

int arr1[5];
char  arr22[6];

在这里插入图片描述

int *arr3[5];

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值