C++ struct constructor
?????下面看看一道關(guān)于C++中筆試題:
// FileName:test.cpp
1:??#include <stdio.h>
2:??struct test
3:??{
4:???????test(int n){
5:???????????printf("test(%d)\n",n);
6:???????}
7:???????test(){
8:???????????printf("test()\n");
9:?????????}
10:??????void Fun(){
11:??????????printf("Fun()\n");
12:??????}
13:??};
14:??int main()
15:??{
16:??????test a(1);
17:??????a.Fun();
18:??????test b();
19:??????b.Fun();
20:??????return 0;
21:???}
????從編譯角度來思考下:
摘自csdn:?http://blog.csdn.net/fuadam/archive/2008/08/04/2766616.aspx
????最近才知道struct和class的靜態(tài)構(gòu)造函數(shù)的觸發(fā)規(guī)則是不同的,不像class在第一次使用類的時(shí)候觸發(fā)靜態(tài)構(gòu)造函數(shù)。如果只訪問struct實(shí)例的字段是不會(huì)觸發(fā)靜態(tài)構(gòu)造函數(shù)調(diào)用的。通過測試發(fā)現(xiàn)當(dāng)訪問靜態(tài)字段,struct本身的函數(shù)(靜態(tài)和實(shí)例)和帶參數(shù)的構(gòu)造函數(shù)就會(huì)引起靜態(tài)構(gòu)造函數(shù)的執(zhí)行。而調(diào)用默認(rèn)構(gòu)造和未覆寫的基類虛函數(shù)是不會(huì)的。為什么呢?
????讓我們先來看看class和struct在調(diào)用構(gòu)造函數(shù)時(shí)的區(qū)別。class使用newobj指令而struct使用initobj指令來構(gòu)造對象。newobj在堆上申請一塊內(nèi)存并調(diào)用相應(yīng)的構(gòu)造函數(shù)進(jìn)行初始化,然后將對象地址返回給計(jì)算棧。initobj則是從本地變量表中載入已經(jīng)分配出來的struct實(shí)例然后初始化struct的各字段。這個(gè)初始化過程是CLR內(nèi)部執(zhí)行的,而不像class編譯器會(huì)給class添加一個(gè)默認(rèn)構(gòu)造函數(shù)(這就是為什么struct不能給字段添加默認(rèn)值的原因。但在類中如果給字段添加了默認(rèn)值編譯器就會(huì)自動(dòng)在構(gòu)造函數(shù)中添加字段賦值操作)。如果給struct中定義了一個(gè)有參數(shù)的構(gòu)造函數(shù),那么系統(tǒng)就不會(huì)使用initobj指令,而是直接用call指令調(diào)用帶參數(shù)的構(gòu)造函數(shù)。
????我們最常見最常用的調(diào)用函數(shù)的指令是call和callvirt。對于靜態(tài)函數(shù)使用call指令,對于class使用callvirt指令(不論class中的函數(shù)是不是虛的)。只有子類調(diào)用父類的函數(shù)的時(shí)候(避免遞歸調(diào)用)以及構(gòu)造函數(shù)中(由編譯器添加保證父類字段被初始化)使用call指令。而對于struct我們發(fā)現(xiàn)只要調(diào)用的函數(shù)是struct本身定義的都是使用call指令。call和callvirt指令的差別在于,call會(huì)把調(diào)用的函數(shù)當(dāng)作靜態(tài)函數(shù)看待,而不會(huì)關(guān)心調(diào)用當(dāng)前函數(shù)時(shí)實(shí)例指針(this)是否為空。這就是struct調(diào)用函數(shù)時(shí)為什么都是call因?yàn)閟truct實(shí)例是不可能被置為null的。實(shí)際上class在調(diào)用非虛函數(shù)時(shí)實(shí)際上也是使用call的只是多做了一步驗(yàn)證——this是否為空,讓我們來驗(yàn)證一下。
總結(jié)
以上是生活随笔為你收集整理的C++ struct constructor的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: taobao
- 下一篇: 抛硬币 直到连续出现两次字为止