目錄
由於c++直譯器比c語言直譯器占用的儲存空間要大500k左右。為了節省有限的儲存空間,降低成本,同時也為了提高效率,將用c++語言寫的源程式用c語言改寫是很有必要的。
c++與c區別最大的就是c++中的類的概念和特性,將c++改為c的問題,就轉換成如何將類化去的問題。
方法有兩種:
第一種是將c++中的物件導向特徵去掉,先全部理解源**的邏輯,然後改寫;
第二種是在c中保留物件導向的部分特徵,用結構體實現類的功能。
第一種方法,對於類的數目很少的情況還可以,如果類的數目比較多,全部理解源**,然後重寫就很耗時間,而且很容易出錯,更甚者,如果遇到大的專案想全部理解源**幾乎是不可能的。
hpijs程式中類有140多個,這個時候就需程式設計客棧要採用第二個方法了,你可以乙個類乙個類的改沒有什麼太高的難度,如果不是筆誤的話,幾乎不會出錯,而且根本不需要理解程式邏輯,也許改完後你對程式所要實現的功能還一無所知。倒不是說一無所知對大家有好處,只是想說這種方法的與程式邏輯本身的無關性。
下面對c++的一些特性,以及如何在c裡實現或者替代,作一些初步的**:
函式ixx為類xx的建構函式的實現;
原類的成員函式改為字首為結構體名+『_'的函式;
函式指標u為原類的析構函式的宣告;
u+結構體名稱為原類的析構函式的實現;
fun-_+結構體名為對該結構體成員函式指標進行指向;
以後遇到上述情況將不再說明。
由於struct沒有對成員的訪問許可權進行控制,必須加入額外的機制進行訪問控制,這樣一來就使得程式複雜化了,所以只能放棄訪問許可權的控制。
1)對於類的資料成員可以直接轉為c中結構體的資料成員。
2)函式則需轉化為對應的函式指標,因為struct裡不允許出現函式的宣告和定義。而函式前如果有virture,inline等修飾符也要去掉,如函式void funca(int a);改為void (*funca)(struct b *p,int a);大家可以看到函式指標的原型裡加了乙個指標struct b的指標,這是因為要在函式內部對類的成員進行操作,要靠該指標指定結構體的成員。在類的成員函式裡,實際上在引數列裡也隱含有乙個指向自身的this指標。
3)對於靜態成員則要定義成全域性變數或全域性函式,因為結構體中不能有靜態成員。
類在例項化的時候會呼叫類的預設建構函式,在struct裡,要定義乙個同名函式指標指向乙個具有建構函式功能的初始化函式,與建構函式不同的是,要在初始化函式裡加入進行函式指標初始化的語句.使用的時候在建立結構體變數的時候要用malloc而不是new,並且這個時候要手工呼叫初始化函式。
如下例所示:
class a
;a::a()
void a::func(int a)
typedef struct classa a;
struct classa
;void fun_a(a *p)
void ia(a *p) //建構函式,命名規則在類名前加i
void classa_func(a *p,int a)
在使用的地方採用如下方式:
a *s=(a*)malloc(sizeof(a));
s->a=ia;
s->a(s);
類的析構函式所作的工作是釋放所佔的資源。
在c中,無論是哪個struct都用函式指標u替代析構函式。之所以所有的struct都用指標u是基於如下情況:
如果將子類指標賦給基類指標,基類指標在釋放的時候不必考慮呼叫哪個函式名的析構函式,只需呼叫成員函式u即可。eteeknsvxj成員函式u需要像一般成員函式一樣在fun_類名()函式中指定。
類的析構函式是由系統呼叫的,在c中則要顯式呼叫。至於何時呼叫,要準確判斷。
類的拷貝建構函式主要用途是加快以下情況下類的構建速度:
1. 作為引數傳給函式。(additem(itema))
2. 作為函式返回值。
3. 例項化類時作引數。
這三種情況下都是由系統直接呼叫類的拷貝建構函式而不是建構函式。
注意:c=d;不會呼叫拷貝建構函式,這種情況下使用的是過載『='運算子的方法。(詳見運算子過載);
由於c中定義struct變數的時候,使用的全部是指標,不會用到拷貝建構函式,所以暫不考慮。對於原來函式引數或者返回值需要類變數的,要全部轉化為類指標的方式。例項化類時作引數的情況,可以通過另外定義乙個帶引數的建構函式來解決。
五.類的內聯函式和虛函式
內聯函式和虛函式的修飾符inline 、virture 要全部去掉。內聯函式體則要去掉,將內聯函式在外面定義成乙個函式。
如:class b
;private:
int a;
int b;
…}改為:
typedef classb b;
struct classb
void cla程式設計客棧ssb_funb(b *p)
int classb_add(b *p)
void fun_classb(b *p)
類中過載有函式過載和運算子過載兩種:
1)函式的過載
函式過載滿足的條件是:
函式名相同,引數個數或者引數型別不同。
這樣在呼叫的時候,會根據你輸入的引數不同,呼叫不同的函式。
在c中只好分別起不同的名字,沒有別的解決辦法。
2)運算子過載
運算子過載只是為了滿足一般的運算子使用的習慣而又不會出現錯誤。
c中不支援運算子過載,可以定義乙個函式實現該功能。
這是一般類的修改。
如何將控制台程式發布為服務
今天分享一種不一樣的方式.一.這裡貼一下我們的program類 1.program.cs using ivony.html using ivony.html.parser using system using system.collections.generic using system.confi...
如何將多個C語言模組組合成乙個程式
一般來說,我們編制的c語言源程式都是放在乙個擴充套件名為.c的檔案中,這對乙個較簡單的程式是合適的,但對於大型專案就不合適了,其一,大專案往往由多人合作完成,大家都來 操作同乙個檔案極易出錯 其二,大檔案的編譯 除錯都極為複雜 其三,如果兩個程式中都要用到同乙個自定義的函式,此函式須從一檔案移動到另...
C 如何將方法作為引數傳遞
如何實現將方法作為引數傳遞 示例是控制台程式,如下 class program static int a 2 static int b 3 static int c 0 static int x 4 宣告乙個方法型,關鍵字就是delegate,有引數就帶上引數 public delegate voi...