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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

3回答

3934閲覧

SwiftのTableViewの構造を教えて下さい!

contact_ideal_m

総合スコア12

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

2グッド

3クリップ

投稿2015/07/09 10:34

プログラミングを始めてまだ間もないです。なので基礎的な質問ですが、教えてくれる嬉しいです!

lang

1class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource { 2 3 // Tableで使用する配列を設定する 4 private let myItems: NSArray = ["TEST1", "TEST2", "TEST3"] 5 private var myTableView: UITableView! 6 7 override func viewDidLoad() { 8 super.viewDidLoad() 9 10 // Status Barの高さを取得する. 11 let barHeight: CGFloat = UIApplication.sharedApplication().statusBarFrame.size.height 12 13 // Viewの高さと幅を取得する. 14 let displayWidth: CGFloat = self.view.frame.width 15 let displayHeight: CGFloat = self.view.frame.height 16 17 // TableViewの生成する(status barの高さ分ずらして表示). 18 myTableView = UITableView(frame: CGRect(x: 0, y: barHeight, width: displayWidth, height: displayHeight - barHeight)) 19 20 // Cell名の登録をおこなう. 21 myTableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "MyCell") 22 23 // DataSourceの設定をする. 24 myTableView.dataSource = self 25 26 // Delegateを設定する. 27 myTableView.delegate = self 28 29 // Viewに追加する. 30 self.view.addSubview(myTableView) 31 } 32 33 override func didReceiveMemoryWarning() { 34 super.didReceiveMemoryWarning() 35 } 36 37 /* 38 Cellが選択された際に呼び出されるデリゲートメソッド. 39 */ 40 func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { 41 println("Num: \(indexPath.row)") 42 println("Value: \(myItems[indexPath.row])") 43 } 44 45 /* 46 Cellの総数を返すデータソースメソッド. 47 (実装必須) 48 */ 49 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 50 return myItems.count 51 } 52 53 /* 54 Cellに値を設定するデータソースメソッド. 55 (実装必須) 56 */ 57 func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { 58 59 // 再利用するCellを取得する. 60 let cell = tableView.dequeueReusableCellWithIdentifier("MyCell", forIndexPath: indexPath) as! UITableViewCell 61 62 // Cellに値を設定する. 63 cell.textLabel!.text = "\(myItems[indexPath.row])" 64 65 return cell 66 } 67 68} 69

というコードを(https://sites.google.com/a/gclue.jp/swift-docs/ni-yinki100-ios/uikit/006-uitableviewdeteburuwo-biao-shi)から書き写しました。

このコードなのですが、 func tableView(){}というメソッドが3つあるのですが、何故同じ名前のメソッドが3つあるのでしょうか??
この3つはどのような構造になっているのでしょうか??

基本的なクラス構造が分かっていないです。
教えていただけると嬉しいです。

退会済みユーザー👍を押しています

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

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

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

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

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

guest

回答3

0

なぜ同じメソッド名がStripeさんのおっしゃるとおりで引数や返り値が異なる(シグニチャが異なる)と別関数扱いになります。

UITableViewの基本的な動きについてはプログラマーが実装しなくても動くようになっており、カスタマイズできる部分だけ実装すれば良いようになっています。

例えば下記の部分はreturnする値を変えればTableViewの動きが変わりますよね。これはおそらく初期化のときに呼ばれています。

lang

1 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 2 return myItems.count 3 }

下記ではセルが選択されたタイミングで呼び出され、その際の処理を記述することができます

lang

1 func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { 2 println("Num: \(indexPath.row)") 3 println("Value: \(myItems[indexPath.row])") 4 }

このように「どんな部分をカスタマイズできて、そのカスタマイズした部分がどのタイミングで呼ばれるか」を知ることがUITableViewの構造を知るための近道だと思います。

なお、どこをカスタマイズできるのかという指定が

lang

1<UITableViewDelegate, UITableViewDataSource>

のところです。

ここの部分を「プロトコル」というのですが
このプロトコルで指定された特定のメソッドの中身を実装すれば、そこの部分だけプログラマが自由に動きを変えられますよということです。

具体的にどんなメソッドを実装しなければならないかはプロトコルのところ(例えば<UITableViewDelegate>)の部分に「command」を押しながらカーソルを当ててクリックするとUITableViewDelegateの中身を見ることができます。

ここから先はご自身で調べてみてください^^/

投稿2015/07/09 12:58

jollyjoester

総合スコア1585

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

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

0

このコードなのですが、 func tableView(){}というメソッドが3つあるのですが、何故同じ名前のメソッドが3つあるのでしょうか??
この3つはどのような構造になっているのでしょうか??

iOSの画面を作ってるライブラリ(UIKit)のビューは基本的に、ViewとViewDelegateとViewDataSourceという3つの構成になっています

今回の例で言うと、ViewがUITableView、ViewDelegateがUITableViewDelegate、ViewDataSourceがUITableViewDataSourceですね

これらを構成的に分類をすると以下のようになります

クラス
UITableView

プロトコル
UITableViewDelegate
UITableViewDataSource

この関係性を一目で理解できる箇所が書いて頂いたコードのこの部分になるのですが

// DataSourceの設定をする. myTableView.dataSource = self // Delegateを設定する. myTableView.delegate = self

これは主様が作られたUITableViewのUITableViewDelegateとUITableViewDataSourceに対して、テーブルビューのイベントを私に教えて下さい、というお願いをしているわけです

試しにこの部分をコメントアウトすることでテーブルビューに何も表示されなくなることが分かると思います

このコードなのですが、 func tableView(){}というメソッドが3つあるのですが、何故同じ名前のメソッドが3つあるのでしょうか??

これは他の回答者も言ってるようにSwiftのオーバーロードという言語機能のおかげで同じメソッド名のtableView(){}が存在できるわけです。

ただしパラメータの()の中を見ると全部中身が違うので厳密にはこの3つのメソッドはそれぞれ違うという扱いになるんですね

なんでこういう作りになってるかというと、Objective-Cの頃の名残の設計パターンがそのままSwiftにも来てるのと、操作したいViewとイベントのやり取りをしたいときに毎回どうやって表示するかの処理を書かなくてすむように最低限これだけ設定すれば動くよっていうメソッドをプロトコル(Delegate、DataSource)が提供してくれてるわけです

以下の部分ですね

/* Cellが選択された際に呼び出されるデリゲートメソッド. */ func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { println("Num: \(indexPath.row)") println("Value: \(myItems[indexPath.row])") } /* Cellの総数を返すデータソースメソッド. (実装必須) */ func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return myItems.count } /* Cellに値を設定するデータソースメソッド. (実装必須) */ func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { // 再利用するCellを取得する. let cell = tableView.dequeueReusableCellWithIdentifier("MyCell", forIndexPath: indexPath) as! UITableViewCell // Cellに値を設定する. cell.textLabel!.text = "\(myItems[indexPath.row])" return cell }

}

投稿2015/07/10 21:26

__moai

総合スコア264

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

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

0

それは、いわゆるひとつの関数オーバーロードです。
引数のラベルや型がそれぞれ異なるので、それらは異なる関数です。

投稿2015/07/09 11:10

Stripe

総合スコア2183

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問