[iOS] @IBOutlet, @IBAction

corncheese·2021년 7월 28일
0

iOS

목록 보기
4/10
post-custom-banner

아울렛 변수와 액션함수란?

스토리보드에 추가한 객체를 선택하고 내용을 변경하거나 / 특정 동작을 수행하도록 하기 위해서는 해당 객체에 접근할 수 있는 변수아울렛 변수
동작을 정의액션 함수가 필요하다.

예를 들어 스토리보드에 텍스트 필드를 추가하고, 사용자가 텍스트 필드에 이름을 입력하도록 하려면 텍스트필드를 받아 저장할 변수를 만들고, 변수와 텍스트필드를 연결시켜 줘야 한다.
이때 텍스트필드와 연결될 변수를 아울렛 변수(Outlet Variable)이라고 한다.

그리고 send 버튼을 입력하여 레이블에 출력하는 함수를 만들고 이 함수를 버튼과 연결 시켜줘야 한다. 이러한 함수를 액션 함수(Action Function)라고 한다.

1. 아웃렛 변수 OUtlet Variable

아웃렛변수를 추가하는 방법은 스토리보드에서 객체를 선택하고 마우스의 오른쪽버튼을 누른 후 그래그하면 오른쪽과 같은 @IBOutlet~형식의 소스가 생긴다.
이때 이 소스의 의미를 알아보자!

  1. @IOutlet :
    IB는 Interface Builder의 약자로, @IB로 시작되는 변수나 함수는 인터페이스 빌더와 관련된 변수나 함수라는 것을 의미한다.
    @IBOutlet은 객체를 소스 코드에서 참조하기 위해 사용하는 키워드이며 주로 색상, 크기, 모양, 선의 두께, 텍스트 내용 등 객체의 속성을 제어하는 데 사용한다.

  2. var playPause:
    변수를 선언하는 var뒤에 아웃렛 변수의 이름을 입력하여 변수를 선언한다.

  3. UIButton! :
    선언하고자 하는 변수의 타입을 나타낸다. 버튼 객체에 대한 변수 선언을 하므로 UIButton 클래스 타입을 선택했다. 여기서 UI는 User Interface를 의미한다.

  4. storage - Strong / weak :
    아웃렛 변수를 추가할때 Strong과 Weak 둘 중에서 선택하게 된다. 이 두 가지는 메모리 회수 정책을 나타내는 키워드이다.
    일반적으로 객체를 참조하기 위한 아웃렛 변수는 strong을 사용한다. Xcode에서도 strong을 기본값으로 선택하게 되어있다.
    Weak로 아웃렛 변수를 선언하면 변수정의 앞에 weak가 추가되지만 Strong을 선택하면 아무런 키워드도 추가되지 않는다.

    Strong으로 선언된 변수는 다른 곳에서 참조하고 있을 경우 메모리에서 제거되지 않지만, Weak로 선언된 변수는 다른 곳에서 참조하고 있더라도 시스템이 임의적으로 메모리에서 제거 할 수 있다.

    * 왜 두가지 메모리 회수 정책을 사용할까?
    메모리 관리 이슈때문이다.
    strong으로 선언된 변수들끼리 상호 참조하는 일이 생길 경우에는 앱이 종료되기 전까지는 메모리에서 제거되지 않기 때문에 메모리 누수가 발생한다.
    이 경우 어느 한 변수 또는 모든 변수를 weak로 지정하면 시스템에서 임의로 제거할 수 있으므로 상호 참조할 때에도 사용하지 않을 경우에는 메모리가 삭제될 수 있다.

2. 액션 함수 Action Function

액션 함수도 마찬가지로 동작을 정의하고 싶은 객체를 선택한 후 마우스의 오른쪽버튼을 누른 후 그래그하면 오른쪽과 같은 @IBAction ~형식의 소스가 생긴다.

  1. @IBAction :
    @IBAction으로 정의된 함수를 액션 함수라 부른다.
    버튼을 누르거나, 피커가 선택되는 등, 특정 객체에서 원하는 이벤트가 발생했을 때 정해진 작업을 실행하기 위해 사용한다.

  2. func sliderValueControl :
    함수를 선언하는 func 뒤에 액션 함수의 이름 bthSend를 입력하여 액션 함수를 선언한다.

  3. (_ sender: UISlider):
    액션 함수가 실행되도록 이벤트를 보내는 객체, 여기서는 slider객체에 이벤트가 발생했을 때 해당 액션 함수를 실행시킬 것이므로 UISlider 클래스 타입을 선택한다.

post-custom-banner

0개의 댓글