일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 클린 코드
- ribs
- clean architecture
- tableView
- ios
- map
- Refactoring
- Clean Code
- 리팩토링
- collectionview
- rxswift
- swift documentation
- Human interface guide
- uiscrollview
- swiftUI
- MVVM
- 스위프트
- 애니메이션
- combine
- UITextView
- Xcode
- Observable
- UICollectionView
- RxCocoa
- 리펙토링
- 리펙터링
- HIG
- SWIFT
- Protocol
- uitableview
- Today
- Total
목록Refactoring (리펙토링) (58)
김종권의 iOS 앱 개발 알아가기
리펙토링 핵심 각 방법들을 '왜' 수행해야 하는지 깨닫고 유연하게 적용하기 문장을 호출한 곳으로 옮기기 한 함수는 한 가지의 일만 해야하는데 두 가지 이상의 일을 하는 경우, 함수 안의 문장을 밖으로 빼내는 작업 함수는 프로그래머가 쌓아 올리는 추상화의 기본 빌딩 블록이지만 추상화의 경계를 항상 올바르게 긋기가 어려움 기능 범위가 달라지면 추상화의 경계도 움직이게 되므로 함수 관점에서 응집도가 높고 한 가지 일만 수행해야하는 함수가 둘 이상의 다른 일을 수행하게 될 수 있으므로 이런 부분들을 리펙토링하는것 반대 리펙토링: 문장을 함수로 옮기기 문장을 호출한 곳으로 옮기기 리펙토링 ex) photo, person 데이터가 있고, 이것을 렌더링하는 함수가 있는 상태 getRecentPhotos(_:)에서도 ..
문장을 함수로 옮기기 함수를 호출하는 쪽에서 항상 그 함수를 호출하기 전이나 후에 동일한 관련 동작을 할 것으로 예상되는 것들은 함수 안으로 이동시키기 함수를 이용하는 관점에서 매번 사용되는 코드를 함수 안으로 이동시킴으로써 코드 중복을 막는게 목적 주의할점은 함수 안으로 이동할 문장이 함수의 일부라는 확신이 있어야함 (한 함수는 하나의 일만 해야지, 응집도가 높은 코드 기대가 가능) 중요한 이유 특정 함수를 호출하는 코드가 나올 때마다 그 앞이나 뒤에서 똑같은 코드가 추가로 실행되면, 그 똑같은 코드를 함수안에 삽입하여 중복 코드를 방지 문장을 함수로 옮기기 예제 ex) 이름을 변경한 후 변경 전과 변경 후의 코드를 출력하는 코드 class ViewController: UIViewController {..
필드 옮기기 데이터구조에서 맥락상 어울리지 않는 필드가 있다면 필드를 옮기는 방법 필드 옮기기가 필요한 배경 프로그램이 상당 부분 동작을 구현하는 코드로 이뤄지지만, 데이터 구조를 잘 활용하면 코드는 자연스럽게 단순하고 직관적으로 변경 데이터 구조를 잘못 선정하면 아귀가 맞지 않는 데이터를 다루기 위한 코드로 범벅되고 데이터 구조파악도 힘들게 됨 현재 데이터 구조가 적절치 않음을 깨닫게 된다면 곧바로 수정이 필요 ex) 필드 옮기기를 수행해야하는 상황 함수에 어떤 레코드를 넘길 때마다 또 다른 레코드의 필드도 넘기고 있는 경우 한 레코드를 변경하려 할 때 다른 레코드의 필드까지 변경해야하는 경우 레코드 뿐만이 아닌 클래스나 객체도 동일 필드 옮기기 리펙토링 ex) 고객(Customer)과 계약정보(Cus..
함수 옮기기 어떤 함수가 자신이 속한 모듈 A의 요소들마다 다른 모듈 B의 요소들을 더 많이 참조하면 모듈 B로 옮겨줘야 좋은데, 이때 함수를 이동시큰 것 '모듈성'을 위해 이동 모듈성이란? 프로그램의 어딘가를 수정하려 할 때 해당 기능과 깊이 관련된 작은 일부만 이해해도 가능하도록 해주는 것 모듈성은 서로 연관된 요소들을 묶고, 요소의 연결관계를 쉽게 찾고 이해할 수 있도록 하는 것 중첩된 함수가 어떻게 보면 은닉화라고 생각할 수 있지만, 중첩되면 그 안에서 숨겨진 데이터끼리 상호 의존하기가 아주 쉬운 구조가 쉬운 형태가 되므로 차라리 중첩하지 않고 바깥으로 빼내고 함수 내부에서는 parameter를 받아서 처리하게끔하는 구조로 구현할것 함수 옮기기 예제 ex) GPS 기록의 총 거리를 계산하는 tra..
위임 숨기기 * swift에서 자주사용하는 delegate와는 다른 개념임을 주의 B안에 C인스턴스가 있고 A가 C에 접근할때, B.C로 접근하지 않고 B에서 C를 리턴하는 메소드를 만들어, 사용하는 쪽에서는 B를 모르게끔 수정하는 방법 (기대효과: 사용하는쪽에서 B를 모르는 상태이므로, B의 코드를 수정할때 사용하는쪽을 신경쓰지 않고 쉽게 수정이 가능) 모듈화 설계의 핵심은 캡슐화이며, 캡슐화는 모듈들이 시스템의 다른 부분에 대해 알아야 할 내용을 줄여주는 것 무언가를 변경해야 할 때 함께 고려해야할 모듈 수가 적어져서 코드 변경이 쉬워짐 반대 리펙토링: 중개자 제거하기 위임 숨기기 예시) 리펙토링 전) 사용하는쪽에서 person.department.manager으로 접근하므로 department가 삭..
클래스 or 구조체 추출하기 * 아래부터 편의상 구조체 추출하기도 클래스 추출하기로 명칭 클래스 안에 일부 property나 메소드를 또다른 클래스로 묶을 수 있다면 따로 그 요소들을 별도의 클래스로 만드는 것 클래스는 데이터가 추가되고, 연산이 추가되다보면 어느새 비대해지는데, 역할이 많을수록 복잡도가 증가하는데 이 것을 클래스 추출하기를 통해 해결이 가능 하나의 클래스에는 하나의 성격만 담도록 코딩하다보면 나중에 변경할때도 다른 사이드 이펙을 고려하지 않고 쉽게 수정이 가능 ex) 구조체 추출하기 struct Person { let officeAreaCode: String let officeNumber: String func getOfficeAreaCode() -> String { officeArea..
레코드란? 데이터를 저장하는것을 의미 대표적인 레코드 표현 구조는 list, dictionary, hash 3가지 캡슐화란? 클라이언트 코드에서(=사용하는쪽) 사용하는 것만 관심있고 내부에서는 어떻게 처리하고 있는지 모르게하는 방법 구현 내용 일부를 "은닉화"한다고도 불림 캡슐화하는 이유? 구현을 숨긴다는것은 클라이언트 코드에서 접근하지 못한다는 의미로, 구현부가 유연하게 변경되어도 클라이언트쪽 코드를 신경쓰지 않아도 되어 곧 개발자는 사용하는쪽을 신경쓰지 않고 구현부 하나만 신경쓸수 있는 장점이 존재 레코드 캡슐화 데이터를 저장하는 부분을 클라이언트 코드쪽에서 모르게끔 하는것 기대효과: 캡슐화되어 있으면 데이터가 변경되어도 클라이언트 코드는 영향이 가지 않기 때문에 더욱 유연한 코딩이 가능 레코드 캡슐..
리펙토링 핵심 각 방법들을 '왜' 수행해야 하는지 깨닫고 유연하게 적용하기 단계 쪼개기 서로 다른 두 대상을 한꺼번에 다루는 코드를 발견하면 각각을 별개 기능으로 나누는 방법 코드를 수정할 때 두 대상을 동시에 생각할 필요 없이 하나에만 집중할 수 있게끔하기 위함 기능이 잘 분리되어 있다면 다른 기능의 상세 내용은 전혀 기억하지 못해도 원하는 대로 수정을 쉽게 접근이 가능 단계 쪼개기 전략 1) 입력을 단순한 형태로 변경 (입력이 처리 로직에 적합하지 않은 형태로 들어오는 경우, 먼저 입력값을 다루기 편한 형태로 가공할것) 2) 처리 로직을 순차적인 단계들로 분리하고 이 단계는 서로 확연히 다른 일을 수행하도록 구현 ex) 단계 쪼개기 전략이 적용된 사례 - 컴파일러 컴파일러는 어떤 코드를 입력받아서, ..