c語言面向對象編程
㈠ c語言能不能面向對象
C++,objective-c肯定可以。
標准c,普遍的說法是不行。我說我自己的想法,如果編寫過面向對象的代碼,類這個名詞跟用戶不陌生吧!類基本上是面向對象編程的精髓。類無非就是,成員數據與成員方法的集合,通過某個指針我們能訪問到成員與方法。抽象、繼承、多態、重載是類的基本特種。
一般而言,c語言是面向過程的,函數式編程。用標准c求解問題。無非就是,定義結構體、共用體、枚舉、基本數據類型等,再定義一堆函數,來訪問操作這些數據。如果吧這些東西,劃分成在適當的文件,授予適當的許可權。c語言的每個源文件就相當於類。
抽象、多態,利用c99的無類型指針很好實現。繼承實現難度高,實現思想是利用指針可訪問到父對象成員。重載,c實現更簡單!此段別認為我是在瞎B吹牛。objective-c,swift這兩門編程語言,如果你要懂一點。可以看到這個理論的影子。當然這兩門語言有專用編譯器。跟c實現的面向對象編程有區別。
總結下來,用c實現面向對象,編程,難度大,不是寫應用程序開發人員該考慮的。建議別往這方向編寫程序。如java,c++,swift等等這些語言,能面向對象編程:
1、編譯器的難題別人解決了;
2、很多很多的基礎功能,按系統類庫已經提供,我們不用去編寫。
㈡ c語言是面向過程的還是面向對象的
c語言是面向過程的。面向過程是著重於其中程序設計的演算法、語言的運用,如設計不同功能的函數。
C++是面向對象的。C語言能以簡易的方式編譯、處理低級存儲器。C語言是僅產生少量的機器語言以及不需要任何運行環境支持便能運行的高效率程序設計語言。
c語言的特點:
1、代碼具有較好的可移植性
C語言是面向過程的編程語言,用戶只需要關注所被解決問題的本身,而不需要花費過多的精力去了解相關硬體,且針對不同的硬體環境,在用C語言實現相同功能時的代碼基本一致,不需或僅需進行少量改動便可完成移植,這就意味著,對於一台計算機編寫的C程序可以在另一台計算機上輕松地運行,從而極大的減少了程序移植的工作強度。
2、可生成高質量、目標代碼執行效率高的程序
與其他高級語言相比,C語言可以生成高質量和高效率的目標代碼,故通常應用於對代碼質量和執行效率要求較高的嵌入式系統程序的編寫。
㈢ 在C語言中,什麼叫做面向對象,什麼叫做面向過程
面向對象和面向過程都是編程思想,分別以對象和過程為主要目標進行編程。
1、面向對象:面向對象(ObjectOriented)是一種軟體開發方法。ObjectOriented的概念和應用已經超越了編程和軟體開發。面向對象是一種理解和抽象現實世界的方法。它是計算機編程技術發展的產物。
2、面向過程:面向過程(Procere Oriented)是一種以過程為中心的編程思想。面向過程都是以正在發生的過程為主要目標進行編程,與面向對象明顯的不同就是封裝、繼承、類。
(3)c語言面向對象編程擴展閱讀:
面向對象和面向過程的區別:
1、分析問題方式的不同:
面向過程是分析解決問題所需的步驟,然後使用函數逐步實現這些步驟,使用時一個接一個。
面向對象是將問題事務分解為各種對象。對象的建立不是為了完成一個步驟,而是為了描述一個事物在解決問題的整個過程中的行為。
2、解決問題的方法的不同:
面向過程其實是最為實際的一種思考方式,就算是面向對象的方法也是含有面向過程的思想。可以說面向過程是一種基礎的方法。它考慮的是實際地實現。一般的面向過程是從上往下步步求精,所以面向過程最重要的是模塊化的思想方法。
對比面向過程,面向對象的方法主要是把事物給對象化,對象包括屬性與行為。當程序規模不是很大時,面向過程的方法還會體現出一種優勢。
參考資料來源:網路-面向對象
參考資料來源:網路-面向過程
㈣ C語言中的「面向對象的編程思想」是什麼意思
面向對象的編程思想是這樣的:萬事萬物皆對象,說白了就封裝.
將程序所有用的所有東西都封裝起來.
簡單的說:你需要一輛車。
非面向對象的程序是這個樣的:你需要定義一個車屬性(即變數):顏色,時速,車的類型。
當然這是一輛車你可以這樣定義:但是如果10輛車呢,你需要定義30個不同名的變數,復雜可維護性極差,有時候自己都搞不清哪個變數對應的那輛車。
但是面向對象的是容易多了,定義一個車的類:顏色,時速,車的類型。
要10輛車,定義10輛車的變數就可以,10兩車就擁有顏色,時速,車的類型的屬性了。你只需要操作者10個變數就等於操作10車。
㈤ 如何理解面向對象編程
[引] 1.基本概念:
1.1 類與對象的初探
要我說,無論是面向過程的語言也好,面向對象的語言也罷,我首先要給他講的都是類和對象!--------「這個世界是由什麼組成的?」這個問題如果 讓不同的人來回答會得到不同的答案。如果是一個化學家,他也許會告訴你「還用問嘛?這個世界是由分子、原子、離子等等的化學物質組成的」。如果是一個畫家 呢?他也許會告訴你,「這個世界是由不同的顏色所組成的」。……呵呵,眾說紛紜吧!但如果讓一個分類學家來考慮問題就有趣的多了,他會告訴你「這個世界是 由不同類型的物與事所構成的」好!作為面向對象的程序員來說,我們要站在分類學家的角度去考慮問題!是的,這個世界是由動物、植物等組成的。動物又分為單 細胞動物、多細胞動物、哺乳動物等等,哺乳動物又分為人、大象、老虎……就這樣的分下去了!
現在,站在抽象的角度,我們給「類」下個定義吧!我的意思是,站在抽象的角度,你回答我「什麼是人類?」首先讓我們來看看人類所具有的一些特徵,這個 特徵包括屬性(一些參數,數值)以及方法(一些行為,他能幹什麼!)。每個人都有身高、體重、年齡、血型等等一些屬性。人會勞動、人都會直立行走、人都會 用自己的頭腦去創造工具等等這些方法!人之所以能區別於其它類型的動物,是因為每個人都具有人這個群體的屬性與方法。「人類」只是一個抽象的概念,它僅僅 是一個概念,它是不存在的實體!但是所有具備「人類」這個群體的屬性與方法的對象都叫人!這個對象「人」是實際存在的實體!每個人都是人這個群體的一個對 象。老虎為什麼不是人?因為它不具備人這個群體的屬性與方法,老虎不會直立行走,不會使用工具等等!所以說老虎不是人!
由此可見-------類描述了一組有相同特性(屬性)和相同行為(方法)的對象。在程序中,類實際上就是數據類型!例如:整數,小數等等。整數也有 一組特性和行為。面向過程的語言與面相對象的語言的區別就在於,面向過程的語言不允許程序員自己定義數據類型,而只能使用程序中內置的數據類型!而為了模 擬真實世界,為了更好的解決問題,往往我們需要創建解決問題所必需的數據類型!面向對象編程為我們提供了解決方案。
1.2 內置數據類型與函數:
計算機程序在存儲數據時必須跟蹤3個基本屬性為:
1. 信息存儲在何處;
2. 存儲的值是多少;
3. 存儲的信息是什麼類型的;
讓我們來看看編程語言的內置數據類型都有哪些!(呵呵,這個不大好說,因為每門語言都有自己獨特的數據類型,但這畢竟是少數,比如在JAVA中有 byte類型的數據,而在C++中就沒有,希望你能舉一反三!)比如整數」int 」,浮點類型的數據」float」!字元串」String」,以及數組還有結構體等等。然而在寫程序的時候,根據需要我們會創建一個類型的變數或常量,例 如:由於我們需要創建一個整形的變數i為5,我們就可以這樣做,int i = 5;而根據需要我很有可能改變i的值,也就是從新給它賦值,比如讓它等與6,就可以在所需的地方改成i = 6;由此我們知道,在「值」上可以發生變化的量就叫變數。不會發生變化的量就叫做常量了,在C++中用count關鍵字來聲明,而在JAVA中則使用 final關鍵字來聲明。由於不同語言的聲明格式不一樣,這里就不做一一介紹了,詳細的內容清查閱相關書籍!
在這里我們主要討論一下函數,我們可以把函數想像成一個「實現某種特定功能的黑匣子」-------這個功能是由你來設定的,舉個例子來說:現在我問 你「2+3等於多少」?我相信你能很快的回答我等於5。讓我們來分析分析這句話包含什麼信息!首先我要把你的大腦想像成是一個黑匣子,我並不知道也沒有必 要知道你的大腦是如何工作的(也就是怎麼運算的),我關心的只是我傳給你的是什麼信息?你對信息做了哪些處理? 以及你返回給我的是什麼信息?需要提醒你一下的是每個方法都會返回一個信息給調用者的,除了構造函數外(稍候我會作詳細的介紹)。我現在需要把自己當作是 一名程序員,而你呢?當然就是計算機了!計算即可沒有人那麼聰明,它只會按事先約好的特定的格式運行,我想讓它具有如上所述的功能,我就要先定義這個黑匣 子!首先我要告訴這個黑匣子會有兩個整數值給你(這就是所謂的參數,是程序員需要給黑匣子的信息),然後就要定義這個黑匣子內部實現這兩個整數相加的運算 (這就是黑匣子對數據所做的加工,根據需要,你可以做任何的加工。)。最後再標注它返回給我一個同樣是整型的數值(這是黑匣子返回給程序員的信息)。一個 函數就這樣定義完了,讓我們來看看書寫格式:
int addnum(int x,int y){
return x+y;
}
具體的含義是這樣的:
int /*返回值類型*/ addnum /*方法(黑匣子)名稱*/ (int x,int y/*傳入的參數*/){
return x+y; /*內部是想方法(實現相加運算,)並用return返回給調用者結果*/
}
首先請注意上明的「return」語句!return 關鍵字的含義是向調用者返回緊跟在它後面的信息!就像上面一樣,因為我問你,你才會回答我,如果我不問你,你就不用回答我的!在計算機中也一樣,定義好這 個函數在哪裡調用呢?我只能告訴你,哪裡需要就在哪裡調用!當然,你可以根據需要去更改參數、返回值以及內部實現,具體到如何定義如何調用你只好去參考相 關的資料了!在這里我只是給你一個思想!
有時你會遇到這樣的問題,我讓你記住,我的年齡是20歲!從字面上理解,你並沒有給我返回信息!然而事實上,你確實給我返回了信息,信息的內容是「無信息,也就是無返回值類型void」。具體的程序如下:
int myAge = 0;
int a=20;
void remAge(int a){
myAge=a;
}
具體的函數說明如下:
int myAge =0; //定義並初始化我的年齡為0;
int a=20; /*定義變數a等於20*/
void /*返回值類型為無返回值類型*/ remAge /*函數名稱*/(int a /*傳入的參數*/){
myAge=a; //內部實現方法,注意,沒有return返回!!!
}
關於函數的話題還有很多很多,這里就不一一介紹了,我的目的是讓你知道函數是怎麼一會事兒!為下面的討論作鋪墊!
1.3 指針以及引用:
指針及引用是在C++中有的,JAVA中沒有。JAVA中取消了對內存的操作,隨之而來的事也取消了操作符重載的操作。不過在稍候我還是會介紹一些操 作符重載的功能等。引用主要還是用在函數參數的傳遞上。所以我在這里就不做過多的介紹了。他們很實用,有興趣的同學可以參閱C++相關書籍。
1.4 運算符及控制語句:
還是自己看看相關書籍吧,這里就不再熬述了!
2.深入探討面向對象:
2.1「類型」的內部細節:
有了上面的知識,我們現在就可以深入的挖掘類的內部實現了。所有的知識點我都會圍繞著類與對象展開,在此之前,我希望你能夠確信對以上所介紹的基本內容已完全掌握了!
是的,面向對象的編程語言最大的特色就是可以編寫自己所需的數據類型,以更好的解決問題。我想我必須要幫你搞清楚「類,對象,屬性,方法它們之間的關 系」!就像我前面所說的,人這個「類」是什麼也做不了的,因為「人類」只是一個抽象的概念,它不是實實在在的「東西」,而這個「東西」就是所謂的對象。只 有人這個「對象」才能去工作。而類呢?類是對象的描述!對象從類中產生出來!此時,對象具有類所描述的所有的屬性以及方法。-------一定要理解這句 話!!!
也許你已經有些不知所措了,沒關系!好好的回味一下,我再舉個例子!例如電視機,電視機都有工作原理圖,那麼什麼叫電視機呢?只要它能夠實現工作原理圖的 所有功能的物體,我們都叫它電視機。你想想是不是這么一回事兒?可是,電視機原理圖是不能工作的,也就是這個原理圖不能收看節目,只有電視機這個「實體 ——即所謂的對象」才能收看節目,也就是說,從類生成出對象之後才算得上是真正的有意義!才能開始工作。此時,電視機擁有電視原理圖所描述的所有的屬性及 方法!明白了吧,呵呵!
我先前介紹過,類是屬性與方法的集合。而這些屬性與方法可以被聲明為私有的(private),公共的(public)或是受保護(protected)的,他們描述了對類成員的訪問控制。下面我分別做一下介紹:
1. 公共的(public):把變數聲明為公共類型的之後,那麼就可以通過對象來直接訪問,一切都是暴露無遺的!也就是說,你的信用卡密碼別人也能夠直接得到。
2. 私有的(private):如果把變數聲明為私有的情況就好多了,想要得到我的信用卡密碼,對象必須要調用專用的方法才能夠得到。
3. 受保護的(protected):介紹繼承時再討論。
4. 默認控制訪問符(friendly)://JAVA中有而C++中沒有。
為了實現數據的封裝,提高數據的安全性,我們一般會把類的屬性聲明為私有的,而把類的方法聲明為公共的。這樣,對象能夠直接調用類中定義的所有方法,當對 象想要修改或得到自己的屬性的時候就必須要調用以定義好的專用的方法才能夠實現。你想想,你會把你的信用卡密碼公布出來嘛?呵呵!所以,我們提倡的是: 「對象調方法,方法改屬性」;
2.2通過實例看內存分配:
說了這么多,讓我們來看一個實例吧!比如:現在我們要編寫某家公司員工管理系統,你認為最合適的數據類型是什麼?我認為是員工個人!但是在面向過程的 語言中,這樣做是不允許的,因為它只能使用語言中的內部數據類型!而員工不在這個內部數據類型之內!也許有人會說可以用C語言中的struct,好注意! 畢竟它是類的基礎!如果你以前是一名面C或B的程序員,請你忘掉這些,讓我們一起看看如何用類來實現這一切吧!
某家公司的員工是人類的一個特殊群體,它除了具備人類的所有特性與方法外,它還有額外的特性與方法,比如她有她的工資、信用卡密碼、作息時間等等,這 些特性以及工作內容,工作量等等這些方法。而在計算機中我們該如何定義這個類呢?下面我將寫出它的格式,讓你看看在計算機中它是張什麼樣子的!
/*在此我需要再次聲明的是,我用的是JAVA格式,在語法格式上它與C++大不相同!許多細節以及內部操作都有諸多區別,而在思想上確實大同小異的*/
//employee.java
public class employee{
private String name; //員工姓名
private int age; //員工年齡
private char sex; //員工性別
private float emolument; //員工薪水
private boolean lunch; //員工午餐
//……等等
public void heater(){ //這個方法是用來加工員工的午餐
lunch = true;
}
public void setName(String a){ //這個方法是修改員工的姓名
name= a;
}
public String getName(){ //這個方法是得到員工的姓名
return name;
}
//……等等
}
這樣我們就定義完了我們所需要的數據類型。現在,讓我們來看看它能夠干什麼以及怎麼工作!
我想要做的是,工作室里有一個光桿司令叫「jingwei」,我修改它的名字後對對它進行輸出,看看我是怎麼做的吧!
注意:請仔細觀察對象是如何調用方法的,它使用了「.」操作符!事實上是這樣的,對象調用公共的屬性或方法時就會使用「.」操作符。
然而在C++中,如果定義一個同類型的指針,該指針調用此對象的方法時,就會使用「->」操作符。更詳細的內容清參閱相關書籍了!
//workstation.java
import java.awt.Graphics;
import java.applet.Applet;
public class workstation extends Applet{
private employee jingwei ; //對象的聲明,此時並不分配內存!
public void init(){
jingwei = new employee(); /*此時創建對象會調用構造函數,稍候介紹*/
jingwei.setName(「jw」); //設置我的名字
}
public void paint(Graphics g){
g.drawString("my age is "+jingwei.getName(),10,10);//顯示我的年齡
}
}
輸出結果是:
my name is jw
這串字元串是在輸出窗口的x坐標軸為10 px , y坐標軸為10 px的位置。
我現在要做的是,把上面的程序做個大解剖,讓你能夠看清楚它到底是怎麼一回事兒!(我可不時帶你去看裡面的匯編,呵呵,那個我也不會:)
首先還是來看看我們自定義的數據類型employee,在應用的時候它和int類型的數據沒什麼兩樣,一樣的需要創建變數(對象),只不過前者是咱自 己定義的,而後這是它內置的。Employee這個類中有許多屬性,也有許多方法。而此時,我們不能直接用我們所創建出來的對象調用它的屬性進行修改。因 為它是private受保護類型的!我要想修改我的姓名我就要用對象調用setName()這個方法,而我想得到我的姓名就要調用getName()這個 方法。我們完全是按照航線來行走的,這個航線就是「對象調方法,方法改屬性」
好的,我真的相信你已經明白了這是怎麼一回事兒了!呵呵!仰起航帆,繼續前行!
現在讓我們一起來看看workstation這個類。這是個主類,和C++中的main()函數的味道差不多。其中,在JAVA中,一個文件只允許有而且必須有一個主類,這個主類用public來聲明!他就跟C++中必須要有一個main()函數是一樣的。
讓我們來看看這個類中的第一條語句!private employee jingwei ;這條語句的作用是聲明一個employee的對象jingwei(在C++中就不用聲明了)。我想要和你說的是「聲明」與「定義」之間的區別。聲明只是 告訴計算機將要有這樣的一個變數(對象),在內存中它並不為這個變數(對象)分配內存!而只有在定義的時候才會給這個變數(對象)分配內存。(需要說明一 下的是init()方法是完成初始化操作的,在此處定義對象,為對象分配內存。start()方法用來啟動瀏覽器的主線程,paint()方法來顯示 Apple的界面。這些是Applet程序所需的,至於Application程序就不需要了,當然了,C++中也不需要他們。關於他們的詳細內容清參閱 相關書籍)
緊接著就開始定一個對象了,對jingwei這個對象進行操作才會有實際的意義。千萬不要有這種想法:「試圖對類進行操作!」就像前面我說的,電視機 原理不能看電視一樣!這是毫無意義的!看這條語句jingwei = new employee();它的意思就是定義一個employee類型的對象jingwei。此時,我想告訴你的是:「jingwei這個對想擁有了些什 么」。它擁有了類所描述的所有的屬性及方法。下面我一一給你列出來:
/*所有的employee對象都擁有這些屬性。每創建一個對象就會從新分配一塊內存來存放相應對象的這些屬性。我的意思是每個對象都有自己「獨特」的一份*/
private String name; //員工姓名
private int age; //員工年齡
private char sex; //員工性別
private float emolument; //員工薪水
private boolean lunch; //員工午餐
/*所有的employee對象都擁有這些方法。但在內存中只有一份*/
public void heater(){ //這個方法是用來加工員工的午餐
lunch = true;
}
public void setName(String a){ //這個方法是修改員工的姓名
name= a;
}
public String getName(){ //這個方法是得到員工的姓名
return name;
}
/*但是,實際上在創建jingwei這個對象時計算機只給這個對象的所有的屬性分配了內存,而並沒有給方法分配內存。方法只有一個,是屬於所有的對象的,所以無論創建了多少個對象,計算機只會為一個方法分配一塊內存。*/
我想我還是舉個例子吧,不然你非暈倒不可。呵呵!
看我這條語句「private boolean lunch;」公司不管午餐,每個員工都需要帶飯。我們現在這樣想,公司的空間是所有的內存容量,你的辦公桌就是計算機中的內存中的一部分(每個員工都有 一份,是在創建對象時分配的)。你把午飯帶到了公司,放在了你的辦公桌上。「午飯」占據了你的辦公桌的一角(佔了你自己「對象」的一塊內存容量)。這份午 飯只屬於你自己,同樣別人的也只屬於她自己!所以每個員工(對象)都需要一快空間(內存)來存放自己的午餐(屬性)。在計算機中也是這樣的,每創建一個對 象,就會在內存中從新分配一塊內存來放「午餐——lunch」這個屬性(對象所擁有的所有的屬性)。
計算機只會為對象的屬性分配內存。因為每個對象的都不一樣!就像你往公司帶的午飯和我往公司帶的午飯不一樣是一個道理!但方法就不同了。早晨帶的飯中 午就涼了,你需要用微波爐來加熱。微波爐可不用你帶,公司就有(只佔公司的一塊空間),它放在了午餐桌上。你想想,微波爐屬於誰的?它屬於所有員工的!因 為每個員工都可以用它。而不必每個員工都帶一份。由此可見,每個員工(對象)都有一份午飯(屬性),但所有的員工(對象)只一個微波爐(方法)。所有的員 工(對象)都可以通過這個微波爐(方法)來改變自己午餐(屬性)的冷熱狀態。殊途同歸!在計算機中也就是這樣,方法只有一份,供所有的對象使用!而屬性是 每個對象一份,因為每個對象的都不一樣。別和我說你還不明白,不然我會撞牆的,呵呵:)
2.3深入探討函數:
2.3.1構造函數、默認構造函數、 預設構造函數
對於上面的實例,它已經能完成絕大部分工作了,但它還是不完善的,還有許許多多的細節等到我們去完善!也許有的同學已經注意到了,當我創建完 「jingwei」這個對象時,這個對象的所有的屬性都是空的,也就是說:這個對象的姓名是未定的、年齡是未定的、性別是未定的、薪水是未定的、午餐也是 未定的。而我們想把這些屬性都添加上去,就還要用對象調用相應的方法,去一個個修改!天啊,這簡直是太麻煩了!有沒有什麼好方法能夠在我們創建對象的同時 就完成了對屬性賦值的操作呢?哦不,應該說是對屬性的初始化呢?當然沒問題了,這就需要所謂的構造函數!
構造函數是類中最特殊的函數,它與析構函數的功能正好相反!
從特徵上來說:1.它是編程語言中唯一沒有返回值類型的函數。
2.它的名稱與類的名稱必須要完全相同。
3.它必須被聲明為公共(public)的類型
4,可以對構造函數進行重載。
5.它在創建對象是自動被調用。
從功能上來說:1.它是對類中的屬性進行初始化。
其實,對於上面的程序來說我們沒有自己定義構造函數。但是,在這種情況下,系統會自動為我們定義一個「默認構造函數」。他會把數值變數自動賦值為0, 把布爾行變數賦值為false等等(但在C++中,默認構造函數不初始化其成員)。如果程序員定義了構造函數,那麼系統就不會再為你的程序添加一個缺默認 造函數了。(在這里,我們提倡的是自己定義構造函數,而不是用系統的默認構造函數)
還是看個實例吧!這樣比較清楚一些!
//employee.java
public class employee{
private String name; //員工姓名
private int age; //員工年齡
private char sex; //員工性別
private float emolument; //員工薪水
private boolean lunch; //員工午餐
//……等等
public employee(){ //這個就是「默認」構造函數
name = 「jw」; //設置員工姓名
age = 20; //設置員工年齡
sex = 「M」; //設置員工性別
emolument = 100; //設置員工薪水
lunch = false; //設置員工午餐
}
public void heater(){ //這個方法是用來加工員工的午餐
lunch = true;
}
//……等等
};
這樣,在我們創建「jingwei」這個對象的同時,它的所有的屬性也被初始化了!顯然,這大大的提高了工作效率,但是,它還是不符合要求。想想看, 如果我們現在創建這個類型的第二個對象的時候會發生什麼事情?告訴你,除了對象的「名」(這個名稱不在是對象屬性中的名稱,而是對象本身的名稱)不一樣 外,其所有的「屬性值」都一樣!比如:現在我們創建第二個對象flashmagic,然而我會發現這個對象的所有的屬性和jingwei這個對象的所有的 屬性完全相同。而我們只能在用對象的方法去改變著寫屬性了!很顯然,這種方法不大好!我們需要一種方法在創建對象的時候為對象的屬性賦予「我們想要的 值」。
相信你也看到了,默認構造函數就顯得無能為力了。我們需要的是帶參數的構造函數,在創建對象時,我們把參數傳給構造函數,這樣就能完成了上述的功能!口說無憑,還是來看個實例吧:
//employee.java
public class employee{
private String name; //員工姓名
private int age; //員工年齡
private char sex; //員工性別
private float emolument; //員工薪水
private boolean lunch; //員工午餐
//……等等
public employee(String n,int a,char s,float e,boolean l){ //看這個構造函數
name = n; //設置員工姓名
age = a; //設置員工年齡
sex = s; //設置員工性別
emolument = e; //設置員工薪水
lunch =l; //設置員工午餐
}
public void heater(){ //這個方法是用來加工員工的午餐
lunch = true;
}
//……等等
};
這樣一來,在創建對象的同時我們就可以給他賦予我們想要的值,很顯然,這可就方便多了。哦,對了!還沒有告訴你怎麼創建呢!哈哈,往前翻幾頁你會看到這句話:
jingwei = new employee();這是創建一個對象,而我們把它改成
jingwei = new employee("jingwei",20,'M',100,false);這樣一來,所有的工作都完成了,呵呵!(在創建對象的同時賦予了我們想要的「初值」)
2.3.2重載構造函數:
我還是先把概念給你吧,讓你有個認識,隨後我們在進行論述。
在JAVA中:
1. 函數重載是一個類中聲明了多個同名的方法,但有不同的參數個數和參數類型。
2. 函數重構是指在子類中聲明與父類同名的方法,從而覆蓋了父類的方法。重構解決了子類與父類的差異問題。(在討論到繼承時我會詳細說明)
在C++中:
1. 數重載的概念一樣。
2. 重構的概念可就不一樣了,C++中功能更為龐大的虛函數。更詳細內容這里就不錯過多介紹了!
其實關於重載的概念你並不陌生,在編程中相信你也接觸過。呵呵!讓我們來舉個操作符重載的例子你就會明白了,(JAVA中不支持這個功能)我們定義三個整數變數:
int i1=2, i2=3,i3=0;
i3 = i1 + i2;
此時i3=5;加號實現了兩個數相加的運算功能。然而我們現在要定義三個字元串變數:
String str1=」jing」, str2=」wei」,str3=」」;
str3 = str1 + str2;
此時str3 = 「jingwei」;加號實現了兩個字元串相加的運算功能。同樣是加號,既可以把兩個整型的變數加在一起,也可以把兩個字元串類型的變數加在一起。同一個 操作符實現了不同的功能------這就是所謂的操作符重載(嘿嘿,我說你一定見過吧:)!不就好像是漢語中的一詞多意一樣!我需要說明一下的是,C++ 中的操作符重載可沒有這么簡單。比如,我們可以對兩個自定義類型的對象進行相加的運算,進行賦值的運算。這樣書寫簡潔明了,而且非常實用。當然,關於操作 符重載的話題太多了,有興趣再看看書吧!
我們把操作符的話題在轉到函數上來,我們一直強調的是「對象調方法」------對象其實調的是方法的「名稱」。而我們現在要對方法進想重載,也就是 定義多個相同名稱的函數,這樣計算機在調用的時候不會混淆嘛?我想應該不會的,呵呵,因為僅僅是函數名稱相同,而我們在調用函數時會把參數傳遞給他的。既 是沒有參數也是一種參數傳遞參數的信息(信息為無參數)!然而由於參數類型、參數數量、返回值類型不同我們就可以對相同名稱的函數進行區分�
㈥ 如何用C語言實現面向對象
可以通過以下方法實現面向對象:
1、封裝
封裝就是把數據和方法打包到一個類裡面。其實C語言編程者應該都已經接觸過了,C 標准庫 中的 fopen(), fclose(), fread(), fwrite()等函數的操作對象就是 FILE。
數據內容就是 FILE,數據的讀寫操作就是 fread()、fwrite(),fopen() 類比於構造函數,fclose() 就是析構函數。
2、繼承
繼承就是基於現有的一個類去定義一個新類,這樣有助於重用代碼,更好的組織代碼。在 C 語言裡面,去實現單繼承也非常簡單,只要把基類放到繼承類的第一個數據成員的位置就行了。
例如,我們現在要創建一個 Rectangle 類,我們只要繼承 Shape 類已經存在的屬性和操作,再添加不同於 Shape 的屬性和操作到 Rectangle 中。
3、多態 C++
語言實現多態就是使用虛函數。在 C 語言裡面,也可以實現多態。 現在,我們又要增加一個圓形,並且在 Shape 要擴展功能,我們要增加 area() 和 draw() 函數。
但是 Shape 相當於抽象類,不知道怎麼去計算自己的面積,更不知道怎麼去畫出來自己。而且,矩形和圓形的面積計算方式和幾何圖像也是不一樣的。
4、虛表和虛指針
虛表(Virtual Table)是這個類所有虛函數的函數指針的集合。
虛指針(Virtual Pointer)是一個指向虛表的指針。這個虛指針必須存在於每個對象實例中,會被所有子類繼承。
5、在構造函數中設置vptr
在每一個對象實例中,vptr 必須被初始化指向其 vtbl。最好的初始化位置就是在類的構造函數中。
事實上,在構造函數中,C++ 編譯器隱式的創建了一個初始化的vptr。在 C 語言裡面, 我們必須顯示的初始化vptr。下面就展示一下,在 Shape 的構造函數裡面,如何去初始化這個 vptr。