목록iOS (53)
develop
class final final 키워드가 있는 class는 다른 class에서 상속받지 못한다. final class Animal { var name = "" } class Dog: Animal { } Inheritance from a final class 'Animal' 이렇게 컴파일 에러가 난다. 클래스를 다른 클래스에 상속 받으면 안되는 경우에 사용할 수 있다. method final final 키워드가 있는 method는 class에서 상속받을떄 해당 method를 override하지 못한다. class Animal { final func bite() { } } class Dog: Animal { override func bite() { print("개가 뭅니다.") } } 메서드에 final을 ..
equatable equatable은 비교를 할수 있게 해주는 프로토콜이며기본적인 데이터 타입들도 적용이 되어있다. extension String : Equatable { /// Returns a Boolean value indicating whether two values are equal. /// /// Equality is the inverse of inequality. For any values `a` and `b`, /// `a == b` implies that `a != b` is `false`. /// /// - Parameters: /// - lhs: A value to compare. /// - rhs: Another value to compare. public static func ==..
OptionSet은 enum과 비슷하지만 차이점이 둘 이상을 결합할 수 있다. 코드를 짤때 자주 OptionSet을 사용을 하는데 예를들어 UIBezierPath나 String의 range메서드에서 볼수 있다. UIBezierPath의 생성자중 init(roundedRect: CGRect, byRoundingCorners: UIRectCorner, cornerRadii: CGSize) 생성자가 있는데 byRoundingCorners를 받는다. UIBezierPath( roundedRect: .zero, byRoundingCorners: UIRectCorner.topLeft, cornerRadii: CGSize(width: 1.0, height: 1.0)) topLeft, topRight, bottomLe..
접근 한정자라고 한다. class나 struct, enum, extension, method에 접근 한정자를 붙여 모듈 외부에서 사용할 수 있거나 클래스 내부에서만 사용하게 할 수 있다. 접근한정자의 종류는 open, public, internal, fileprivate, private 이 있다. open 가장 열려있는 접근 한정자이고 전체적으로는 public과 유사하지만 타모듈에서 만들어진 class의 접근한정자가 open 이면 상속을 할수 있다. 타모듈에서 만들어진 method의 접근한정자가 open이면 override를 할수 있다. 같은 모듈에서는 public이나 internal과 동일하다. public 다른 모듈의 public 로 된 클래스를 상속할려고 하면 Cannot inherit from n..
코드를 만들다 보면 많은 곳 에서 where을 사용하고 있다. where를 사용하는 곳을 정리해보자 for let array: [Int] = [1, 2, 3, 5, 7, 12, 24, 130] for element in array where element%2 == 0 { print(element) } 2 12 24 130 for문에 where을 추가해서 원하는 값만 동작하게 할수 있다. switch case enum NetworkType { case success case suspend case error(code: Int) var result: Bool { switch self { case .success: return true case .suspend: return false case .error(l..
let array: [Int] = [1, 2, 3, 5, 7, 12, 24, 130] for (index, element) in array.enumerated() { print("index: \(index), element: \(element)") } 고차함수 라고 한다. 일반적으로 array에 있는 값들을 출력을 할때 아래와 같은 코드로 하게 된다. Swift에서 index를 알고 싶으면 아래와 같은 코드로 하게 된다. let array: [Int] = [1, 2, 3, 5, 7, 12, 24, 130] for element in array { print(element) } forEach 위의 코드를 forEach 고차함수로 적용하면 아래와 같은 코드가 된다. array.forEach({ print($..
AutoLayout FirstItem AutoLayout가 적용된 첫번째 컨텐츠이다. SecondItem AutoLayout가 적용된 두번째 컨텐츠이다. 고정값으로 준 Width나 Height같이 컨텐츠의 연결이 필요없는 오토레이아웃은 SecondItem이 필요없다. Relation Greater Than or Equal (같거나 클수 있다), Less Than or Equal (같거나 작을수 있다), Equal(같다) 를 적용할수 있다. 예를들어 superView에 view를 넣고 상하좌우에 constant를 0만 주었을때는 view가 superView의 크기를 따라가는데Relation을 주면 view의 컨텐츠의 길이가 superView의 크기보다 크지 않을때까지 view의 컨텐츠 크기를 따라가다가 s..
blocking vs non-blocking blocking class Network { var isLoading = false func blocking() -> Bool { print("start date: \(Date().timeIntervalSince1970)") sleep(1) print("end date: \(Date().timeIntervalSince1970)") return true } } class Example { init() { let network = Network() let result = network.blocking() print("complete \(result) date: \(Date().timeIntervalSince1970)") } } start date: 15442499..
세마포어를 사용하기 전에 세마포어가 왜 생겼는지 알아보자 하나의 자원에 접근할 때 동시에 여러 쓰레드에서 그 하나의 자원에 접근한다면? var array = [Int]() DispatchQueue.global().async { for element in 0...1000 { array.append(element) } } DispatchQueue.global().async { for element in 0...1000 { array.append(element) } } malloc: *** error for object 0x10b4d6cb0: pointer being freed was not allocated malloc: *** set a breakpoint in malloc_error_break to de..
연관 타입이라고 한다. protocol ExampleProtocol { var value: Int { get } } 위와 같은 프로토콜이 있다고 가정해 보자 코드에서 이 프로토콜을 공통적으로 사용을 하는데 value가 String이 필요한 화면이 있다. 그래서 하나 더 만들면 protocol ExampleProtocol2 { var value: String { get } } 그러다가 value가 Int와 String 둘다 받을 수 있게 되었다. 그러면 value를 어디서든 사용할수 있게 타입을 AnyObject로 해보자 protocol ExampleProtocol { var value: AnyObject { get } } class Example: ExampleProtocol { var value: An..
convenience는 편의 생성자라고 한다. 기존에 구현 했던 init을 수정하지 않고 custom한 init을 사용할 수 있다. 사용 방법은 init앞에 convenience을 붙인다. 그리고 convenience로 구현한 init은 동일한 클래스에서 다른 init을 호출하여야 한다. 그렇지 않으면 아래와 같은 에러가 나타나게 된다. 'self.init' isn't called on all paths before returning from initializer class SuperClass { let name: String let age: Int init(name: String, age: Int) { self.name = name self.age = age } init(name: String) { s..
App LifeCycle 앱은 항상 5가지 상태중의 하나에 있다. Not Running: 앱이 실행되지 않은 상태 Inactive: 앱이 실행중인상태지만 이벤트없음 Active: 앱이 실행중이며 이벤트가 발생 Background: 앱이 백그라운드에 있지만 실행되는 코드가 있음 Suspened: 앱이 백그라운드에 있고 실행되는 코드가 없음 5가지의 상태 들의 이벤트를 관리하는 곳이 UIApplicationDelegate 프로토콜이다. Launch: 앱이 실행되지 않은 상태에서 비활성 또는 백그라운드 상태로 전환된다. func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication...
ARC(Automatic Reference Counting) 클래스의 인스턴스를 만들고 참조할 때 ARC가 인스턴스에 대한 정보를 메모리에 할당한다. 프로퍼티, 상수, 변수에 레퍼런스가 지정되면 카운트가 올라가고 해제되면 내려가고 0이되면 해제한다. 자동 레퍼런트 카운터는 더 이상 사용되지 않는 시점을 결정하여 메모리를 해제한다. 메모리가 제대로 해지되지 않는 경우가 있다. 순환참조 두 클래스 인스턴스의 프로퍼티가 서로를 강한 참조할 경우 class Example1 { deinit { print("deinit Example1") } var example2: Example2! } class Example2 { deinit { print("deinit Example2") } var examle1: Examp..
함수에서 클로져를 쓸 때 보통 아래와 같이 쓴다. func example(_ handler: (() -> Void)) { } func example(_ handler: ((Int) -> Int)) { } 이렇게 함수에 클로져를 쓰다보면 아래와 같은 에러가 나올때가 있다. 물론 에러를 누르고 fix를 하면 자동으로 클로져에 @escaping 가 붙는다. escaping는 탈출한다는 뜻이고 클로져가 함수를 탈출할 때 붙는다. noescape는 함수를 탈출하지 않을때 사용되며 생략한다. 즉, 그냥 클로져를 사용하면 noescape로 된다. 클로져가 함수를 탈출하는 상황은 두가지가 있다. 비동기 실행: 클로저가 비동기로 실행되면 클로저를 잡고 있어야한다. 저장소: 클로저를 변수나 프로퍼티에 저장할 때. 비동기 ..