如下图所示,整型指针xptr指向变量x的地址。
int *xptr;
int x=10;
xptr = &x;
源码:
#include <stdio.h>
int main()
{
int *xptr = NULL;
int x = 10;
xptr = &x;
printf("x = %d, *xptr = %d\n", x, *xptr);
printf("&x = %p, xptr = %p\n", &x, xptr);
return 0;
}
运行结果:
二、二级指针
实现方法一
如下图所示,先为二级整型指针ptr分配空间,然后赋值。
int **ptr=NULL;
int num=4, size=4, i,j;
ptr = (int **)malloc(num*sizeof(int*));
for(i=0; i<num; ++i)
{
*(ptr+i) = (int *)malloc(size*sizeof(int));
*(*(ptr+i) +j)=(i+1)*j;
}
源码:
#include <stdio.h>
#include <stdlib.h>
int main()
{
int **ptr = NULL;
int num=4, size=4, i, j;
ptr = (int **)malloc(num * sizeof(int *));
for(i=0; i<num; ++i)
{
*(ptr+i) = (int *)malloc(size * sizeof(int));
for(j=0; j<size; ++j)
*(*(ptr+i)+j) = (i+1)*j;
}
for(i=0; i<num; ++i)
{
for(j=0; j<size; ++j)
{
printf("(%d, %d) -> %d\t", i, j, *(*(ptr+i)+j));
}
printf("\n");
}
return 0;
}
运行结果:
实现方法二
如下图所示,先为二级整型指针ptr分配空间,然后赋值。
与实现方法一的不同之处,在于使用数组形式就行相关操作。
int **ptr=NULL;
int num=4, size=4, i;
ptr = (int **)malloc(num*sizeof(int*));
for(i=0; i<num; ++i)
{
ptr[i]= (int *)malloc(size*sizeof(int));
ptr[i][j]=(i+1)*j;
}
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上物联网嵌入式知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新