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'로 선언되기 때문에 프로그램은 하위 클래스를 더 이상 만들 수 없으며 오류가 발생합니다.