
クラスのメンバ関数が多すぎる場合のデメリットはありますか?
C++ であるクラスを実装してメンバ関数の追加を続けていたところ、メンバ関数の数が数十にまでふくれあがってしまいました。
このようにクラスのメンバ関数の数が多くなってしまった場合、パフォーマンス上でデメリットがありますでしょうか。
私としては、メンバ関数分だけメモリを食う、クラスのコピーが遅くなる、といいた点で心配なのですが実際のところどうなのでしょうか?
(メンバ関数は、基本的にはクラスのメンバを操作するものなので、グローバル関数ではなくてクラスのメンバにしておいたほうが分かりやすいかなと思っています。)
No.4ベストアンサー
- 回答日時:
まず大雑把に言うと、メモリ上に置かれたクラスは変数の設計図と関数の実体が含まれます。
インスタンス化されて複数作成される場合でも、変数領域は複数作成されますが、関数の実体はコピーされません。
ですから、メンバー関数が複数コピーされてメモリを食うと言う事はありません。
なので、この話しからだけでは、パフォーマンスやデメリットに直結した事象は見えません。
多分スレ主さんも危惧されているので書き込まれてんだと思いますけど…
そんな小手先の事より、歴代積み上げてしまった関数の是非って言うのの再検討は必要かもしれません。
実際にやってると中々見直せって言われても出来ない事多いんですが息が長いプログラムならばこそ何処かでね。
迅速にご回答いただきまして大変ありがとうございました。
当初心配していた意味でのデメリットは無いことがわかりました。
長く、かつ複数人で使いたいと思っているので設計については、機会を見つけて再検討してみたいと思います。
No.5
- 回答日時:
仮想関数であれば、サイズ的なデメリットはあります。
つまり、大量の仮想関数を持つクラスから継承した場合、基底クラスの仮想関数は、実際に呼び出されるかどうかに関わらずすべてリンクされてしまいます。
ほかのデメリットとしては、メンバ関数が多くなってくると、そのクラスのデータメンバは実質的にグローバル変数化しますね。
迅速にご回答いただきまして大変ありがとうございました。
当初心配していた意味でのデメリットは無いことがわかりました。
クラスのメンバ変数は確かに実質的にはグローバル変数のような扱いになってしまってきています。
この点も考え再検討したいと思います。
No.3
- 回答日時:
仮想関数だとほぼ選択の余地がないので, おそらく仮想でないメンバ関数と非メンバ関数との比較において, ですよね? だとしたら, パフォーマンスの問題はないといっていいです.
ただ, #1 も言われているようにクラスの設計に問題がある可能性がないとはいえないので, そこには気を付ける必要があるかと. まあ, しょうがないときはしょうがないんですが....
迅速にご回答いただきまして大変ありがとうございました。
当初心配していた意味でのデメリットは無いことがわかりました。
設計という意味では再検討してみたいと思います。
No.2
- 回答日時:
C++は詳しくはありませんが…
>私としては、メンバ関数分だけメモリを食う、クラスのコピーが遅くなる、といいた点で心配なのですが実際のところどうなのでしょうか?
メンバ関数が増えたところで、上記は変わらないハズです。
# メンバ変数が増えれば関係するでしょうが。
MFCのCWndクラスもそれなりのメンバ関数持っているんではないか…と。
大変迅速にご回答いただきまして大変ありがとうございました。
当初心配していた意味でのデメリットは無いことがわかりました。
パフォーマンスが重要ものだったので一応安心しました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
中学のクラス数
-
UMLのクラス図はmain()も含むん...
-
Cstring(日本語含む)をcharに...
-
サーブレットを始めようとした...
-
packageとimport の違いって?
-
CListCtrlクラスに初期化する関...
-
僕の出身中学校は200人同級生が...
-
明示的なserialVersionUIDの意...
-
どこからも呼ばれていない無意...
-
「囲うインスタンス」のエラー...
-
進学校通ってたんですけど、眼...
-
java eclipse 型に解決できません
-
dllと同じプロジェクトにする方法
-
3年間同じクラスになる確率
-
クラス名の「~Factory」って何?
-
ヒグマを撃退
-
エクセルVBAでのwitheventsにつ...
-
IPアドレスの3バイト目の呼び方
-
「タイプ初期化子が例外をスロ...
-
eclipse-Tomcatでのデバッグに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ヒグマを撃退
-
中学のクラス数
-
そんなにお金がなくても年に1度...
-
UMLのクラス図はmain()も含むん...
-
どこからも呼ばれていない無意...
-
java eclipse 型に解決できません
-
配列の重複する値とその個数を...
-
EclipseでJSPのコンパイルエラー
-
僕の出身中学校は200人同級生が...
-
コンボボックスのマウスホイー...
-
main()を持つクラスが2つ以上...
-
Cstring(日本語含む)をcharに...
-
同一パッケージにあるクラスが...
-
IPアドレスのクラスAを取得して...
-
dllと同じプロジェクトにする方法
-
標準モジュールとクラスモジュ...
-
VBAもしくはVB6:クラスの中で...
-
Sub-LVDS規格とは
-
同じクラスにならない確率を教...
-
複数のクラスで共通した関数を...
おすすめ情報