![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
文法を一通り覚えただけの初心者なんですが、自分で100行くらいのちいさなプログラムを組んで、後でそのプログラムをちょっと機能拡張させようとすると、もとのプログラムをだいぶ変えないと機能拡張できない、もしくはプログラムがやばいくらい汚くなりそう・・ってほぼ100%なります。
機能拡張しやすいように心がけてプログラムを書こうと思っても、何を心がけて書けばいいのかわかりません。みなさんは機能拡張性に優れたプログラムを書くとき、どういったことを心がけていますか?
適当な具体例があれば、示してほしいです・・・。もちろんなくてもいいです。いろんな人の考えが聞きたいです。お願いします。
No.3ベストアンサー
- 回答日時:
機能拡張しやすくするには、プログラムの書き方というよりもプログラム全体構造の設計方法が大きく影響すると思います。
ただ、拡張性を考慮した設計というのはとにかく色々書いてみないとつらいと思います。プログラミング面では個人的には機能や処理の意味にあわせて関数やファイルを分割したりですかね。
でも、結局は経験則で色々設計、実装してしまうことが多いです。
また、複数プラットフォームで動くという意味での拡張性を作成しようとするとシステム依存しそうな関数を全部取り替えやすく実装したりですかね。そういうことをすると例えば、windowsでもlinuxでもmacosxでもsolarisでもfreebsdでも動くようなプログラムを書けます。
本で勉強するというのもあります。
「アンチパターン―ソフトウェア危篤患者の救出」
「アナリシスパターン―再利用可能なオブジェクトモデル」
人の書いたプログラムを読むという方法もあります。
「Code Reading―オープンソースから学ぶプログラミングテクニック」
最初から拡張性を考慮しながらプログラムを書きたくなるというのは非常に良いことなので、それを意識しつつ経験を積むとそのうち自動的に拡張性が高いプログラムを書けるようになると思います。
回答ありがとうございます。大変参考になります。
プログラムの設計方法が大きく影響するんですね。
自分は設計はせず、とりあえず書いてみる、ことから初めていました。
設計方法については、学んだほうがいいみたいですね。以前、UMLの本を読んで即挫折した経験があるんですが、基本の設計方法ならたぶんいけますよね・・。
拡張性について、複数プラットフォームで動くという意味での拡張性というのは自分の中ではまったく意識してなかったので、意識するようにします。今の知識、技術ではこの意識をいかしきれないかもしれませんが・・。
やはり、プログラムを書きまくることが一番みたいですね。紹介していただいたおもしろそうな書籍を読みつつ、ひたすらプログラムを書く、そういうふうにやっていきたいとおもいます。
No.6
- 回答日時:
C++なら
JavaやVisualC++のMFC等、完成されたクラス群をみると
その設計思想が参考になると思います。
CというかC++もですが
関数や変数の命名規則を統一する。
これだけで随分コードはみやすくなりますし
整理されたコードは機能拡張がしやすいと思います。
例えばハンガリアン記法とか取り入れると良いと思います。
int iIndex;みたいに
ある程度自分でコードを書いたなら
次にやることは人のソースを見ることです。勉強になります。
他の人のソースやライブラリを自分のソースに融合してみてください。
使いにくかったなら、何故そのライブラリは使いにくいのか
使いやすかったなら、何故使いやすいのか
追求すれば答えはみえてくるでしょう。
回答ありがとうございます。
ハンガリアン記法ですか。調べてみます。
ソースはいくらでも公開してるみたいなので、こちらも調べまくります。
No.5
- 回答日時:
基本的な文法やアルゴリズム、データ構造を身につけたら、こんどはソフトウェアの設計方法論や開発プロセスについて学ぶことをお勧めします。
具体的には、「構造化分析、構造化設計」や「オブジェクト指向分析・設計」などです。ppokaanさんご自身が、プログラムの拡張性で悩まれたのは大変よい体験だったと思います。自分で悩んだ上で先人の知恵を借りると、格段に理解が高くなりますからね!(悩まず教わったことは頭の中を素通りするだけです。)
ppokaanさんがどのプログラミング言語を勉強されたかわかりませんが、C言語なら「構造化分析・設計」を、C++なら「オブジェクト指向分析・設計」の本やウェブサイトを探して読んでみることをお勧めします。先人が如何にして、理解しやすく、拡張性高く設計する方法を考えたか参考になりますよ。
回答ありがとうございます。大変参考になります。
C言語を勉強中なので、構造化分析というキーワードでいろいろ調べてみます。おもしろそうです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- ノートパソコン ソフトアンインストール残存ファイル 3 2022/09/13 18:15
- その他(ブラウザ) Twitterの「返信をさらに表示」 ボタンの後ろに隠れているツイートを常に表示 1 2023/08/04 12:20
- Windows 10 【PC】デュアルディスプレイ利用時に2画面分で最大化できる? 3 2023/03/22 01:45
- その他(ソフトウェア) ダウンロードしたファイルの「種類」が「Windowsmediaplayer」に変わってしまい、開くこ 2 2023/07/03 21:45
- Chrome(クローム) スマホはauのアンドロイドです。 GoogleChromeの拡張機能としてKeepaを使いたいです。 2 2023/04/08 20:08
- Windows 10 拡張子.tibxの開き方 1 2023/06/30 13:01
- ノートパソコン Windows 10 動作改善方法 6 2023/04/26 22:30
- システム 古いWEBシステム。もう追加プログラムは作れない? それともできる? 6 2022/06/08 13:41
- Android(アンドロイド) スマホ chromeの戻るボタンが機能しにくい スマホ(OPPO reno5A、Android12) 1 2022/09/11 20:39
- au(KDDI) ■AU「 スマホトクするプログラム」について 4 2023/08/09 08:54
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Ryzen 3700(無印)はWin11に対応...
-
UNIX環境でのCプログラム上でC...
-
プログラミングに興味がありま...
-
汎用的・将来的なプログラムに...
-
基本情報技術者 午前 リバース...
-
プログラミング言語の覚え方習得法
-
プログラミング言語を習得した...
-
作曲のアプリを作りたいのですが
-
今年の新規開発でVB6を使って...
-
プログラミング言語について御...
-
CGIとは?
-
Vix総合画像ビュアーは動作を...
-
文系大学生ですが応用情報技術...
-
1年無職の彼氏 別れるべきですか?
-
6~7割の正解で、なぜ合格?
-
今職業訓練のパソコン教室行っ...
-
IT業界に勤めていた人の末路は?
-
就職のため、どのプログラミン...
-
全豊田作業責任者
-
個人HPにログイン機能付けられる?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
API、OCX、DLLって何でしょう?
-
VBプログラムをEXCEL VBAに移植...
-
C言語のHP-UXからLinuxへのポ...
-
OSとCPUの関係について
-
コンソールアプリでファイル選...
-
SNMPトラップ情報をC#.netで作...
-
変数の大きさを超える代入
-
WEBページに読み書きするプログ...
-
Perl5とActivePerl
-
UNIX環境でのCプログラム上でC...
-
3ウェイハンドシェイクの流れ...
-
.Net とは何ですか?
-
i,j,k
-
VBS:コンピュータ名を取得し、...
-
DLLってなに?
-
Ryzen 3700(無印)はWin11に対応...
-
CGIとは?
-
プログラミング 素数か素数では...
-
プログラマやシステムエンジニ...
-
このプログラミング誰か教えて...
おすすめ情報