樓主有些誤解了,C語言中的確有你說的多變參數(shù)的函數(shù),比如printf()scanf()等等,它們的實(shí)現(xiàn)也的確是用宏來實(shí)現(xiàn)了,具體實(shí)現(xiàn)不贅述,C++是C的超集,自然也可以用這種方式解決。
中江網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),中江網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為中江上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個(gè)售后服務(wù)好的中江做網(wǎng)站的公司定做!
下面說多態(tài),其實(shí)多態(tài)是面向?qū)ο蟮奶卣?,具體到C++中,函數(shù)的重載,重寫,以及虛函數(shù)都是多態(tài)的體現(xiàn),而類似于C中的多變函數(shù),則是用函數(shù)的重載實(shí)現(xiàn)的,舉個(gè)例子
class A
{
public:
void func(int);
void func(float);
void func(long);
};
void A::func(int x)
{
cout "int version" endl;
}
void A::func(float x)
{
cout "float version" endl;
}
void A::func(long x)
{
cout "long version" endl;
}
void main()
{
int a;
float b;
long c;
func(c);
func(b);
func(a);
}
類A中的func()成員函數(shù)有3個(gè)重載版本,重載函數(shù)是通過對應(yīng)不同的參數(shù)來識(shí)別時(shí)調(diào)用哪一個(gè)函數(shù),這就是類似C中的可變函數(shù)。
(重載只是C++中多態(tài)的一角,想更詳細(xì)的了解的,我想市面上任何一本C++
的書都會(huì)講到,不過重點(diǎn)可能都是虛函數(shù),重載和重寫比較容易理解)
----------------我是無視上面的分割線--------------------------
你的問題里面不是說C++么
C語言怎么實(shí)現(xiàn)的看我轉(zhuǎn)的這篇文章吧
最簡單的做法是在結(jié)構(gòu)體里存函數(shù)指針,然后初始化結(jié)構(gòu)體的時(shí)候?qū)⒑瘮?shù)的地址賦值給它。
復(fù)雜一點(diǎn)的,就得按照C++的多態(tài)原理,用虛函數(shù)表(其實(shí)就是能記錄函數(shù)名對應(yīng)的函數(shù)地址就好)記錄每種結(jié)構(gòu)體的成員函數(shù)地址,然后每個(gè)結(jié)構(gòu)體里多存一個(gè)虛函數(shù)表的地址。。。然后調(diào)用函數(shù)的時(shí)候查到函數(shù)地址強(qiáng)轉(zhuǎn)成函數(shù)類型然后調(diào)用。。。這個(gè)可以自己研究一下c++的虛函數(shù)表機(jī)制。
參數(shù)多態(tài)概念:采用參數(shù)化模板,通過給出不同的類型實(shí)參,使
得一個(gè)結(jié)構(gòu)有多種類型。
對實(shí)參所取的類型不加限制;對不同的實(shí)參執(zhí)行的是相同的代碼。
比如說一個(gè)壓棧操作函數(shù),它既可以實(shí)現(xiàn)int型數(shù)據(jù)壓棧,也可以實(shí)現(xiàn)char型數(shù)據(jù)壓棧
如:自定義類型void 就是;void* 是C語言的一個(gè)“多態(tài)”方式
又如:
參數(shù)多態(tài):對不同類型的值執(zhí)行相同的代碼。
宏----好象不對,比如象典型的這種情況
#define max(a,b) ((a)(b)?(a):(b)
int a=5,b=0;
max(a++,b); (1) a被累加2次
max(a++,b+10); (2)a被累加1次
(1)和(2)的行為并不相同。
多態(tài)
多態(tài)是OOP的另一個(gè)重要概念。多態(tài)的意思是事物具有不同形式的能力。舉個(gè)例子,對于不同的實(shí)例,某個(gè)操作可能會(huì)有不同的行為。這個(gè)行為依賴于所要操作數(shù)據(jù)的類型。比如說加法操作,如果操作的數(shù)據(jù)是數(shù),它對兩個(gè)數(shù)求和。如果操作的數(shù)據(jù)是字符串,則它將連接兩個(gè)字符串。
一個(gè)函數(shù)處理不同數(shù)量、不同類型的參數(shù)。就像某個(gè)單詞在不同的上下文中具有不同的含義。
多態(tài)機(jī)制使具有不同內(nèi)部結(jié)構(gòu)的對象可以共享相同的外部接口。這意味著,雖然針對不同對象的具體操作不同,但通過一個(gè)公共的類,它們(那些操作)可以通過相同的方式予以調(diào)用。多態(tài)在實(shí)現(xiàn)繼承的過程中被廣泛應(yīng)用。
面向?qū)ο蟪绦蛟O(shè)計(jì)語言支持多態(tài),術(shù)語稱之為“one interface multiple method(一個(gè)接口,多個(gè)實(shí)現(xiàn))”。簡單來說,多態(tài)機(jī)制允許通過相同的接口引發(fā)一組相關(guān)但不相同的動(dòng)作,通過這種方式,可以減少代碼的復(fù)雜度。在某個(gè)特定的情況下應(yīng)該作出怎樣的動(dòng)作,這由編譯器決定,而不需要程序員手工干預(yù)。
在多函數(shù)程序中,許多重要的數(shù)據(jù)被聲明為全局變量,這樣它們才可以被所有的函數(shù)訪問。每個(gè)函數(shù)又可以具有它自己的局部變量。全局變量很容易被某個(gè)函數(shù)不經(jīng)意之間改變。而在一個(gè)大程序中,很難分辨每個(gè)函數(shù)都使用了哪些變量。如果我們需要修改某個(gè)外部數(shù)據(jù)的結(jié)構(gòu),我們就要修改所有訪問這個(gè)數(shù)據(jù)的函數(shù)。這很容易導(dǎo)致bug的產(chǎn)生。
在結(jié)構(gòu)化程序設(shè)計(jì)中,另一個(gè)嚴(yán)重的缺陷是不能很好的模擬真實(shí)世界的問題。這是因?yàn)楹瘮?shù)都是面向過程的,而不是真正的對應(yīng)于問題中的各個(gè)元素。
面向過程的程序設(shè)計(jì)的一些特點(diǎn)如下:
·強(qiáng)調(diào)做(算法);
·大程序被分隔為許多小程序,這些小程序稱為函數(shù);
·大多數(shù)函數(shù)共享全局?jǐn)?shù)據(jù);
·數(shù)據(jù)開放的由一個(gè)函數(shù)流向另一個(gè)函數(shù)。函數(shù)把數(shù)據(jù)從一種形式轉(zhuǎn)換為另一種形式。
采用由上至下的程序設(shè)計(jì)方法。
c++是一種編程語言,當(dāng)然只有一種。但是基于c++的編程平臺(tái)有很多種。
在這些平臺(tái)上編程序,用的語言是c++的,但是在一些細(xì)節(jié)上會(huì)有所不同。我接觸過的主要有vc++,symbian c++,borland c++,它們都是基于c++的,但是編程風(fēng)格或方式稍有不同。
你學(xué)c++要打好基礎(chǔ),先學(xué)好c++語言。看書的時(shí)候可以找一些書名為“c++編程語言”之類的書,只有在學(xué)好c++語言后,才可以去具體的學(xué)習(xí)某個(gè)平臺(tái)的編程教程。
一般來說,多態(tài)分為兩種,靜態(tài)多態(tài)和動(dòng)態(tài)多態(tài)。靜態(tài)多態(tài)也稱編譯時(shí)多態(tài),主要包括模板和重載。而動(dòng)態(tài)多態(tài)則是通過類的繼承和虛函數(shù)來實(shí)現(xiàn),當(dāng)基類和子類擁有同名同參同返回的方法,且該方法聲明為虛方法。
當(dāng)基類對象,指針,引用指向的是派生類的對象的時(shí)候,基類對象,指針,引用在調(diào)用基類的虛函數(shù),實(shí)際上調(diào)用的是派生類函數(shù)。這就是動(dòng)態(tài)多態(tài)。
靜態(tài)多態(tài)的實(shí)現(xiàn)。
靜態(tài)多態(tài)靠編譯器來實(shí)現(xiàn),簡單來說就是編譯器對原來的函數(shù)名進(jìn)行修飾,在c語言中,函數(shù)無法重載,是因?yàn)椋琧編譯器在修飾函數(shù)時(shí),只是簡單的在函數(shù)名前加上下劃線”_” ,不過從gcc編譯器編譯之后發(fā)現(xiàn)函數(shù)名并不會(huì)發(fā)生變化。
而c++編譯器不同,它根據(jù)函數(shù)參數(shù)的類型,個(gè)數(shù)來對函數(shù)名進(jìn)行修飾,這就使得函數(shù)可以重載,同理,模板也是可以實(shí)現(xiàn)的,針對不同類型的實(shí)參來產(chǎn)生對應(yīng)的特化的函數(shù),通過增加修飾,使得不同的類型參數(shù)的函數(shù)得以區(qū)分。
在編程語言和類型論中,多態(tài)(英語:polymorphism)指為不同數(shù)據(jù)類型的實(shí)體提供統(tǒng)一的接口。?多態(tài)類型(英語:polymorphic type)可以將自身所支持的操作套用到其它類型的值上。
計(jì)算機(jī)程序運(yùn)行時(shí),相同的消息可能會(huì)送給多個(gè)不同的類別之對象,而系統(tǒng)可依據(jù)對象所屬類別,引發(fā)對應(yīng)類別的方法,而有不同的行為。簡單來說,所謂多態(tài)意指相同的消息給予不同的對象會(huì)引發(fā)不同的動(dòng)作。
多態(tài)也可定義為“一種將不同的特殊行為和單個(gè)泛化記號(hào)相關(guān)聯(lián)的能力”。
擴(kuò)展資料:
多態(tài)可分為變量多態(tài)與函數(shù)多態(tài)。變量多態(tài)是指:基類型的變量(對于C++是引用或指針)可以被賦值基類型對象,也可以被賦值派生類型的對象。函數(shù)多態(tài)是指,相同的函數(shù)調(diào)用界面(函數(shù)名與實(shí)參表),傳送給一個(gè)對象變量,可以有不同的行為,這視該對象變量所指向的對象類型而定。因此,變量多態(tài)是函數(shù)多態(tài)的基礎(chǔ)。
多態(tài)還可分為:動(dòng)態(tài)多態(tài)(dynamic polymorphism)和靜態(tài)多態(tài)(static polymorphism)。
對于C++語言,帶變量的宏和函數(shù)重載(function overload)機(jī)制也允許將不同的特殊行為和單個(gè)泛化記號(hào)相關(guān)聯(lián)。然而,習(xí)慣上并不將這種函數(shù)多態(tài)(function polymorphism)、宏多態(tài)(macro polymorphism)展現(xiàn)出來的行為稱為多態(tài)(或靜態(tài)多態(tài)),否則就連C語言也具有宏多態(tài)了。談及多態(tài)時(shí),默認(rèn)就是指動(dòng)態(tài)多態(tài),而靜態(tài)多態(tài)則是指基于模板的多態(tài)。