Swift-상속
그 이상의 형태를 취하는 능력은 상속으로 정의됩니다. 일반적으로 클래스는 다른 클래스에서 메서드, 속성 및 기능을 상속 할 수 있습니다. 클래스는 하위 클래스와 수퍼 클래스로 더 분류 될 수 있습니다.
Sub Class − 클래스가 다른 클래스의 속성, 메서드 및 함수를 상속 할 때 하위 클래스라고합니다.
Super Class − 다른 클래스를 상속하기위한 속성, 메서드 및 함수를 포함하는 클래스를 수퍼 클래스라고합니다.
Swift 4 클래스는 메서드, 속성, 함수 및 재정의 메서드를 호출하고 액세스하는 슈퍼 클래스를 포함합니다. 또한 속성 관찰자는 속성을 추가하고 저장되거나 계산 된 속성 메서드를 수정하는데도 사용됩니다.
기본 클래스
다른 클래스에서 메서드, 속성 또는 함수를 상속하지 않는 클래스를 '기본 클래스'라고합니다.
class StudDetails {
var stname: String!
var mark1: Int!
var mark2: Int!
var mark3: Int!
init(stname: String, mark1: Int, mark2: Int, mark3: Int) {
self.stname = stname
self.mark1 = mark1
self.mark2 = mark2
self.mark3 = mark3
}
}
let stname = "Swift 4"
let mark1 = 98
let mark2 = 89
let mark3 = 76
print(stname)
print(mark1)
print(mark2)
print(mark3)
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
Swift 4
98
89
76
클래스 이름이 StudDetails 인 클래스는 여기에서 학생 이름을 포함하는 데 사용되는 기본 클래스로 정의되며 세 개의 과목은 mark1, mark2 및 mark3으로 표시됩니다. 'let'키워드는 기본 클래스의 값을 초기화하는 데 사용되며 기본 클래스 값은 '인쇄'기능의 도움으로 놀이터에 표시됩니다.
아강
기존 클래스를 기반으로 새 클래스를 만드는 행위는 '하위 클래스'로 정의됩니다. 하위 클래스는 기본 클래스의 속성, 메서드 및 기능을 상속합니다. 하위 클래스를 정의하려면 ':'이 기본 클래스 이름 앞에 사용됩니다.
class StudDetails {
var mark1: Int;
var mark2: Int;
init(stm1:Int, results stm2:Int) {
mark1 = stm1;
mark2 = stm2;
}
func print() {
print("Mark1:\(mark1), Mark2:\(mark2)")
}
}
class display : StudDetails {
init() {
super.init(stm1: 93, results: 89)
}
}
let marksobtained = display()
marksobtained.print()
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
Mark1:93, Mark2:89
'StudDetails'클래스는 학생 마크가 선언 된 수퍼 클래스로 정의되고 하위 클래스 'display'는 수퍼 클래스에서 마크를 상속하는 데 사용됩니다. 하위 클래스는 학생 표시를 정의하고 print () 메서드를 호출하여 학생 표시를 표시합니다.
재정의
수퍼 클래스 인스턴스, 유형 메소드, 인스턴스, 유형 속성 및 첨자 하위 클래스에 액세스하면 재정의 개념이 제공됩니다. 'override'키워드는 수퍼 클래스에 선언 된 메서드를 재정의하는 데 사용됩니다.
수퍼 클래스 메서드, 속성 및 첨자에 대한 액세스
'super'키워드는 수퍼 클래스에서 선언 된 메서드, 속성 및 아래 첨자에 액세스하기위한 접두사로 사용됩니다.
재정의 | 메서드, 속성 및 아래 첨자에 대한 액세스 |
행동 양식 | super.somemethod () |
속성 | super.someProperty () |
아래 첨자 | super [someIndex] |
재정의하는 메서드
상속 된 인스턴스 및 형식 메서드는 하위 클래스에 정의 된 메서드에 대한 'override'키워드로 재정의 할 수 있습니다. 여기서 print ()는 수퍼 클래스 print ()에 언급 된 유형 속성에 액세스하기 위해 서브 클래스에서 재정의됩니다. 또한 cricket () 수퍼 클래스의 새로운 인스턴스가 'cricinstance'로 생성됩니다.
class cricket {
func print() {
print("Welcome to Swift 4 Super Class")
}
}
class tennis: cricket {
override func print() {
print("Welcome to Swift 4 Sub Class")
}
}
let cricinstance = cricket()
cricinstance.print()
let tennisinstance = tennis()
tennisinstance.print()
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
Welcome to Swift Super Class
Welcome to Swift Sub Class
속성 재정의
상속 된 인스턴스 또는 클래스 속성을 재정 의하여 해당 속성에 대한 고유 한 사용자 지정 getter 및 setter를 제공하거나 재정의 속성이 기본 속성 값이 변경 될 때 관찰 할 수 있도록 속성 관찰자를 추가 할 수 있습니다.
속성 Getter 및 Setter 재정의
Swift 4를 사용하면 사용자가 사용자 정의 getter 및 setter를 제공하여 저장된 속성이든 계산 된 속성이든 상속 된 속성을 재정의 할 수 있습니다. 하위 클래스는 상속 된 속성 이름 및 유형을 알지 못합니다. 따라서 사용자는 수퍼 클래스에 지정된 재정의 속성의 이름과 유형을 하위 클래스에 지정해야합니다.
이것은 두 가지 방법으로 수행 할 수 있습니다.
속성을 재정의하기 위해 setter가 정의되면 사용자는 getter도 정의해야합니다.
상속 된 속성 getter를 수정하지 않으려면 'super.someProperty'구문으로 상속 된 값을 수퍼 클래스에 전달하면됩니다.
class Circle {
var radius = 12.5
var area: String {
return "of rectangle for \(radius) "
}
}
class Rectangle: Circle {
var print = 7
override var area: String {
return super.area + " is now overridden as \(print)"
}
}
let rect = Rectangle()
rect.radius = 25.0
rect.print = 3
print("Radius \(rect.area)")
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
Radius of rectangle for 25.0 is now overridden as 3
속성 관찰자 재정의
상속 된 속성에 대해 새 속성을 추가해야하는 경우 Swift 4에 'property overriding'개념이 도입되었습니다. 상속 된 속성 값이 변경되면 사용자에게 알립니다. 그러나 상속 된 상수 저장 속성 및 상속 된 읽기 전용 계산 속성에는 재정의가 적용되지 않습니다.
class Circle {
var radius = 12.5
var area: String {
return "of rectangle for \(radius) "
}
}
class Rectangle: Circle {
var print = 7
override var area: String {
return super.area + " is now overridden as \(print)"
}
}
let rect = Rectangle()
rect.radius = 25.0
rect.print = 3
print("Radius \(rect.area)")
class Square: Rectangle {
override var radius: Double {
didSet {
print = Int(radius/5.0)+1
}
}
}
let sq = Square()
sq.radius = 100.0
print("Radius \(sq.area)")
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
Radius of rectangle for 25.0 is now overridden as 3
Radius of rectangle for 100.0 is now overridden as 21
재정의 방지를위한 최종 속성
사용자가 다른 사람이 수퍼 클래스 메서드, 속성 또는 첨자에 액세스하는 것을 원하지 않을 때 Swift 4는 재정의를 방지하기 위해 '최종'속성을 도입합니다. 'final'속성이 선언되면 첨자는 수퍼 클래스 메서드, 속성 및 해당 첨자를 재정의 할 수 없습니다. '슈퍼 클래스'에 '최종'속성을 갖는 조항은 없습니다. 'final'속성이 선언되면 사용자는 추가 하위 클래스를 만들 수 있도록 제한됩니다.
final class Circle {
final var radius = 12.5
var area: String {
return "of rectangle for \(radius) "
}
}
class Rectangle: Circle {
var print = 7
override var area: String {
return super.area + " is now overridden as \(print)"
}
}
let rect = Rectangle()
rect.radius = 25.0
rect.print = 3
print("Radius \(rect.area)")
class Square: Rectangle {
override var radius: Double {
didSet {
print = Int(radius/5.0)+1
}
}
}
let sq = Square()
sq.radius = 100.0
print("Radius \(sq.area)")
Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.
<stdin>:14:18: error: var overrides a 'final' var
override var area: String {
^
<stdin>:7:9: note: overridden declaration is here
var area: String {
^
<stdin>:12:11: error: inheritance from a final class 'Circle'
class Rectangle: Circle {
^
<stdin>:25:14: error: var overrides a 'final' var
override var radius: Double {
^
<stdin>:6:14: note: overridden declaration is here
final var radius = 12.5
수퍼 클래스가 'final'로 선언되고 데이터 유형도 'final'로 선언되기 때문에 프로그램은 하위 클래스를 더 이상 만들 수 없으며 오류가 발생합니다.