Swiftのfuncの引数に出てくるアンダースコアやシャープの意味について調べた
Swiftではfuncでメソッドを定義する。 funcの引数に出てくるアンダースコアやシャープはExternal Parameter Namesという。 これはメソッドの引数をラベル化する場合に使う。Rubyのキーワード引数と似ている。
Swiftでは第二引数以降はラベルを付けて呼び出す必要がある
func join(s1: String, s2: String, joiner: String) -> String { return s1 + joiner + s2 }
join("hello", "world", ":") // => コンパイルエラー join("hello", s2: "world", joiner: ":") // => OK
アンダースコア ( _ ) は、引数が自明でラベルが必要ない場合に使う
// s2の前に_を書くと、 func join(s1: String, _ s2: String, joiner: String = " ") -> String { return s1 + joiner + s2 } join("hello", "world", joiner: ":") // s2はラベル無しでOK
明示的にラベルで指定して欲しい時は、ラベルとして変数の前に外部から参照する文字列を置く
func join(first s1: String, second s2: String, joiner joiner: String) -> String { return s1 + joiner + s2 } join(first: "hello", second: "world", joiner: ":")
シャープ ( # )は上記の外部から見えるラベルと、内部で使うパラメータが同じ名前の場合に簡略化できる
func join(s1: String, #s2: String, #joiner: String) -> String { return s1 + joiner + s2 } join("hello", s2: "world", joiner: ":")
Shorthand External Parameter Names in Swift - Qiita
イニシャライザではデフォルト値が無くてもラベルが必要
class Example { init( counter: Int) { } } var example = Example(counter: 0) //ラベル必須
class Example { init( _ counter: Int) { } } var example = Example(0) //アンダースコアがあるとラベルはいらない
Swiftをターミナルで実行してWebAPIからjsonを取得してみる
Qiitaに投稿した。
Swiftをコマンドラインで実行してWebAPIからjsonを取得する - Qiita
コンパイル型言語なのにRubyのirbのようなREPLモードができて楽しい。
ターミナルでSwiftを起動
$ sudo xcode-select -switch /Applications/Xcode6-Beta.app/Contents/Developer $ xcrun swift
実行したコード
ターミナルにコピペすれば動く。
import Foundation // Thanks to tiqav api! ( http://dev.tiqav.com/ ) var request = NSURLRequest(URL: NSURL(string: "http://api.tiqav.com/search/random.json")) var data = NSURLConnection.sendSynchronousRequest(request, returningResponse: nil, error: nil) var json: NSArray = NSJSONSerialization.JSONObjectWithData(data, options:NSJSONReadingOptions.AllowFragments, error: nil) as NSArray for item: NSDictionary! in json { println(item.objectForKey("source_url")) }
SwiftでAVFoundationを使ったカメラアプリ
Qiitaに投稿した。
SwiftでAVFoundationを使ったカメラアプリのサンプル - Qiita
ViewController.swift
// // ViewController.swift // swift-camera-sample // // Created by Shoken Fujisaki on 6/8/14. // Copyright (c) 2014 Shoken Fujisaki. All rights reserved. // import UIKit import AVFoundation class ViewController: UIViewController { var stillImageOutput: AVCaptureStillImageOutput! var session: AVCaptureSession! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. // Start Camera self.configureCamera() } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } func configureCamera() -> Bool { // init camera device var captureDevice: AVCaptureDevice? var devices: NSArray = AVCaptureDevice.devices() // find back camera for device: AnyObject in devices { if device.position == AVCaptureDevicePosition.Back { captureDevice = device as? AVCaptureDevice } } if captureDevice { // Debug println(captureDevice!.localizedName) println(captureDevice!.modelID) } else { println("Missing Camera") return false } // init device input var error: NSErrorPointer! var deviceInput: AVCaptureInput = AVCaptureDeviceInput.deviceInputWithDevice(captureDevice, error: error) as AVCaptureInput self.stillImageOutput = AVCaptureStillImageOutput() // init session self.session = AVCaptureSession() self.session.sessionPreset = AVCaptureSessionPresetPhoto self.session.addInput(deviceInput as AVCaptureInput) self.session.addOutput(self.stillImageOutput) // layer for preview var previewLayer: AVCaptureVideoPreviewLayer = AVCaptureVideoPreviewLayer.layerWithSession(self.session) as AVCaptureVideoPreviewLayer previewLayer.frame = self.view.bounds self.view.layer.addSublayer(previewLayer) self.session.startRunning() return true } }
SwiftをiOS 7のiPhone 5で動かす
Qiitaに投稿した。 Appleから新しく発表されたプログラミング言語、SwiftはiOS 7で開発できる。 Xcode 6 のダウンロードから始めて、Swiftで書かれたサンプルアプリをiOS 7のiPhone 5 にデプロイ。 サンプルアプリはWantedlyさんがMITライセンスで公開されているSwift RSS Sampleを使わせてもらいました。
iOS Dev Centerへの登録から、Swiftのサンプルアプリを実機iPhoneにデプロイするまでの手順 - Qiita