質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

2回答

1386閲覧

継承について

wug

総合スコア13

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2015/06/07 01:40

###前提・実現したいこと
実行結果は
AIFLの貸出高は2000億円
TADANOの建造物はcrane
とならなければいけません
条件としてmain関数はこのままです。

###発生している問題・エラーメッセージ
string getName()const{ return name; }で
nameを返したいのですがnameがprivateの為アクセス出来ません
どうすればnameはprivateのままでアクセス出来ますか?

###ソースコード

lang

1#include <iostream> 2#include <string> //文字列操作用クラス 3using namespace std; 4 5//会社クラス定義 6class Company { 7 string name; //会社名 8public: 9 Company(string cname = "") : name(cname){} 10 11}; 12//金融業クラス定義 13class Finance : public Company { 14 int loan; //貸出高(億円) 15public: 16 Finance(string fname, int floan) : Company(fname),loan(floan){} 17 int getLoan() { return loan; } 18 string getName()const{ return name; } 19}; 20///////////////////////////////////////////////////// 21//製造業クラス定義 22class Production : public Company { 23 string product; //製造物 24public: 25 Production(string pname, string pproduct) : Company(pname),product(pproduct){} 26 string getProduct()const{ return product; } 27 string getName()const{ return name; } 28}; 29///////////////////////////////////////////////////// 30int main() 31{ 32 Finance* financeP(new Finance("AIFL", 2000)); 33 Production* productionP(new Production("TADANO", "crane")); 34 35 cout << financeP->getName() << "の貸出高は" 36 << financeP->getLoan() << "億円" << endl; 37 cout << productionP->getName() << "の製造物は" 38 << productionP->getProduct() << endl; 39 40 delete financeP; 41 delete productionP; 42 return 0; 43}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ProductionとFinanceの getName()は問題があります
まず Companyの nameはprivateのようですが、子クラスではアクセス出来ないので
子クラスの return(name) はエラーになりませんか?

親クラスにgetName()がありますが、そちらを使うべきです。
親クラスのgetNameと子供のgetNmaeの動作が異なるというのは 問題です

なので、改善点としては
1、親クラスのgetNameをpublicとして公開し、子クラスのgetNameは削除する
(public継承なので 子クラスのgetNameを削除した場合 親のgetNameが呼ばれます)
継承の勉強なので こちらの回答が正解と思います

2、親クラスのgetName()は 外部からアクセスされたくないという意図があれば
親クラスのgetName()は protected にします
protected:
string getName()const{ return name; }
そして 子クラスのgetName()は 変数を直接参照せず、親のgetNameを呼び出します
string getName() const{return(Company::getName());};

この2つです。

投稿2015/06/07 21:15

YukiMiyatake

総合スコア144

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

getName()はCompanyクラスに定義すればいいのでは?

投稿2015/06/07 01:57

ozwk

総合スコア13512

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

wug

2015/06/07 02:23

できました!ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問