C/C++ 类型内存占用详解
最近做一些面試題目碰到了很多次考察C/C++類型內(nèi)存占用的題目,主要考察隊C/C++的指針、類型等的熟悉程度。
本blog為了方面大家參考,總結(jié)了常見的類型內(nèi)存占用的情況,能力所限,若有問題,請指出!
1. 基本類型
C/C++的基本類型包括int/long等等,這些基本類型在內(nèi)存中的字節(jié)數(shù)一般是固定的(當然根據(jù)不同bit的系統(tǒng)有所調(diào)整),下表是基本類型的占用字節(jié)數(shù)。
PS: 1byte=8bit, byte通常寫成大寫B(tài), bit一般寫為小寫b
下表單位均為Byte
| 32bit | 1 | 2 | 4 | 4 | 8 | 4 | 8 | 4 |
| 64bit | 1 | 2 | 4 | 8 | 8 | 4 | 8 | 8 |
不信?我們以代碼說話:
#include <iostream>using namespace std;int main() {cout<<"sizeof(char)="<<sizeof(char)<<endl;cout<<"sizeof(short)="<<sizeof(short)<<endl;cout<<"sizeof(int)="<<sizeof(int)<<endl;cout<<"sizeof(unsigned int)="<<sizeof(unsigned int)<<endl;cout<<"sizeof(long)="<<sizeof(long)<<endl;cout<<"sizeof(long long)="<<sizeof(long long)<<endl;cout<<"sizeof(float)="<<sizeof(float)<<endl;cout<<"sizeof(double)="<<sizeof(double)<<endl;//Poiter typecout<<endl;cout<<"sizeof(void *)="<<sizeof(void *)<<endl;cout<<"sizeof(char *)="<<sizeof(char *)<<endl;cout<<"sizeof(int *)="<<sizeof(int *)<<endl;cout<<"sizeof(float *)="<<sizeof(float *)<<endl;cout<<"sizeof(double *)="<<sizeof(double *)<<endl;return 0; }結(jié)果如下(我的系統(tǒng)是64bit的):
可以看到,任意類型的指針的位數(shù)皆為8byte,即與系統(tǒng)位數(shù)保持一致,因此,判斷系統(tǒng)的位數(shù)我可以直接用sizeof(void *).
2. 復雜類型
編程時,有時我們會碰到如下情況:
- int *p[n]
- int (*p)[n]
以上兩者到底有什么區(qū)別呢?
下面我們先看一下代碼:
①. P1 : 數(shù)組
- p1為一維數(shù)組的數(shù)組名,包含五個int型元素
- p1雖然數(shù)值上與&p1[0]相等,但是兩者不是一個東西(&p1[0]是第一個元素的地址)
- p1+1 其實就是 &p1[1]
②. P2 : 數(shù)組指針 (int *p2[n])
[]的優(yōu)先級高于*,因此先p2[3],即p2先是一個數(shù)組,然后與*結(jié)合,*p2[n]即成了數(shù)組指針(數(shù)組內(nèi)部存放的內(nèi)容皆為指針)
③. P3 : 指針數(shù)組(int(*p3)[n])
int (p3)[n],由于()優(yōu)先級大于[],所以先(p3),后為數(shù)組,即p3所指向的對象是有n個int型元素的數(shù)組,即p3是指向一維數(shù)組的指針;p3的值即為該一維數(shù)組的地址。
以上,相當于二維數(shù)組。
結(jié)果:
根據(jù)以上講解,你是否已經(jīng)得出答案?
3. 函數(shù)相關
有的時候,我們還會遇到以下的情況:
- int *p() : 返回指針的函數(shù)
- int (*p)() : 指向函數(shù)的指針
①. int *p() 指針函數(shù)
實際上,它就是一個函數(shù),只不過返回類型為指針而已,和普通函數(shù)沒什么區(qū)別的。
#include <iostream> #include <cstring>using namespace std;char *array() {auto ptr = new char(10);ptr="hello";return ptr; }int main() {char *pt = array();cout<<pt<<endl;return 0; }②. int (*p)(): 函數(shù)指針
指向函數(shù)的指針變量,其本質(zhì)是一個指針。
int (*fptr)(int x); /*聲明一個函數(shù)指針*/
fptr = func; /*將func函數(shù)的首地址賦給該指針*/
每個函數(shù)都有一個入口地址,將該入口地址賦值給一個指針,通過該指針即可以調(diào)用這個函數(shù)。
#include <stdio.h>void (*ptr)(char *str);void prt1(char *str) {printf("ptr1 string=%s\n", str);return ; }void prt2(char *str) {printf("ptr2 string=%s\n", str);return ; }int main() {ptr = prt1;(*ptr)("hello");ptr = prt2;(*ptr)("world");return 0; }特別類似于C++的多態(tài)是不是?
③. 函數(shù)的形式參數(shù)
有時候,我們函數(shù)的形參需要為指針,這個時候,其實我們可以有多重寫法
- void *func(char *str)
- void *func(char str[])
- void *func(char str[n])
以上三種寫法一個意思,即使n小于實參的字節(jié)數(shù)也無妨,此處的n只是一個提示作用而已。
轉(zhuǎn)載于:https://www.cnblogs.com/Jimmy1988/p/8338131.html
總結(jié)
以上是生活随笔為你收集整理的C/C++ 类型内存占用详解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Git基本操作用法
- 下一篇: [C/C++标准库]_[0基础]_[怎样