詳解Swift改訂版(13)〜クロージャ

2017. 03. 30
この記事は詳解 Swift 改訂版(初版第1刷)を元に、Xcode 8.2.1(Swift 3.0.2)下における差異を記述しています。



CHAPTER 13 クロージャ



●13.1 クロージャの宣言


・クロージャと関数の型

単一引数の関数を定数に代入する例において、引数型を括る () を省略するとエラーが出るようになりました。

let c4: Int -> Double = f2    // error: single argument function types require parentheses

詳解Swift 第3版」の同項によると、Swift 3 でこの記法は廃止されたようです。


・クロージャの複雑な型宣言

クロージャを格納する空配列を変数に代入する例で、本文ではエラーになるとありますが、現在は問題ないようです。

var ca3 = [(Int, Int) -> Double]()
type(of: ca3)    // Array<((Int, Int)) -> Double>.Type



●13.2 変数のキャプチャ


・クロージャが参照型の変数をキャプチャする場合

List13-3 において、「詳解Swift改訂版(03)〜構造体」の「3.3 プロパティ/格納型プロパティの初期値を式で設定する」で述べたように Swift 3 でインクリメント演算子は廃止されており、且つ文字列埋め込みに複合代入演算子を用いた式は使えませんので、関数 makerZ の return 文は以下のように修正することになります。

print("\(s): \(++localvar.value)")    // error: '++' is unavailable: it has been removed in Swift 3

print("\(s): \(localvar.value += 1)")    // エラーや警告は出ないが「m1: ()」など式が反映されない

localvar.value += 1
print("\(s): \(localvar.value)")


・イニシャライザとクロージャ

列挙型 Lot の例において、クロージャ gen への引数としてタプル値を渡すとエラーが出るようになりました。
(「Developers.IO/[iOS][Swift] Swift 3.0の変更点まとめ」の "SE-0029" 参照)

Swift 3 から複数の引数に対して単一のタプル値を渡すことはできなくなったようですが、タプル値を展開して各々の引数に渡すのは問題ありません。

lots.append( gen(t) )    // error: passing 2 arguments to a callee as a single tuple value has been removed in Swift 3

lots.append( gen(t.0, t.1) )



●13.3 クロージャの使い方と記法


・配列の整列

配列の要素を並び替える例において、元配列 list にメソッド sort を指定するとエラーが出るようになりました。
(「Developers.IO/[iOS][Swift] Swift 3.0の変更点まとめ」の "SE-0006" 参照)

Swift 3 からメソッド sort は sorted(by:) に改名されたので修正する必要があります。

let slist = list.sort( { (a:String, b:String) -> Bool in a < b } )    // error: 'sort' has been renamed to 'sorted(by:)'

let slist = list.sorted(by: { (a:String, b:String) -> Bool in a < b } )


・配列要素の選択

List13-6 において、関数 select の引数定義でエラーが出るようになりました。

Swift 3 から関数の型を定義する際に引数を囲む () は省略できなくなったので追加する必要があります。

func select(_ list:[String], _ filter:String->Bool) -> ([String],[String]) {    // error: single argument function types require parentheses

func select(_ list:[String], _ filter:(String)->Bool) -> ([String],[String]) {


・エラーを投げるクロージャ

定数 qux に代入しているクロージャの中で唐突に出てくる XError.Zero はエラーの種類を示す列挙型で、「詳解 Swift 改訂版 サンプルダウンロード」の「samples/Chap13/p316.swift」からコピーすると便利です。

ただし「詳解Swift改訂版(12)〜エラー処理」の「12.1 エラー処理構文/エラーの発生」で述べたように、プロトコル ErrorType は Error に改名されたとエラーが出るので修正する必要があります。

enum XError : ErrorType {    // error: 'ErrorType' has been renamed to 'Error'

enum XError : Error {

また本文中で「Int throws -> Double」と書いても同じとありますが、上記の通り引数を囲む () を省略することはできません。

var syr : (Int) throws -> Double = qux

var syr : Int throws -> Double = qux    // error: single argument function types require parentheses


・rethrow のある関数

List13-7 において、引数の記述でいくつか修正する必要があります。

まず「詳解Swift改訂版(02)〜関数」の「2.1 関数定義の基本/外部引数名」で述べたように、関数の第1引数は自動的に外部引数名となるので呼び出し時に省略したい場合は「_」を追加します。

また inout 引数は「詳解Swift改訂版(02)〜関数」の「2.2 関数定義におけるさまざまな設定/inout 引数」で述べたように、: の後ろに書く、さらに第2引数のクロージャでは上述の通り引数を囲む () を追加します。

func apply(inout arg:[Int], _ map:Int throws -> Int) rethrows {
// 'inout' before a parameter name is not allowed. place it before the parameter type instead
// error: single argument function types require parentheses


func apply(_ arg:inout [Int], _ map:(Int) throws -> Int) rethrows {

XError 型は「詳解 Swift 改訂版 サンプルダウンロード」の「samples/Chap13/List13-7.swift」で定義されています。
(上述の p316.swift のものと同じです)


・配列要素に対する操作

2つ目の配列 dat から複数の条件で新たな文字列配列 str を得る例において、上述の通りメソッド sort は sorted(by:) に改名されたので修正する必要があります。

let str_ = dat.filter{ $0 >= 10 }.sort( < ).map{ "\($0)" }    // error: 'sort' has been renamed to 'sorted(by:)'

let str_ = dat.filter{ $0 >= 10 }.sorted(by: < ).map{ "\($0)" }

またSequeceType プロトコルの reduce メソッドも reduce(_:_:) に改名されたので修正する必要があります。

let sum = numbers.reduce(0, combine:+)    // error: 'reduce(_:combine:)' has been renamed to 'reduce(_:_:)'

let sum = numbers.reduce(0, +)


・関数のカリー化と部分適用

詳解Swift(12)〜クロージャ」の「12.3 クロージャの使い方と記法/関数のカリー化と部分適用」で述べたように、Swift 3 でカリー化関数構文は廃止されました。
(「Developers.IO/[iOS][Swift] Swift 3.0の変更点まとめ」の SE-0002 参照)



●13.4 クロージャと強い参照の循環


・キャプチャによる強い参照

List13-8 において、遅延格納プロパティ daytime と nighttime の定義で引数を囲む () と関数 meter() を呼び出す際の引数ラベル midnight: を追加する必要があります。

lazy var daytime: Int->Int = self.meter(false)    // error: single argument function types require parentheses
// error: missing argument label 'midnight:' in call

lazy var nighttime: Int->Int = self.meter(true)    // error: single argument function types require parentheses
// error: missing argument label 'midnight:' in call


lazy var daytime: (Int)->Int = self.meter(midnight: false)
lazy var nighttime: (Int)->Int = self.meter(midnight: true)

また関数 meter() の定義においても、引数を囲む () を追加する必要があります。

func meter(midnight: Bool) -> (Int -> Int) {    // error: single argument function types require parentheses

func meter(midnight: Bool) -> (Int) -> Int {

それと関数 meter() 内のクロージャ式で、「詳解Swift改訂版(02)〜関数」の「2.2 関数定義におけるさまざまな設定/引数の値を処理中に変更できるようにする」で述べたように、引数 distance に変数 var を指定することはできなくなりましたので、(定数の)引数 dist で受けて 変数 distance に入れ替えるなどの修正をする必要があります。

return { (var distance: Int) in    // error: parameters may not have the 'var' specifier

return { (dist:Int) in
            var distance = dist

実行例においては、C 様式の for 文が使われているので for-in 文に修正します。

for var d = 1000; d <= 5000; d += 1000 {    // error: C-style for statement has been removed in Swift 3

for d in stride(from: 1000, through: 5000, by: 1000) {


・関数の引数にクロージャを渡す場合

最初の例の関数 setFunc() の定義で、離脱する(@escaping)クロージャに(暗黙的に)非離脱パラメータである f を割り当てようとしているとエラーが出るようになりました。

func setFunc(_ f:(Int) -> Int) { theFunc = f }
// error: assigning non-escaping parameter 'f' to an @escaping closure
// note: parameter 'f' is implicitly non-escaping

Qiita/Xcode 8 Release Notes 日本語翻訳メモ(SE-0103)」によると、Swift 3 でクロージャの引数は @noescape の動作がデフォルトとなり、離脱する場合は @escaping で明示することになったようです。

これに関しては「Xcode Release Notes(Xcode 8.0/Swift/New Features)」に、その旨の記述があります。

「クロージャ・パラメータは、@noescape で明示的に注釈をつけるのではなく、デフォルトで非離脱となっています。
クロージャ・パラメータが離脱する場合は @escaping を使用して示します。
@autoclosure(escaping) は現在 @autoclosure @escaping と記述します。
注釈 @noescape と @autoclosure(escaping) は廃止されました。
(
SE-0103)」

また「Developers.IO/[iOS][Swift] Swift 3.0の変更点まとめ(SE-0049)」によると、Swift 3 から @noescape の記述位置がパラメータの属性からパラメータ型の属性に変わったとあり、@escaping も : の後ろに記述することになります。

したがって関数 setFunc() は以下のようになります。

func setFunc(_ f:@escaping (Int) -> Int) { theFunc = f }



Developers.IO/[iOS][Swift] Swift 3.0の変更点まとめ

Qiita/Xcode 8 Release Notes 日本語翻訳メモ

詳解Swift 第3版(Amazon)
 

詳解Swift改訂版(12)〜エラー処理

2017. 03. 08
この記事は詳解 Swift 改訂版(初版第1刷)を元に、Xcode 8.2.1(Swift 3.0.2)下における差異を記述しています。



CHAPTER 12 エラー処理



●12.1 エラー処理構文


・エラーの発生

TicketError 型の定義において、プロトコル ErrorType は Error に改名されたとエラーが出るので修正する必要があります。

enum TicketError : ErrorType {    // error: 'ErrorType' has been renamed to 'Error'

enum TicketError : Error {


・エラーのあるオプショナル型の関数と try? 演算子

List12-3 において、if-let 文で try? 演算子による関数 convInt の判定をした場合、定数 x の標準出力で警告が出ます。

print("x:", x)    // Expression implicitly coerced from 'Int?' to Any

try 演算子であれば定数 x は整数に変換できた場合は Int 型、できなかった場合は nil となりelse 節が実行、空文字列の場合は(上流もなく捕捉されずに)何もしないことになります。

しかし try? 演算子ですと(If-let 文でも)定数 x はオプショナル Int 型になり、整数への変換の成否に関わらず x の print 文が実行されるために警告が出るので、nil 合体演算子で修正すると良いでしょう。

print("x:", x ?? "nil")

空文字列の時はエラーが発生すると(上流に遡って捕捉しようとせず) nil を返すため、else 節が実行され Failure が出力されます。

if-case 文での定数 x は、整数に変換できた場合は Int 型として x の print 文が実行され、できなかった場合はオプショナル nil に、エラーが発生した場合は nil になり else 節が実行されます。



●12.3 アクセス制御


・プロパティのアクセス制御

List12-8 において、サブクラス WebCamera の定義でエラーが出るようになりました。

class WebCamera : USBCamera {
    internal override var focus: Double {    // error: property does not override any property from its superclass
        didSet {
            super.shutterSpeed = ss(super.focus)    // error: 'shutterSpeed' is inaccessible due to 'private' protection level
        }
    }
    internal private(set) override var shutterSpeed: Double {    // error: property does not override any property from its superclass
        get { return super.shutterSpeed }    // error: 'shutterSpeed' is inaccessible due to 'private' protection level
        set { super.shutterSpeed = newValue }    // error: 'shutterSpeed' is inaccessible due to 'private' protection level
    }
    override init() { super.init() }
    override func take() { super.take() }    // error: method does not override any method from its superclass
    private func ss(_ f: Double) -> Double {
        return ( f * f) / 4000.0
    }
}

プロパティやメソッドがオーバーライドできない、または private なのでアクセスできないというものですが、「Qiita/Xcode 8 Release Notes 日本語翻訳メモ」によると、Swift 3 から元々の「private」は「fileprivate」になったようです。

これに関しては「Xcode 8 Release Notes(Xcode 8.0/Swift/New Features)」に、その旨の記述があります。

「private として記された宣言は、宣言されている(基本的に波括弧 {} で囲まれている)レキシカル・スコープ内でしかアクセスすることはできません。
Swift 2 では、ファイルのトップレベルでの private 宣言はそのファイルのどこにでもアクセスすることができました。
以前は private として知られていたアクセスレベルは、現在は fileprivate と呼ばれています。
(
SE-0025)」

つまり定義されたソースファイル内でのみアクセス可能にするには private ではなく fileprivate に、private はクラスや構造体の定義内でのみアクセスする場合に用いると変更されました。

したがってクラス USBCamera およびサブクラス WebCamera の private を fileprivate に変更する必要があります。

class USBCamera {
    fileprivate var focus = 2.0
    fileprivate var shutterSpeed = 1.0 / 1000.0
    fileprivate func take() {
        print("take a picture")
    }
}

class WebCamera : USBCamera {
    internal override var focus: Double {
        didSet {
            super.shutterSpeed = ss(super.focus)
        }
    }
    internal fileprivate(set) override var shutterSpeed: Double {
        get { return super.shutterSpeed }
        set { super.shutterSpeed = newValue }
    }
    override init() { super.init() }
    override func take() { super.take() }
    fileprivate func ss(_ f: Double) -> Double {
        return ( f * f) / 4000.0
    }
}

なお「詳解Swift(8)〜クラスと継承」の「8.5 アクセス制御/プロパティのアクセス制御」で述べたように、プレイグラウンドではこの可視性の実行例を試すことができません。



Qiita/Xcode 8 Release Notes 日本語翻訳メモ

詳解Swift 第3版(Amazon)
 

詳解Swift改訂版(11)〜拡張

2017. 02. 14
この記事は詳解 Swift 改訂版(初版第1刷)を元に、Xcode 8.2.1(Swift 3.0.2)下における差異を記述しています。



CHAPTER 11 拡張



●11.2 拡張定義とプロトコルへの適合


・プロトコルへの適合

List11-4 において、プロトコル FloatLiteralConvertible を指定するとエラーが出るようになりました。

extension Ounce : FloatLiteralConvertible {    // 'FloatLiteralConvertible' is deprecated: renamed to 'ExpressibleByFloatLiteral'

Qiita/Xcode 8 Release Notes 日本語翻訳メモ」によると、Swift 3 で「〜LiteralConvertible」は「ExpressibleBy〜Literal」に改名されたようです。

これに関しては「Xcode 8 Release Notes(Xcode 8.0/Swift/New Features)」に、その旨の記述があります。

「 *LiteralConvertible プロトコルの役割を明確にするため、ExpressibleBy*Literal に改名しました。
これらのプロトコルの要件は変更されていません。
(
SE-0115) 」

したがって拡張定義で適合させるプロトコルは以下のようになります。

extension Ounce : ExpressibleByFloatLiteral {

なお「詳解Swift(11)〜拡張」の「11.2 拡張定義とプロトコルへの適合/プロトコルへの適合」で述べたように、プレイグラウンドでは Sources フォルダに Ounce.swift や Ounce+Ext.swift などのソースファイルを追加して試そうとしても、可視性の問題でうまくいかないのでご注意ください。


・プロトコルに適合するための定義が既に存在する場合

List11-5 において、「詳解Swift改訂版(06)〜パターン」の「6.2 列挙型/シンプルな列挙型」で述べたように、case 節でメンバにアクセスするには「.」が必要になります。

case 秀, 優, 良, 可: return true
// error: enum element '秀' cannot be referenced as an instance member
// error: enum element '優' cannot be referenced as an instance member
// error: enum element '良' cannot be referenced as an instance member
// error: enum element '可' cannot be referenced as an instance member


case .秀, .優, .良, .可: return true

List11-7 において、プロトコル FloatLiteralConvertible を指定するとエラーが出るようになりました。

extension Grade : BooleanType { }    // error: 'BooleanType' has been renamed to 'Bool'

Build Insider/Swift 3.0でなぜ「Cスタイルのforループ」「++/--演算子」などの仕様が廃止されたのか」によると、Swift 3 からBoolean プロトコルは廃止になったようです。

これに関しては「Xcode 8 Release Notes(Xcode 8.0/Swift/New Features)」に、その旨の記述があります。

「Boolean プロトコルは削除されました。
(
SE-0109) 」

エラーメッセージでは Bool に改名されたとありますが、この Bool はプロトコルではなく構造体なので指定することはできません。

extension Grade : Bool { }    // error: inheritance from non-protocol type 'Bool'

(ちなみに「詳解Swift 第3版」のこの項ではプロトコル Equatable を例として解説しています)



●8.3 プロトコル拡張


・既定実装の利用に関する注意

Swift 3.0.2 (Xcode 8.2.1) では、DateType と TimeType 双方のプロトコル拡張で toString() を実装し(List11-12)、且つ Date の拡張定義でも toString() を実装しても動作するようです。

extension Date {
    func toString() -> String {
        return (self as DateType).toString() + ", " + (self as TimeType).toString()
    }
}

print(d.toString())    // 2010. 8. 13, 19:56 (JST)



Qiita/Xcode 8 Release Notes 日本語翻訳メモ

Build Insider/Swift 3.0でなぜ「Cスタイルのforループ」「++/--演算子」などの仕様が廃止されたのか

詳解Swift 第3版(Amazon)
 

詳解Swift改訂版(10)〜プロトコル

2017. 02. 12
この記事は詳解 Swift 改訂版(初版第1刷)を元に、Xcode 8.2.1(Swift 3.0.2)下における差異を記述しています。



CHAPTER 10 プロトコル



●10.2 プロトコルと型


・オプション項目のあるプロトコルを宣言する

プロトコル PersonalData の宣言において、オプション項目である変数 bloodtype と関数 age でエラーが出ます。

optional var bloodtype: String { get }    // error: 'optional' requirements are an Objective-C compatibility feature; add '@objc'
optional func age() -> Int    // error: 'optional' requirements are an Objective-C compatibility feature; add '@objc'

Qiita/Swift変更履歴早見表」によると、Swift 3 でプロトコルの optional 宣言は @objc optional に変更されたようです。

したがって下記のように修正する必要があります。

@objc optional var bloodtype: String { get }
@objc optional func age() -> Int


・プロトコルの使用例

List10-5 において、関数 sayHelloTo() の if-let 文でエラーが出ます。

if let w = p as? HealthInfo where self.sex == w.sex {    // Expected ',' joining parts of a multi-clause condition

これは「詳解Swift改訂版(04)〜オプショナル」の「4.2 オプショナル束縛構文/if-let 文」で説明したように、Swift 3 から条件句は "where" ではなく "," で区切るように変更されたためです。

if let w = p as? HealthInfo, self.sex == w.sex {

if-case 文の場合も同様です。



●10.3 プロトコルと付属型


・ネスト型とプロトコル

List10-6 において、typealias による付属型の宣言で警告が出るようになりました。

typealias Element    // Typealias is missing an assigned type; use 'associatedtype' to define an associated type requirement

これは「詳解Swift(10)〜プロトコル」で説明したように、typealias の代わりに associatedtype を使うように変更されたためです。

したがって付属型の宣言は以下のように修正する必要があります。

associatedtype Element


・付属型が適合するプロトコルを指定

List10-8 において、付属型へのプロトコルの指定でエラーが出るようになりました。

associatedtype Element: IntegerType    // error: 'IntegerType' has been renamed to 'Integer'

プロトコル InteferType は Integer に改名されたようなので修正します。

associatedtype Element: Integer


・付属型の制約を継承する

List10-9 において、上記と同様にプロトコル UnsignedIntegerType は UnsignedInteger に改名されています。

associatedtype Element: UnsignedIntegerType    // error: 'UnsignedIntegerType' has been renamed to 'UnsignedInteger'

associatedtype Element: UnsignedInteger



●10.4 プロトコルに適合する型の定義方法


・プロトコル ForwardIndexType

List10-13 において、プロトコル ForwardIndexType を継承しようとするとエラーが出ます。

enum WeekDay: Int, ForwardIndexType {    // error: 'ForwardIndexType' has been renamed to 'Comparable'

Swift の標準ライブラリ(「Apple Developer Documentation/Swift Standard Library」参照)を見ても ForwardIndexType やそれに類するプロトコルが見当たらないので廃止されたと思われます。

エラーメッセージではプロトコル Comparable に改名されたとありますが、Comaparable のプロトコル要件には(比較)演算子関数しかなく関数 successor() のような関数がありません。

また「詳解Swift改訂版(05)〜基本的なデータ型」の「5.1 整数と実数/範囲型と区間型」の表にあるように、Comparable は区間型と範囲型の両方で採用されていますが、範囲型のみプロトコル Strideable が採用されているので Strideable を継承する必要があると思われます。

プロトコル Strideable の定義(概要)は以下の通りです。

public protocol Strideable : Comparable {
    associatedtype Stride : SignedNumber
    public func distance(to other: Self) -> Self.Stride
    public func advanced(by n: Self.Stride) -> Self
}

Strideable は Comparable を継承し、要件としてインスタンスメソッド distance(to:Self)advanced(by: Self.Stride) を実装する必要があります。
(「Qiita/Swift で Strideable な独自タイプを実装してみる」参照)

enum WeekDay: Int, Strideable {
    case Sun, Mon, Tue, Wed, Thu, Fri, Sat
   
    func distance(to other: WeekDay) -> Int {
        return other.rawValue
    }
   
    func advanced(by n: Int) -> WeekDay {
        return WeekDay(rawValue: (self.rawValue + n) % 7)!
    }

}

プロトコル ForwardIndexType の関数 successor が不要なことはもちろん、Swift 2.2 までの不可解な範囲型 Range が Swift 3 で半開区間型の CountableRange と閉区間型の CountableClosedRange に変更されたので _dummy という要素も不要です。

ただしプロトコル Comparable の要件である比較演算子の定義(List10-10 の関数 <() )は必須です。

なお、型を指定せずに範囲演算子を用いると範囲型になるので、区間型にするには型を指定する必要があります。
(閉区間型も同様)

let wd1 = WeekDay.Sun ..< .Wed
type(of: wd1)    // CountableRange<WeekDay>.Type

let wd2: Range = WeekDay.Mon ..< .Thu
type(of: wd2)    // Range<WeekDay>.Type


・継承のあるクラス定義で Self を使う

List10-14 において、クラス GeoPoint の関数 copy() でプロパティ dynamicType が用いられていますが、「詳解Swift改訂版(08)〜クラスと継承」の「8.1 クラス定義/継承とメソッド呼び出し」で説明したように dynamicType は廃止されて関数 type(of:) に変更されたので修正する必要があります。

let nw = self.dynamicType.init(lat:latitude, lon:longitude)    // '.dynamicType' is deprecated. Use 'type(of:...)' instead

let nw = type(of: self).init(lat:latitude, lon:longitude)



Qiita/Swift変更履歴早見表

Qiita/Swift で Strideable な独自タイプを実装してみる

詳解Swift 第3版(Amazon)
 

詳解Swift改訂版(09)〜メモリ管理

2017. 02. 08
この記事は詳解 Swift 改訂版(初版第1刷)を元に、Xcode 8.2.1(Swift 3.0.2)下における差異を記述しています。



CHAPTER 09 メモリ管理



●9.2 強い参照の循環


・インスタンスが解放できない場合

List9-3 において、クラス Student 内の関数 description の定義でエラーが出ます。

func description: String {    // Expected '->'after function parameter tuple


クラス Student はプロトコル CustomStringConvertible を採用しているため、String 型の変数 description を定義しなければならないのですが、前の版である詳解 Swift では CustomStringConvertible を採用しておらず、String 型を返り値とする関数 description() で同じ機能を実装していたことによる単純なミスです。
したがって関数 description() を変数 description に修正する必要があります。

var description: String {


・弱い参照

最初の実行例において、変数 kaz に nil を代入した後に 弱い参照の変数 who を出力している文で警告が出ます。

print(who)    // Expression implicitly coerced from 'Student?' to Any


これは既に nil になっている変数 who をそのまま出力としているためなので、nil 合体演算子を使用した式などに修正すると良いでしょう。

print(who ?? "nil")



詳解Swift 第3版(Amazon)
 






QuietControl 30 wireless headphones
Calendar
10 | 2017/11 | 12
Sun Mon Tue Wed Thu Fri Sat
- - - 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 - -
Recent Articles
iTunes


Swift
Categories
Tips
Profile

水月杏香

Author:水月杏香
永遠の初心者プログラマ。

Wish List
WACOM


ARC
Technical Q&A
情報プロパティリストキー
Start Developing iOS Apps Today
BOSE

QuietControl 30 wireless headphones
Reference
NSApplicationDelegateプロトコル
NSArrayクラス
NSAutoreleasePoolクラス
NSBundleクラス
NSBundle UIKit追加分
NSCalendarクラス
NSCoderクラス
NSCodingプロトコル
NSCopyingプロトコル
NSDataクラス
NSDateクラス
NSDateFormatterクラス
NSDictionaryクラス
NSEntityDescriptionクラス
NSEnumeratorクラス
NSErrorクラス
NSExceptionクラス
NSFetchRequestクラス
NSFileHandleクラス
NSFileManagerクラス
NSIndexPathクラス
NSIndexPath UIKit追加分
NSKeyedArchiverクラス
NSKeyedUnarchiverクラス
NSKeyValueCodingプロトコル
NSLocaleクラス
NSManagedObjectクラス
NSManagedObjectContextクラス
NSManagedObjectModelクラス
NSMutableArrayクラス
NSMutableCopyingプロトコル
NSMutableDictionaryクラス
NSMutableSetクラス
NSNotificationクラス
NSNotificationCenterクラス
NSNullクラス
NSNumberクラス
NSObjectクラス
NSObject UIKit追加分
NSObjectプロトコル
NSPersistentStoreクラス
NSPersistentStoreCoordinatorクラス
NSPredicateクラス
NSPropertyListSerializationクラス
NSRunLoopクラス
NSSetクラス
NSStringクラス
NSString UIKit追加分
NSTimerクラス
NSTimeZoneクラス
NSURLクラス
NSURLProtectionSpaceクラス
NSURLRequestクラス
NSUserDefaultsクラス
NSValueクラス

UIActionSheetクラス
UIActionSheetDelegateプロトコル
UIActivityIndicatorViewクラス
UIAlertViewクラス
UIAlertViewDelegateプロトコル
UIApplicationクラス
UIApplicationDelegateプロトコル
UIBarButtonItemクラス
UIBarItemクラス
UIButtonクラス
UIColorクラス
UIControlクラス
UIDatePickerクラス
UIDeviceクラス
UIEventクラス
UIFontクラス
UIGestureRecognizerクラス
UIImageクラス
UIImageViewクラス
UIKit Function
UILabelクラス
UINavigationControllerクラス
UINavigationItemクラス
UIPickerViewクラス
UIPickerViewDataSourceプロトコル
UIPickerViewDelegateプロトコル
UIPinchGestureRecognizerクラス
UIResponderクラス
UIScreenクラス
UIScrollViewクラス
UISearchBarクラス
UISearchBarDelegateプロトコル
UISegmentedControlクラス
UISliderクラス
UISwipeGestureRecognizerクラス
UISwitchクラス
UITableViewクラス
UITableViewCellクラス
UITableViewControllerクラス
UITableViewDataSourceプロトコル
UITableViewDelegateプロトコル
UITapGestureRecognizerクラス
UITextFieldクラス
UITextFieldDelegateプロトコル
UITextInputTraitsプロトコル
UITextViewクラス
UITextViewDelegateプロトコル
UIToolbarクラス
UITouchクラス
UIViewクラス
UIViewControllerクラス
UIWebViewクラス
UIWebViewDelegateプロトコル
UIWindowクラス

AVAudioPlayerクラス
AVAudioPlayerDelegateプロトコル

CADisplayLinkクラス
CAEAGLLayerクラス
CALayerクラス

CGAffineTransform
CGBitmapContext
CGColor
CGColorSpace
CGContext
CGGeometry
CGImage
CGPath

EAGLContextクラス
EAGLDrawableプロトコル

Foundation Constants
Foundation Data Types
Foundation Functions

MPMediaItemクラス
MPMediaItemArtworkクラス
MPMediaPlaylistクラス
MPMediaPropertyPredicateクラス
MPMediaQueryクラス
MPMusicPlayerControllerクラス

Randomization Services

System Sound Services
Amazon


OpenGL ES
SQLite
Monthly Archives
Recent Comments
Recent TrackBacks
RSS Link
Visitors
QR Code
QR