詳談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>)
斷定表達式一定為真,如果為假程序崩潰,并報告錯誤位置。
release面向用戶版本:assert后面需要進行條件判斷。
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語言程序設(shè)計譚浩強第五版課后答案(第三章習題答案)
這篇文章主要介紹了C語言程序設(shè)計譚浩強第五版課后答案(第三章習題答案),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2021-04-04wince程序防止創(chuàng)建多個實例實現(xiàn)互斥作用
什么時候用的互斥?當你的程序只允許同時打開一個的時候,就可以通過互斥來實現(xiàn),下面說的互斥,主要是針對防止程序創(chuàng)建多個實例這種情況來實現(xiàn)的2014-02-02C++利用inotify+epoll實現(xiàn)異步文件監(jiān)控的方法
這篇文章講給大家詳細介紹一下C++利用inotify+epoll實現(xiàn)異步文件監(jiān)控的方法,inotify是一種異步文件監(jiān)控機制,文章通過代碼示例介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下2023-08-08