p=&a; //将变量地址赋值给指针 p=array; //将数组地址赋值给指针 p=&array[i]; //将数组元素赋值给指针 p1=p2; // 将指针地址赋值给指针
# include <stdio.h>//引用函数库 void main(){ int a = 10;//变量赋值,此时a变量的地址是&a int *p1 = &a;//将a变量的地址赋值给p1 int *p2 = p1;//将p1的值赋值给p2 printf("%x %x %x",&a,p1,p2); printf("\n%d %d %d",a,*p1,*p2); } f0889414 f0889414 f0889414 10 10 10*(p+1)和*p++意义不相同,前者没有改变p的地址,而后者改变了p的地址
#include <stdio.h> int main(int argc, char *argv[]) { //数组名是数组的首地址,是一个常量,它就是一个指针 int arr[10] = { 10 }; int* p = arr; //指向数组的指针,当操作指针的时候,间接操作 for (int i = 0; i < 10; i++) { printf("%d\n", p[i]); } system("pause"); return 0; }指针的自增和自减运算只有在数组中才有意义,因为数组中的元素类型是一定的,就是指针的+1前进的长度是一定的。 这也解释了为什么数组的类型是要求一致的 指针++就是按照一个指针类型的大小,前进一个类型的大小,如果是int就前进四个字节
# include <stdio.h>//引用函数库 void main(){ int a[5] = {1,2,3,4,5}; printf("%x\n",a);//打印数组的首地址 for (int i = 0;i<5;i++){//下标循环 //打印数组元素的值 printf("%d,%d\n",a[i],*(a+i));//a是一个地址值,a+1表示地址值前进一个该类型大小的字节 //打印数组元素的地址 printf("%x,%x\n",&a[i],a+i); } for (int *p =a;p<a+5;p++){//指针循环 printf("\n%d,%x", *p,p); } }指针降级操作,就是值的操作
*p=100; *(p+1) =200; p[5]=300; *(p+5)=300;