Swift-확장

확장을 사용하여 기존 클래스, 구조 또는 열거 형의 기능을 추가 할 수 있습니다. 유형 기능은 확장으로 추가 할 수 있지만 기능을 재정의하는 것은 확장으로 가능하지 않습니다.

Swift Extension Functionalities

  • 계산 된 속성 및 계산 된 유형 속성 추가
  • 인스턴스 및 유형 메소드 정의.
  • 새로운 이니셜 라이저 제공.
  • 아래 첨자 정의
  • 새 중첩 유형 정의 및 사용
  • 기존 유형을 프로토콜에 맞게 만들기

확장은 키워드 'extension'으로 선언됩니다.

통사론

extension SomeType {
   // new functionality can be added here
}

기존 유형을 확장과 함께 추가하여 프로토콜 표준으로 만들 수도 있으며 구문은 클래스 또는 구조의 구문과 유사합니다.

extension SomeType: SomeProtocol, AnotherProtocol {
   // protocol requirements is described here
}

계산 된 속성

계산 된 '인스턴스'및 '유형'속성은 확장을 사용하여 확장 할 수도 있습니다.

extension Int {
   var add: Int {return self + 100 }
   var sub: Int { return self - 10 }
   var mul: Int { return self * 10 }
   var div: Int { return self / 5 }
}

let addition = 3.add
print("Addition is \(addition)")

let subtraction = 120.sub
print("Subtraction is \(subtraction)")

let multiplication = 39.mul
print("Multiplication is \(multiplication)")

let division = 55.div
print("Division is \(division)")

let mix = 30.add + 34.sub
print("Mixed Type is \(mix)")

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

Addition is 103
Subtraction is 110
Multiplication is 390
Division is 11
Mixed Type is 154

이니셜 라이저

Swift 4는 확장을 통해 기존 유형에 새 이니셜 라이저를 추가 할 수있는 유연성을 제공합니다. 사용자는 이미 정의 된 유형을 확장하기 위해 자신의 사용자 정의 유형을 추가 할 수 있으며 추가 초기화 옵션도 가능합니다. 확장은 init () 만 지원합니다. deinit ()는 확장에서 지원되지 않습니다.

struct sum {
   var num1 = 100, num2 = 200
}

struct diff {
   var no1 = 200, no2 = 100
}

struct mult {
   var a = sum()
   var b = diff()
}

let calc = mult()
print ("Inside mult block \(calc.a.num1, calc.a.num2)")
print("Inside mult block \(calc.b.no1, calc.b.no2)")

let memcalc = mult(a: sum(num1: 300, num2: 500),b: diff(no1: 300, no2: 100))
print("Inside mult block \(memcalc.a.num1, memcalc.a.num2)")
print("Inside mult block \(memcalc.b.no1, memcalc.b.no2)")

extension mult {
   init(x: sum, y: diff) {
      let X = x.num1 + x.num2
      let Y = y.no1 + y.no2
   }
}

let a = sum(num1: 100, num2: 200)
print("Inside Sum Block:\( a.num1, a.num2)")

let b = diff(no1: 200, no2: 100)
print("Inside Diff Block: \(b.no1, b.no2)")

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

Inside mult block (100, 200)
Inside mult block (200, 100)
Inside mult block (300, 500)
Inside mult block (300, 100)
Inside Sum Block:(100, 200)
Inside Diff Block: (200, 100)

행동 양식

확장을 사용하여 새로운 인스턴스 메서드와 형식 메서드를 하위 클래스에 추가 할 수 있습니다.

extension Int {
   func topics(summation: () -> ()) {
      for _ in 0..<self {
         summation()
      }
   }
}

4.topics(summation: {
   print("Inside Extensions Block")
})

3.topics(summation: {
   print("Inside Type Casting Block")
})

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

Inside Extensions Block
Inside Extensions Block
Inside Extensions Block
Inside Extensions Block
Inside Type Casting Block
Inside Type Casting Block
Inside Type Casting Block

topic () 함수는 '(summation : () → ())'유형의 인수를 사용하여 함수가 인수를 취하지 않으며 값을 반환하지 않음을 나타냅니다. 해당 함수를 여러 번 호출하기 위해 for 블록이 초기화되고 topic () 메서드에 대한 호출이 초기화됩니다.

인스턴스 메서드 변경

인스턴스 메서드는 확장으로 선언 될 때 변경 될 수도 있습니다.

self 또는 해당 속성을 수정하는 구조 및 열거 메서드는 원래 구현의 변경 메서드와 마찬가지로 인스턴스 메서드를 mutating으로 표시해야합니다.

extension Double {
   mutating func square() {
      let pi = 3.1415
      self = pi * self * self
   }
}

var Trial1 = 3.3
Trial1.square()
print("Area of circle is: \(Trial1)")

var Trial2 = 5.8
Trial2.square()
print("Area of circle is: \(Trial2)")

var Trial3 = 120.3
Trial3.square()
print("Area of circle is: \(Trial3)")

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

Area of circle is: 34.210935
Area of circle is: 105.68006
Area of circle is: 45464.070735

아래 첨자

이미 선언 된 인스턴스에 새 첨자를 추가하는 것도 확장을 통해 가능합니다.

extension Int {
   subscript(var multtable: Int) -> Int {
      var no1 = 1
      while multtable > 0 {
         no1 *= 10
         --multtable
      }
      return (self / no1) % 10
   }
}

print(12[0])
print(7869[1])
print(786543[2])

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

2
6
5

중첩 유형

클래스, 구조 및 열거 형 인스턴스의 중첩 유형은 확장을 사용하여 확장 할 수도 있습니다.

extension Int {
   enum calc {
      case add
      case sub
      case mult
      case div
      case anything
   }
   var print: calc {
      switch self {
         case 0:
            return .add
         case 1:
            return .sub
         case 2:
            return .mult
         case 3:
            return .div
         default:
            return .anything
      }
   }
}

func result(numb: [Int]) {
   for i in numb {
      switch i.print {
         case .add:
            print(" 10 ")
         case .sub:
            print(" 20 ")
         case .mult:
            print(" 30 ")
         case .div:
            print(" 40 ")
         default:
            print(" 50 ")
      }
   }
}
result(numb: [0, 1, 2, 3, 4, 7])

Playground를 사용하여 위의 프로그램을 실행하면 다음과 같은 결과를 얻습니다.

10
20
30
40
50
50