终于到了精髓的地方了,这确实有点懵,总感觉这太麻烦了,而且写着也不爽,还是怀念py或者java,但也没办法,还是要继续学下去。
#include <stdio.h> int main(void) { int i = 0; printf("0x%x\n", &i); // 0x62fe4c return 0; }
&不能对没有地址的东西取地址
就是保存地址的变量 , *p
// p是一个指针,现在把i的地址交给了p int i; int* p = &i; // 下面两种形式一样,p是一个指针,而q是一个普通的int变量 int* p , q; int *p , q;
#include <stdio.h> void f(int *p); int main(void) { int i = 6; printf("&i=%p\n", &i); f(&i); return 0; } void f(int *p) { printf(" p=%p\n", p); } // 可以看到这里获取的地址是相同的 // &i=000000000062fe4c // p=000000000062fe4c
#include <stdio.h> // 声明两个函数 void f(int *p); void g(int k); int main(void) { int i = 6; printf("&i=%p\n", &i); f(&i); // 此时i的值已经发生了变化 g(i); return 0; } // 传入的是地址 void f(int *p) { printf(" p=%p\n", p); printf("*p=%d\n", *p); *p = 66; } // 传入的普通int void g(int k){ printf("k=%d\n", k); } // &i=000000000062fe4c // p=000000000062fe4c // *p=6 // k=66
交换两个变量的值
#include <stdio.h> void swap(int *pa , int *pb); int main() { int a = 5; int b = 10; swap(&a , &b); printf("a=%d , b=%d\n", a , b); return 0; } void swap(int *pa , int *pb){ int t = *pa; *pa = *pb; *pb = t; }
#include <stdio.h> void minmax(int a[] , int len , int *min , int *max); int main(void) { int a[] = {1,2,3,4,5,6,7,8,9,12,13,14,15,34,35,66,}; int min , max; minmax(a , sizeof(a)/sizeof(a[0]) , &min , &max); printf("min = %d , max = %d \n", min , max); return 0; } void minmax(int a[] , int len , int *min , int *max) { int i; *min = *max = a[0]; for (i = 0; i < len; i++) { if (a[i] > *max) { *max = a[i]; } if (a[i] < *min) { *min = a[i]; } } }
#include <stdio.h> // 如果成功就返回1,否则就是0 int divide(int a , int b , int *result); int main(void) { int a = 5; int b = 2; int c; if (divide(a,b,&c)) { printf("%d/%d = %d\n", a, b, c); } return 0; } int divide(int a , int b , int *result) { int ret = 1; if ( b== 0) { ret = 0; }else{ *result = a/b; } return ret; }
定义了指针变量,还没有指向任何变量,就开始使用了
下面的四种函数原型是等价的
int sum(int *ar , int n); int sum(int* , int); int sum(int ar[] , int n); int sum(int[] , int);
数组变量本身表达地址,所以
[]运算符可以对数组做,也可以对指针做
*运算符可以对指针做,也可以对数组做
数组变量是const的指针,所以不能被赋值
// q内写的地址不能被改变 int *const q = &i; *q = 26; // ok q++; // error
const int *p = &i; *p = 26; // error (*p是不能变的) i = 26; // ok p = &j; // ok
const int * p1 = &i; int const * p2 = &i; int *const p3 = &i;
判断那个被const的标志是const在的前面还是后面
前面两个p不能被修改,就像第二种情况
const int a[] = {1,2,3,4,5,6,};
int sum(const int a[] , int length);
1+1 = 2 ?那么指针加1等于什么呢
#include <stdio.h> int main(void) { char ac[] = {0,1,2,3,4,5,6,7,8,9,}; char *p = ac; printf("p =%p\n", p); printf("p + 1 =%p\n\n", p+1); // p =000000000062fe30 // p + 1 =000000000062fe31 // 相差了1 int ai[] = {0,1,2,3,4,5,6,7,8,9,}; int *q = ai; printf("q =%p\n", q); printf("q + 1 =%p\n\n", q+1); //q =000000000062fe00 //q + 1 =000000000062fe04 // 相差了4 return 0; }
我们不难发现,在char中,相差了1,在int中相差了4,这是怎么回事?
sizeof(char) = 1 , sizeof(int) = 4
对指针做一个加1的动作,意味着要把它移动到下一个单元去
int a[10]; int *p = a; *(p+1) --> a[1]
如果指针不是指向一片连续分配的空间,如数组,那么这运算没有意义
#include <stdio.h> int main(void) { char ac[] = {0,1,2,3,4,20,6,7,8,9,}; char *p1 = &ac[5]; char *p2 = &ac[4]; printf("p1 - p2 = %d\n" , p1 - p2); printf("*p1 - *p2 = %d\n" , *p1 - *p2); // p1 - p2 = 1 也就是 5 -4 // *p1 - *p2 = 16 也就是 20 - 4 int ai[] = {0,1,2,3,4,5,6,7,8,18,}; int *q1 = &ai[9]; int *q2 = &ai[2]; printf("q2 - q1 = %d\n", q2 - q1); printf("*q2 - *q1 = %d\n", *q2 - *q1); // q2 - q1 = -7 也就是 2 - 9 // *q2 - *q1 = -16 也就是 2 - 18 return 0; }
char ac[] = {0,1,2,3,4,20,6,7,8,9,-1}; char *p = &ac[0]; // 普通方法遍历数组 // int i ; // for (i = 0; i < sizeof(ac)/sizeof(ac[0]); i++) // { // printf("%d\n", ac[i]); // } // 普通指针遍历数组 // for (p = ac; *p != -1; p++) // { // printf("%d\n", *p); // } // printf("---------------\n"); // 使用*p++,快 while(*p != -1){ printf("%d\n", *p++); }
#include <stdio.h> #include <stdlib.h> int main(void) { int number; int *a; int i; printf("请输入数量:\n"); scanf("%d" , &number); // 动态内存分配用malloc,此时a就相当于数组 a = (int*)malloc(number*sizeof(int)); for (i = 0; i < number; i++) { scanf("%d" , &a[i]); } for (i = number - 1; i >=0; i--) { printf("%d\n", a[i]); } // 最后释放空间 free(a); return 0; }
#include <stdlib.h> void* malloc(size_t size);
(int*)malloc(n*sizeof(int));
#include <stdio.h> #include <stdlib.h> int main(void) { void *p; int cnt = 0; while((p = malloc(100 * 1024 *1024))){ cnt ++ ; } printf("分配了%d00mb的空间\n", cnt); return 0; } // 分配了27200mb的空间
如对本文有疑问, 点击进行留言回复!!
clion+vs编译器+Qt5中使用QPrinter和QprintDialog类
基于open62541在QT编写OPCUA特定的客户端程序(含有源码) + VS2015 C语言搭建OPCUA客户端环境
网友评论