詳談C語言指針
#include<stdio.h>
int main()
{
int a = 10;
int b = 20;
int* p = &a;//*定義指針變量
*p = 100;//*間接訪問,解引用,a = 100
p = &b;//p保存b的地址
*p = 200;//b = 200
int** pp = &p;//對指針取地址,二級指針
*pp = &a;//解一次引用,一級指針p保存的值,即a的地址
**pp = 1000;//解二次引用,a = 1000
*pp = &b;//解一次引用,一級指針p保存的值,即b的地址
**pp = 2000; // 解二次引用,b = 2000
int*** ppp = &pp;//三級指針
**ppp = &a;//解二次引用,一級指針p保存的值,即a的地址
***ppp = 5000;//解三次引用,a = 5000
**ppp = &b;//解二次引用,一級指針p保存的值,即b的地址
***ppp = 6000;//解三次引用,b = 6000
printf("%d", a);
return 0;
}
#include<stdio.h>
int main()
{
int a = 0;
int b = 0;
int c = 0;
int* p1 = &a;
int* p2 = &b;
int* p3 = &c;
*p1 = 100;
*p2 = 200;
*p3 = 300;
*p3 = *p1 + *p2;
*p3 = *p1 / *p2;
*p3 += 1;
printf("%d %d %d\n", *p1, *p2, *p3);//100,200,1
return 0;
}
- 指針的大小只與平臺有關(guān)
32位sizeof( * )=4
64位sizeof( * )=8(字節(jié))
#include<stdio.h>
void Swap_1(int* p1, int* p2)//p1,p2分別保存a和b的地址
{
int *tmp = p1;//定義指針變量tmp,把p1的值(即a的地址)賦給tmp
p1 = p2;//把p2的值(即b的地址)賦給p1
p2 = tmp;//把tmp的值(即a的地址)賦給p2
} //只交換地址,并沒有更改值
#if 0
void Swap_2(int* p1, int* p2)
{
int* tmp;//懸掛指針,野指針
*tmp= *p1;
*p1 = *p2;
*p2 = *tmp;
}
#endif
void Swap(int* p1, int* p2)//p1,p2分別保存a和b的地址
{
int tmp;
tmp = *p1;//把p1解引用的值(即a的值)賦給tmp
*p1 = *p2;//把p2解引用的值(即b的值),賦給p1解引用的值(即a的值)
*p2 = tmp;//把tmp的值(即a的值)賦給把p2解引用的值(即b的值)
} //完成交換。
int main()
{
int a = 10;
int b = 20;
Swap(&a, &b);//主函數(shù)的改變要想影響到自定義函數(shù):(1)必須傳遞指針,(2)必須解引用
printf("%d,%d\n", a, b);
return 0;
}
#include<stdio.h>
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
for (int* p = arr; p <= &arr[9]; p++)
//for (int* p = arr; p < &arr[10]; p++)
//for (int* p = &arr[9]; p >= &arr[0]; p--)
//for (int* p = &arr[9]; p > &arr[-1]; p--)
{
printf("%d ", *p);
}
char a = 'x';
char* p = &a;
//int* np = &p;//指針類型不同
return 0;
}
#include<stdio.h>
void Fun(int* p)
{
//p = NULL;//空指針,p的值為0
int* p1= p;//p1保存p的值
int* p2 = NULL;//p2保存NULL
int tmp;
tmp = *p1;//把p1解引用的值(即p的值)賦給tmp
*p1 = *p2;//把p2解引用的值(即NULL),賦給p1解引用的值(即p的值)
*p2 = tmp;//把tmp的值賦給把p2解引用的值
}
int main()
{
int a = 10;
int* p = &a;
Fun(p);
//p = NULL;
printf("%d\n", *p);
return 0;
}
總結(jié)
assert()(需要頭文件#include<assert.h>)
斷定表達(dá)式一定為真,如果為假程序崩潰,并報告錯誤位置。
release面向用戶版本:assert后面需要進(jìn)行條件判斷。
void* 通用指針,泛型指針
void*無數(shù)據(jù)類型,不參與運算,不能++和解引用
| 賦值 | 通用指針 = 特定指針 | 特定指針 = 通用指針 |
|---|---|---|
| C++ | char* p; void* p1=p; |
不可以 (char* p; void* p1=p; int* p2=p1 (p2=p)數(shù)據(jù)類型不同 ) |
| C | char* p; void* p1=p; |
void* p; char* p2=p; |
C++:NULL——0
C:NULL——((void*)0)
先有C后有C++,C++不支持void*賦值,故定義為0
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C語言編程中對目錄進(jìn)行基本的打開關(guān)閉和讀取操作詳解
這篇文章主要介紹了C語言編程中對目錄進(jìn)行基本的打開關(guān)閉和讀取操作,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-09-09
C++中拷貝構(gòu)造函數(shù)的總結(jié)詳解
深拷貝和淺拷貝可以簡單理解為:如果一個類擁有資源,當(dāng)這個類的對象發(fā)生復(fù)制過程的時候,資源重新分配,這個過程就是深拷貝,反之,沒有重新分配資源,就是淺拷貝2013-09-09
C++ 風(fēng)靡一時的連連看游戲的實現(xiàn)流程詳解
游戲“連連看”是源自臺灣的桌面小游戲,自從流入大陸以來風(fēng)靡一時,也吸引眾多程序員開發(fā)出多種版本的“連連看”。這其中,顧芳編寫的“阿達(dá)連連看”以其精良的制作廣受好評,這也成為顧方“阿達(dá)系列軟件”的核心產(chǎn)品。并于2004年,取得國家版權(quán)局的計算機軟件登記證書2021-11-11
C語言中feof函數(shù)和ferror函數(shù)示例詳解
在C語言中feof函數(shù)用于檢查文件流的結(jié)束標(biāo)志,判斷文件在讀取時是否已經(jīng)到達(dá)了文件的末尾,這篇文章主要給大家介紹了關(guān)于C語言中feof函數(shù)和ferror函數(shù)的相關(guān)資料,需要的朋友可以參考下2024-09-09

