共享庫有類似c++類構造和析構函式的函式,當動態庫載入和解除安裝的時候,函式會被分別執行。乙個函式加上 constructor的 attribute就成了建構函式;加上 destructor就成了析構函式。
下面舉例說明。
$ cat 1.c
#include extern void goo(void);
__attribute__((constructor)) void init1(void)
__attribute__((destructor)) void fini1(void)
void foo(void)
$ cat 2.c
#include __attribute__((constructor)) void init2(void)
__attribute__((destructor)) void fini2(void)
void goo(void)
$ cat main.c
#include extern void foo();
int main(void)
gcc 1.c -fpic -shared -g -o lib1.so
gcc 2.c -fpic -shared -g -o lib2.so
gcc main.c -g -o main -l. -l1 -l2
執行結果:
$ ./main
library lib2.so loaded!
library lib1.so loaded!
foogoo
library lib1.so unloaded!
library lib2.so unloaded!
建構函式和析構函式
建構函式沒有返回值,不能被顯示的呼叫。它是在定義物件時由系統自動執行的,而且只執行一次。如果沒有定義建構函式,系統會自動生成乙個建構函式,只是這個建構函式的函式體是空,沒有引數,也不執行任何初始化的操作。帶引數的建構函式 有一種簡練,方便的寫法 建構函式的引數初始化表 box int h,int w...
析構函式和建構函式
每個物件生成的時候都要完成物件的初始化,如設定屬性的初始值。c 中規定每個類都有乙個初始值,如果沒有,系統會產生乙個預設的建構函式。這個建構函式沒有任何引數,不做任何額外的工作。但往往我們會自己寫乙個建構函式,用來進行特殊的初始化工作。這樣的話,編譯器就不會再為其生成預設的建構函式。class 類名...
建構函式和析構函式
stock hot 因為資料部分的訪問狀態是私有的,程式不能訪問資料成員。建立stock的建構函式,由於需要為stock提供3個值,因此應為建構函式提供3個引數值,程式設計師可能指向設定company成員,而其他的設定為0 使用預設引數完成 宣告如下 stock const char co,int ...