C語言之初識指針
指針是什么?
那到底什么是指針呢,其實指針和之前學(xué)習(xí)的變量基本相似,不過變量里面放的是一些值,而指針里面放的是它所指的地方的地址。在聲明一個變量是,計算機就會為該變量預(yù)留一個位置,而指針?biāo)?的就是那個位置。
舉個例子:
int a = 10;
//設(shè)置一個變量a的值為10
int *p = &a;
//p這個指針里面就放的是a的地址
而&這個符號,就是取地址符,就像我們在使用scanf函數(shù)時? scanf("%d",&a); 這個a前面的&是一個意思,就是獲取到某個變量的地址。
而當(dāng)你創(chuàng)建了一個指針是,你就要給他賦地址,否則的話它就會像那種鼠標(biāo)一樣在硬盤上亂找,就會隨機找個地址,所以我們在創(chuàng)建了指針時,就一定要給他去給他賦一個位置。
指針的基礎(chǔ):
如何創(chuàng)建一個指針函數(shù)呢?
int p;
這是我們之前就知道的,創(chuàng)建一個整形變量p,而int *p;
?就是設(shè)置一個指針p;關(guān)鍵就是在于中間的 *。所以我們在創(chuàng)建指針變量時,一定不要忘記 *;
指針的賦值:
可以在創(chuàng)建指針的時候就賦值像這樣:int *p = &a;
? 也可以在創(chuàng)建了之后單獨賦值像這樣: int *p;? ?p = &a;
? ?兩種方法都一樣,沒有太大的區(qū)別,只不過一個一行代碼,一個兩行代碼,如果我們之前已經(jīng)創(chuàng)建了變量,那我們還是在創(chuàng)建指針的時候就直接給他賦值,以免后面忘了,對自己后續(xù)的程序發(fā)生影響。
那指針到底能干什么呢?
#include <stdio.h> int main() { int a = 10; int *p = &a; printf("a的地址為%p",&a);//這是直接輸出a的地址 printf("a的地址為%p",p);//只是輸出p的指針?biāo)傅牡刂? printf("a的值為%d",*p);//輸出p的指針?biāo)傅牡刂分凶兞康闹? return 0; }
通過這3個輸出函數(shù)我們可以知道,前兩個輸出的都是a的地址,而第三個輸出的則是a變量里的值。
所以我們可以理解為 *p
就是 a
這個變量的值,這就是最通俗易懂的理解了。
并且在輸出 p
時也就是輸出 a
的地址時,也是有不同的輸出方式的,最基礎(chǔ)的就是
- %lu 是十進(jìn)制的方式輸出;
- %p是以十六進(jìn)制的方式輸出;
之前說到 *p 可以看作是它所指的 a 變量的值,所以它也是可以再重新被賦值的,當(dāng)然它的賦值不是給指針函數(shù)賦值,看似是在給指針賦值,其實改變的還是它所指的函數(shù)的值;
像這樣
int a,*p; a = 10; p = &a; *p = 20; printf("a = %d",*p);
這個函數(shù)所輸出的值就會為 20 ;因為指針是之間在你的地址上給你改變,所以說指針的改變相比較之前的函數(shù)就會方便很多,比如我們在學(xué)習(xí)函數(shù)的時候,會將值從主函數(shù)傳到其他的函數(shù)中去做計算,但是傳回來時就很麻煩,因為它一次只能傳回來一個值,但是指針就不一樣了,它不需要將值傳回來,直接時實時將它所指的值進(jìn)行改變;
像接下來這個例子,我們之前也都用函數(shù)的方式寫過;
#include <stdio.h> void swap(int* p, int* q) { int temp; temp = *p; *p = *q; *q = temp; } int main() { int a = 10, b = 20; swap(&a, &b); printf("a=%d b=%d",a,b); return 0; }
這個函數(shù)最后輸出的值為
可以看到,輸出的值已經(jīng)發(fā)生了交換,這就是指針的強大之處吧;
可以更簡單的來解決我們之前遇到的問題,所以說,學(xué)好指針是學(xué)好c語言的基礎(chǔ)!
到此這篇關(guān)于C語言之初識指針的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Qt利用QJson實現(xiàn)解析數(shù)組的示例詳解
這篇文章主要為大家詳細(xì)介紹了Qt如何利用QJson實現(xiàn)解析數(shù)組功能,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Qt有一定幫助,需要的小伙伴可以了解一下2022-10-10基于Matlab實現(xiàn)多目標(biāo)粘液霉菌算法的示例代碼
多目標(biāo)粘液霉菌算法(MOSMA),這是最近開發(fā)的粘液霉菌算法(SMA)的多目標(biāo)變體,用于處理工業(yè)中的多目標(biāo)優(yōu)化問題。本文將用Matlab實現(xiàn)這一算法,需要的可以參考一下2022-05-05C++?JSON庫?nlohmann::basic_json::accept的用法解析
nlohmann::basic_json::accept 是 Nlohmann JSON 庫中的一個方法,它用于檢查一個字符串是否可以解析為有效的 JSON,這篇文章主要介紹了C++?JSON庫nlohmann::basic_json::accept的用法,需要的朋友可以參考下2023-06-06C語言中關(guān)于動態(tài)內(nèi)存分配的詳解
動態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存。棧上分配的內(nèi)存是由系統(tǒng)分配和釋放的,空間有限,在復(fù)合語句或函數(shù)運行結(jié)束后就會被系統(tǒng)自動釋放而堆上分配的內(nèi)存則不會有這個問題。2021-09-09VS C++頭文件引用提示“未定義標(biāo)識符”的問題解決
本文主要介紹了VS C++頭文件引用提示“未定義標(biāo)識符”的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07