C语言实用算法系列之二级指针用法简介
生活随笔
收集整理的這篇文章主要介紹了
C语言实用算法系列之二级指针用法简介
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、幾個知識點
- 內存四區:棧、全局(靜態),常量區,除此以外剩余的空間暫時不能隨意使用;除此以外剩余的空間只要通過malloc函數申請一下,就可以使用了;
- 申請一個堆上的單個int變量的方法:int* p = (int*)malloc(sizeof(int));
- 申請一個堆上的int數組的方法:int* p = (int*)malloc(sizeof(int)*5);
- 堆上的地址可以跨函數使用,在不需要使用時使用 free 函數釋放;
二、二級指針
問題引入
char* ss[4] = { "basic","fortran","C++" };//每個元素都是char*類型
對于這樣的指針數組,應該用什么樣的指針去遍歷呢?答案是:二級指針
char** p = ss; // 二級指針變量p,指向一個指針數組
示例1-在棧內和堆上分別定義指針數組
char* ss[] = { "abc","dd","aaa",NULL }; char* *p = (char**)malloc(sizeof(char*) * 4); int i = 0; while (i < 4) {p[i] = ss[i];++i; } free(p);示例2-二級指針遍歷指針數組
#include <stdio.h> void main() {char* p = "Test";char* ar[4] = { "basic","fortran","C++" }; // 一共4個元素,每個元素都是char*類型printf("sizeof(ar)=%d\n", sizeof(ar));char* *pp = ar;int i = 0;while (i < sizeof(ar) / sizeof(ar[0])){p = pp[i];printf("第%d個指針變量指向的內容是:%s\n", i, p); //pp[i]的類型是char*++i;}printf("p指向的地址是:0x%p內存空間上的內容是:%s\n", p, p); }運行結果
示例3
#include<stdio.h> void main() {int ar[10] = { 33,55 };int n = 10;int* p = &n; //一級指針變量指向了一個普通變量,為了遠程操控普通變量存儲的數據int* q = ar;*p = -1;//int* *pp = &p; //指針變量的指針是二級指針//pp = &q;//*pp = p;//*p或p[0]遠程操控一個一級指針變量,讓它指向到其他地址int* as[10] = { ar,&n,NULL }; // 每個元素都是一個一級指針變量int* *pp = as; // =&as[0]; // as[0]類型是int*類型int i = 0;while (i < sizeof(as) / sizeof(as[0])){printf("第%d條指針指向:0x%p\n", i, pp[i]); //pp[i]類型是int*類型++i;}printf("\n");int ar1[] = { 32,56,93,56,-1,0 }; //每個元素都是int類型int* p1 = &ar1[0]; // ar; // 一級指針變量p, 指向一個普通變量的一維數組while (*p1){printf("p[%d]=%d\n", p1 - ar1, *p1);//指針的減法: 相差字節/sizeof(int),邏輯上是幾個int++p1;} }總結
以上是生活随笔為你收集整理的C语言实用算法系列之二级指针用法简介的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 中断路由器怎么用如何设置路由器的中断设置
- 下一篇: C语言实用算法系列之行指针