W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
有了Deck對(duì)象之后,把所有從屬于Deck的函數(shù)放入其結(jié)構(gòu)定義中也是情理之中的事了??匆幌碌侥壳盀橹刮覀兌x的函數(shù),很明顯12.7節(jié)的printDeck函數(shù)可以作為候選加進(jìn)來(lái)。下面將printDeck重寫(xiě)為成員函數(shù):
void Deck::print () const {
for (int i = 0; i < cards.length(); i++) {
cards[i].print ();
}
}
通常,引用當(dāng)前對(duì)象不需要使用點(diǎn)記號(hào)。
其他幾個(gè)函數(shù),至于是否應(yīng)將它們變?yōu)镃ard或Deck的成員函數(shù),還是作為以Card或Deck變量為參數(shù)的非成員函數(shù),并非顯而易見(jiàn)的。比如上一章以一個(gè)Card變量和一個(gè)Deck變量為參數(shù)的find函數(shù),將它變?yōu)镃ard或Deck類型的成員函數(shù)都是合理的。作為練習(xí),請(qǐng)重寫(xiě)find函數(shù),其參數(shù)為Card類型,使之成為Deck的成員函數(shù)。
將find改寫(xiě)為Card的成員函數(shù)需要一些小技巧,這是我寫(xiě)的版本:
int Card::find (const Deck& deck) const {
for (int i = 0; i < deck.cards.length(); i++) {
if (equals (deck.cards[i], *this)) return i;
}
return -1;
}
一個(gè)技巧是,必須使用this關(guān)鍵字來(lái)引用調(diào)用find函數(shù)的對(duì)象;再就是在C++中定義相互引用的結(jié)構(gòu)也需要一點(diǎn)技巧,因?yàn)榫幾g器正在讀取第一個(gè)結(jié)構(gòu)定義時(shí)還不知道第二個(gè)結(jié)構(gòu)的定義。
一種解決方案是,在Card定義之前先聲明Deck,以后再給出Deck的定義。
// 聲明Deck結(jié)構(gòu),這里不定義declare that Deck is a structure, without defining it
struct Deck;
// 這樣我們就可以在Card的定義中引用Deck
struct Card
{
int suit, rank;
Card ();
Card (int s, int r);
void print () const;
bool isGreater (const Card& c2) const;
int find (const Deck& deck) const;
};
// 后面給出Deck的定義
struct Deck {
apvector<Card> cards;
Deck ();
Deck (int n);
void print () const;
int find (const Card& card) const;
};
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: