プログラム再構成に関する 特申請について.pptVIP

プログラム再構成に関する 特申請について.ppt

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
プログラム再構成に関する 特申請について

オブジェクト指向 プログラミング 第六回 知能情報学部 新田直也 インデントについて(再掲) Javaの標準のインデントに従おう. public static void main(String[] args) { int x, y; x = 4; y = fact(x); System.out.println(4! = + y); } public static int fact(int a) { if (a == 1) { return 1; } return a * fact(a - 1); } 行の 先頭 を揃 える 中括弧開くは 行の末尾に 再帰関数を使った階乗の実装 階乗を求める関数 fact() 再帰を使って実装する. public static void main(String[] args) { int x, y; y = fact(4); System.out.println(4! = + y); y = fact(5); System.out.println(5! = + y); y = fact(6); System.out.println(6! = + y); } public static int fact(int a) { if (a == 1) { return 1; } return a * fact(a - 1); } 呼び出し 呼び出し 呼び出し 呼び出し(再帰) 内部処理(実装)の変更 factの内部の処理を変えてみる. public static void main(String[] args) { int x, y; y = fact(4); System.out.println(4! = + y); y = fact(5); System.out.println(5! = + y); y = fact(6); System.out.println(6! = + y); } public static int fact(int a) { int x, b = 1; for (x = 1; x = a; x++) { b = b * x; } return b; } 呼び出し側は 一行も変えていない 呼び出し側は 内部の処理を 知らなくてよい (情報隠蔽) 内部の処理を 書き換え 情報隠蔽の効用 再利用が容易になる. 何度も同じようなコードを書かなくて済む.(効率化) 何度もテスト&デバッグしなくて済む.(高信頼化) 作業を分担できる.(分業化) 変更が必要となったときに修正箇所を局所化できる. (変更の局所化,可変性の向上) データ構造の情報隠蔽(1/4) 処理(アルゴリズム)の隠蔽 関数を用いる. データ構造の隠蔽 構造体を用いる. 配列を使ったリストの例: struct List { int values[1000]; int size; } データ構造 データ構造の情報隠蔽(2/4) 構造体変数を引数に渡したり戻り値で返したりすることで情報隠蔽を行う. main() { int v; struct List *l; l = create(); add(l, 11); add(l, 22); v = get(l, 1); } struct List* create() { return malloc(sizeof(struct List)); } void add(struct List *l, int v) { l-values[l-size] = v; l-size++; } List構造体の 内部構造を知らなくてよい List構造体の 内部構造を知っている データ構造の情報隠蔽(3/4) オブジェクト指向(Java)でそれっぽく書いてみる. List構造体は,JavaではListクラスに相当する. Listクラスを新規に作成する. public class List { int values[] = new int[1000]; int size; } データ構造(List構造体とまったく同じ) データ構造の情報隠蔽(4/4) オブジェクト指向(Java)でそれっぽく書いてみる. Listクラスを使うプログラムを書いてみる. Listクラスの 内部構造を知らなくてよい Listクラスの 内部構造を知っている public static void main(String[] args) { List l = new List(); add(l, 11); add(l, 22); int v = get(l, 1); System.out.printl

文档评论(0)

book1986 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档