일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- rxjava cold observable
- 2022 플러터 안드로이드 스튜디오
- jvm이란
- android ar 개발
- 안드로이드 유닛 테스트
- 안드로이드 라이선스
- 안드로이드 유닛테스트란
- 멤버변수
- 스택 자바 코드
- 안드로이드 레트로핏 crud
- 안드로이드 os 구조
- 안드로이드 라이선스 종류
- 큐 자바 코드
- jvm 작동 원리
- 2022 플러터 설치
- 서비스 쓰레드 차이
- ANR이란
- 스택 큐 차이
- 클래스
- rxjava hot observable
- 서비스 vs 쓰레드
- 안드로이드 레트로핏 사용법
- 안드로이드 유닛 테스트 예시
- android retrofit login
- ar vr 차이
- 객체
- Rxjava Observable
- 자바 다형성
- rxjava disposable
- 플러터 설치 2022
- Today
- Total
나만을 위한 블로그
[Android] 콜백이란? 리스너란? 본문
콜백(callback)의 사전적 정의는 답신 전화, (컴퓨터나 전화 사용자의) 회신, 재통보, 회수라는 뜻이 있다.
그럼 안드로이드에서의 콜백은 뭘까?
외국 사이트에서 검색하다 아래와 같은 내용을 찾았다.
https://www.geeksforgeeks.org/asynchronous-synchronous-callbacks-java/
콜백 메서드란 다른 함수에 인수로 전달되는 함수이며, 일종의 이벤트 후에 실행될 것으로 예상된다. 콜백 메서드의 목적은 다른 클래스에서 일부 작업이 완료된 경우 클래스 Sync/Async에 알리는 것이다. 이는 비동기 작업을 할 때 매우 유용하다. 버튼을 누르거나 인터넷에서 데이터를 가져온 후 일부 작업을 수행하거나, 컨텐츠를 표시하는 등의 일상적인 작업을 수행하려 한다고 가정한다. 콜백 기능을 통해 버튼을 누르면 알림을 받으므로 이벤트 처리에 사용된다. 이 유형의 디자인 패턴은 관찰자 디자인 패턴(Observer design pattern)에 사용된다.
국내 사이트 중 한 곳에선 이렇게 말하고 있다.
콜백 : 이벤트가 발생하면 특정 메서드를 호출해 알려준다(1개)
리스너 : 이벤트가 발생하면 연결된 리스너(핸들러)들에게 이벤트를 전달한다(n개)
콜백을 리스너와 비교하고 콜백은 1개, 리스너는 n개라고 한다.
이 블로그는 좀 더 자세하게 설명해놨다.
http://www.dreamy.pe.kr/zbxe/CodeClip/3768942
일반적인 함수 호출(call)은 호출하는 함수, 호출자와 호출되는 함수, 피호출자로 나눠져서 호출자가 피호출자를 불러 함수의 기능을 수행한다고 한다.
반면 콜백(callback)은 호출(call)을 거꾸로(back) 하는 것이라고 한다. 피호출자가 호출자를 부르는 것이다.
즉, 일반적으로 사용자가 시스템에 임의의 서비스를 호출하는 것이 보편적이다. 처리 루틴은 시스템에 있고 사용자가 해당 루틴을 요청함에 따라 동작이 일어나는 것이다.
이 호출과는 달리 시스템 측에서 이벤트를 발생시켜 이 처리를 해달라고 요청해오는 과정에서 콜백이 사용된다. 일반적인 경우와는 반대인 상황이다.
이러한 콜백의 장점은 특정 조건이 만족됐을 때 지정한 기능을 수행하는 경우, 조건을 확인하기 위해 계속해서 조건을 만족하는지 확인하는 과정 없이 조건이 만족됐을 때 기능을 호출하기 때문에 효율적으로 기능을 수행할 수 있다는 것이다.
비동기로 조건에 대한 작업을 수행할 수 있게 되기 때문이다.
콜백의 장점을 말로만 들으면 잘 모르겠다. 언젠가 실험할 수 있는 기회가 있다면 직접 해보고 이 말의 의미를 확인해야겠다.
그럼 리스너란 무엇일까? 디벨로퍼에선 이벤트 리스너라는 것에 대해 설명하고 있다.
아마 이것이 리스너인 것 같아서 정리한다.
https://developer.android.com/guide/topics/ui/ui-events?hl=ko
이벤트 리스너란 뷰 클래스 안에 있는 일종의 인터페이스로, 이 안에 하나의 콜백 메서드가 들어 있다.
이 메서드는 리스너가 등록된 뷰가 UI 안의 항목과 사용자의 상호작용으로 인해 트리거됐을 때 안드로이드 프레임워크가 호출된다.
이벤트 리스너 인터페이스 안에 포함된 콜백 메서드는 onClick(), onLongClick(), onFocusChange() 등이다.
콜백은 다른 함수에 인수로 들어갈 수 있는 함수인데, 리스너는 이 콜백을 갖고 있는 인터페이스라고 할 수 있겠다.
다른 사이트는 어떻게 설명하고 있을까?
https://okky.kr/article/369831
리스너 : 특정 이벤트를 처리하는 인터페이스, 이벤트 발생 여부를 기다리다가 이벤트 발생시 해당 이벤트에 맞는 처리를 수행하는 객체
이벤트 리스너 : 사용자와 상호작용하는 이벤트 발생 시 안드로이드 프레임워크의 인터페이스를 호출한다. 이 인터페이스를 실체화한 객체에서 이벤트에 맞는 처리를 하는 걸 의미한다.
예를 들어 사용자와의 상호작용 이벤트는 포커스가 변하는 경우, 포커스를 맞추면서 하드웨어 키를 누르는 경우와 터치하는 경우 등이 있다.
안드로이드 프레임워크의 인터페이스는 뷰 클래스에 모두 정의돼 있다.
인터페이스의 실체화는 각 액티비티나 프래그먼트, 다이얼로그 등 UI를 보여주게 될 때 실체화된다.
이벤트 리스너를 넣는 예 : 입력 이벤트 리스너, 드래그 앤 드롭 이벤트, GPS 상태 이벤트, 라디오 그룹의 체크상태 변화를 감지하는 이벤트 등
이라고 설명한다. 댓글 중에는 이벤트 = 몬스터 패턴, 이벤트 리스너 = 공략집 / 이벤트 리스너 = 행동에는 대가가 따른다 등의 내용이 있는데 뭔 소린지.
이 글의 결론 : 볼드 처리 해놓았다.
http://blog.naver.com/PostView.nhn?blogId=2hyoin&logNo=220398943180
버튼을 눌렀을 때 이를 감지하고 이에 맞는 동작을 하게 하려면 리스너 클래스를 만들어 이 클래스가 이벤트 감지 및 알맞은 동작을 하도록 구현하면 된다.
- 리스너 : 특정 이벤트를 처리하는 인터페이스. 추상 메서드인 onTouch()를 받아서 사용하며 이벤트 핸들러라고도 한다.
인터페이스 구현을 위해 별도의 클래스를 하나 더 선언해야 한다. 핸들러는 자신을 등록하는 외부 메서드의 지역변수를 참조하는데, 이 때 외부 지역 변수에 final 지정자(스택을 통한 인수전달)을 반드시 붙여야 한다.
사용자가 어떤 액션을 취할 때마다(버튼 클릭, 키보드 키 입력 등) 메시지가 발생해서 해당 메시지의 핸들러가 미리 정의해둔 행동을 하는 것이 안드로이드의 리스너다.
대략 6가지가 있는데
1. 콜백 메서드 정의
2. 뷰가 리스너 구현
3. 액티비티가 리스너 구현
4. 액티비티가 인터페이스 구현
5. 익명 내부 클래스 사용
6. 익명 내부 클래스의 임시 객체 사용이 있다.
- 콜백 함수 : 이벤트 발생을 감지하기 위한 처리와 해당 이벤트 발생 시 실행할 각각의 처리를 나눠서 코딩하는 곳, 개발자가 해당 함수의 사용을 명령하는 게 아닌 이벤트, 메시지, 알람을 받았을 때 자동으로 실행되는 함수. 대부분 on으로 시작하는 함수들이 콜백 함수다.
- 리스너와 옵저버의 차이)
리스너 : 이벤트 발생 시 사용하는 개념
옵저버 : 변경을 감지하기 위해 사용하는 개념
구현은 둘 다 인터페이스로 하지만 개념 자체가 달라서 확실히 구별해야 한다.
지금까지 공부한 것을 종합해보면 콜백과 리스너란 용어의 뜻이 한번에 와닿진 않는다.
그래도 정리해보자면, 내 생각엔 콜백 메서드란 다른 메서드에 인수로서 전달될 수 있는 함수인 것 같다. 리스너는 이 콜백 메서드를 가진 인터페이스라 할 수 있겠다.
디벨로퍼의 생명주기 문서에도 onStart(), onStop() 등 생명주기 메서드들도 콜백이라고 하니 이것들도 콜백이라 말할 수 있을까? 왜 이것들을 콜백이라 하는지는 더 공부해봐야겠다.
결론 :
- 콜백 메서드는 다른 함수에 인수로 넣을 수 있는 메서드고, 보통 on으로 시작하는 것들이 콜백 함수다. 버튼 클릭 등 이벤트가 발생하면 이에 맞는 작업을 수행하기 위해 코드를 작성하는 곳이다.
- 리스너는 특정 이벤트를 처리하는 인터페이스로, 추상 메서드인 onTouch()를 받아서 실행하며 이벤트 핸들러라고도 한다. 사용자와 상호작용하는 이벤트 발생 시 안드로이드 프레임워크의 인터페이스를 호출한다.
'Android' 카테고리의 다른 글
[Android] 태그란? (0) | 2019.11.25 |
---|---|
[Android] 핸들러란? 루퍼란? (0) | 2019.11.25 |
[Android] 뷰페이저, 카드뷰 사용 위한 implementation 코드 (0) | 2019.11.24 |
[Android] SQLite란? - 1 - (0) | 2019.11.23 |
[Android] 안드로이드 스튜디오 프로젝트 디버그 창에서 SHA-1키 찾기 (0) | 2019.11.16 |