詳解C語言中的指針與數(shù)組的定義與使用
指針的特點(diǎn)
- 他就是內(nèi)存中的一個(gè)地址
- 指針本身運(yùn)算
- 指針?biāo)赶虻膬?nèi)容是可以操作的
操作系統(tǒng)是如何管理內(nèi)存的
棧空間
4M~8m的大小
當(dāng)進(jìn)入函數(shù)的時(shí)候會(huì)進(jìn)行壓棧數(shù)據(jù)
堆空間
- 4g的大小 1g是操作系統(tǒng)
- 全局變量
內(nèi)存映射
- 可以對內(nèi)存的內(nèi)容修改修改硬盤的內(nèi)容
- 一般在數(shù)據(jù)庫中經(jīng)常使用
內(nèi)存的分配與釋放
c語言分配內(nèi)存的方法
// malloc(需要分配的大小); 這里的分配的大小需要對齊的2的指數(shù) void *mem = malloc(size);
釋放內(nèi)存
// 一般分配的內(nèi)容都是在堆空間中的 // 如果使用完不去釋放會(huì)照成內(nèi)存泄漏和野指針的出現(xiàn) free(men);
什么是內(nèi)存泄漏:
- 不斷的向系統(tǒng)
- 申請內(nèi)存申請的內(nèi)存不用,也不去釋放
- 絕對不允許內(nèi)存泄漏
什么是野指針
- 這個(gè)指針已經(jīng)被釋放掉了
- 別人又創(chuàng)建了這個(gè)指針
- 過去的自己又用到了這個(gè)指針
函數(shù)指針
返回值類型(*指針變量名)(參數(shù)列表);
int func(int x); // 聲明一個(gè)函數(shù) int (*f)(int x); // 聲明一個(gè)函數(shù)指針 f = func; // 將func函數(shù)的首地址賦值給指針f #include <stdio.h> int sum (int a, int b) { return (a+b); } int main(int argc, int *argv[]) { // 定義一個(gè)函數(shù)指針 int (*f) (int, int); // f 指向 sum函數(shù) f = sum; // 執(zhí)行f函數(shù),相當(dāng)于執(zhí)行sum函數(shù) int f_sum = f(2,3); printf("f_sum: %d\n", f_sum); return 0; }
指針就是內(nèi)存地址: void*、 char*
數(shù)組就是:char c[2]、 int arr[10],指連續(xù)相同類型的空間
#include <stdio.h> #include <stdlib.h> int main(int argc, char *argv[]) { // 定義兩個(gè)int類型的指針 int *a, *b; // 通過malloc在堆里面開辟了空間 a = (int*)malloc(sizeof(int)); b = (int*)malloc(sizeof(int)); *a = 1; *b = 2; // 指針a的地址是&a, a是指向空間的地址,*a是指向空間的值 printf("addr of a:%p, %p, %d\n", &a, a, *a); printf("addr of b:%p, %p, %d\n", &b, b, *b); return 0; }
#include<stdio.h> #include<stdlib.h> int main(int argc, char *argv[]) { // 創(chuàng)建一個(gè)數(shù)組c里面有3個(gè)數(shù)據(jù),int類型的數(shù)組一個(gè)數(shù)組占4個(gè)字節(jié),地址相關(guān)的空間相差是1個(gè)字節(jié) int c[3] = {1,2,3}; printf("c的地址:%p\t%p\tc[0]:%p\tc[1]:%p\tc[2]:%p\t\n",c, &c, &c[0], &c[1], &c[2]); printf("%d, %d, %d\n", c[0], c[1], c[2]); }
總結(jié)
以上所述是小編給大家介紹的C語言中的指針與數(shù)組的定義與使用,希望對大家有所幫助!
相關(guān)文章
C語言實(shí)現(xiàn)手寫Map(全功能)的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用C語言實(shí)現(xiàn)手寫Map(全功能),文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C語言有一定幫助,需要的可以參考一下2022-08-08帶頭結(jié)點(diǎn)單鏈表與不帶頭結(jié)點(diǎn)單鏈表的區(qū)別
這篇文章主要介紹了帶頭結(jié)點(diǎn)單鏈表與不帶頭結(jié)點(diǎn)單鏈表的區(qū)別,需要的朋友可以參考下2023-07-07