C++ 学习杂谈:sizeof和sizeof(string)的问题
最近遇到一個令我困惑的問題,就是 sizeof(string)的值,之前在vs2010上測得是固定28,最近在用CLion,上面測得是4,出現(xiàn)了不一樣的結(jié)果,我又在vs2013上試了一下,結(jié)果又不一樣,在vs2013上是32.
查閱了相關(guān)資料得出結(jié)論:string的實現(xiàn)在各庫中可能有所不同,但是在同一庫中相同一點(diǎn)是,無論你的string里放多長的字符串,它的sizeof()都是固定的,字符串所占的空間是從堆中動態(tài)分配的,與sizeof()無關(guān)。 sizeof(string)=4可能是最典型的實現(xiàn)之一,不過也有sizeof()為28、32字節(jié)的庫實現(xiàn)。 但是MS2015測試后sizeof(string)=40.還是跟編譯器有關(guān).
也就是說sizeof(string)和字符串的長度是無關(guān)的,在一個系統(tǒng)中所有的sizeof(string)是一個固定值,這個和編譯器相關(guān),string字符串是存儲在堆上,這個屬于動態(tài)分配的空間,對于別的整形浮點(diǎn)型數(shù)據(jù)類型則沒有這個問題。
sizeof到底是什么?
這個我們要看一下,sizeof在msdn上的定義:
The sizeof keyword gives the amount of storage, in bytes, associated with a variable or a type (including aggregate types). This keyword returns a value of type size_t.
看到return這個字眼,是不是想到了函數(shù)?錯了,sizeof不是一個函數(shù),sizeof可以不加括號,所以sizeof不是函數(shù)。網(wǎng)上有人說sizeof是一元操作符,但是我并不這么認(rèn)為,因為sizeof更像一個特殊的宏,它是在編譯階段求值的。舉個例子:
?
在編譯階段已經(jīng)被翻譯為:
cout<<4<<endl;cout<<1<<endl;這里有個陷阱,看下面的程序:
int a = 0;cout<<sizeof(a=3)<<endl;cout<<a<<endl;輸出為什么是4,0, 而不是期望中的4,3???就在于sizeof在編譯階段處理的特性。由于sizeof不能被編譯成機(jī)器碼,所以sizeof作用范圍內(nèi),也就是()里面的內(nèi)容也不能被編譯,而是被替換成類型。=操作符返回左操作數(shù)的類型,所以a=3相當(dāng)于int,而代碼也被替換為:
int a = 0;cout<<4<<endl;cout<<a<<endl;所以,sizeof是不可能支持鏈?zhǔn)奖磉_(dá)式的,這也是和一元操作符不一樣的地方。
結(jié)論:不要把sizeof當(dāng)成函數(shù),也不要看作一元操作符,把他當(dāng)成一個特殊的編譯預(yù)處理。
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
總結(jié)
以上是生活随笔為你收集整理的C++ 学习杂谈:sizeof和sizeof(string)的问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: unity3d软阴影和硬阴影的原理_Un
- 下一篇: 用函数实现simulink_VCU/BM