일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Play2 로 웹 개발
- 스위프트
- 스칼라 강좌
- 파이썬 데이터분석
- 파이썬 동시성
- hyperledger fabric
- 하이브리드앱
- Golang
- 엔터프라이즈 블록체인
- akka 강좌
- 스칼라 동시성
- 파이썬 강좌
- 이더리움
- play 강좌
- 스칼라
- Hyperledger fabric gossip protocol
- 파이썬
- Play2
- 그라파나
- 블록체인
- 파이썬 머신러닝
- 안드로이드 웹뷰
- 플레이프레임워크
- 주키퍼
- Actor
- Adapter 패턴
- 하이퍼레저 패브릭
- CORDA
- Akka
- play2 강좌
- Today
- Total
HAMA 블로그
인터페이스라는 사치 본문
소프웨어 엔니지어링에서 가장 교조주의적인 덕목은 인터페이스를 위시한 유연성,확장성이 아닐까 싶다. (추가적으로 제네릭과 폴리모피즘의 환상 떡칠은 가독성을 최악으로 치닫게 만든다.) 그게 절실히 필요한 코드는 5%나 될까 싶은데 주로 공용 라이브러리겠지.나머지 95%의 코드를 만드는 사람들이 모든 책에 적혀져있는 "확장가능하게 만들어야한다" 를 맹목적으로 받아드리고 있는거 같기도 하며,교조적인 덕목에 따라 혹시 자신은 유연하게 만들지 않았는지에 대한 죄책감이 남아 있을지도 모르겠다. 물론 그 정도 고민을 하는 사람이라면 그것만으로도 훌륭하다고 볼 수 있겠다. 까놓고 말해보자. 자신이 만든 클래스가 100개 있다면, 그 중에 1년 후에 형제 클래스를 만들어야 했던 경우가 얼마나 되었는지. 내 경우는 하나 밖에 없다. 솔직히 말하면 오히려 안쓰던 클래스를 줄였다.일반 응용프로그래밍 작성시 확장성 있게 만들지 않아서 고통받는 코드는 거의 별로 없다. 성능문제와 마찬가지로 확장성이 필요하면 그때 가서 고쳐도 충분한 코드(팀내에서 조율 가능한)가 훨씬 더 많다.짐을 내려 놓아도 된다.
*
특히 대형 솔루션을 만들지 않는 마이크로 서비스 형태의 스타트업이라면 철저하게 빠른 구현 위주로 가야 하며, 뜯어 고치는거 & 더 좋게 새로 만드는 것은 눈감고도 기민하게 해야 한다.즉 비지니스 로직(예를들어 MVC 경우 Controlller 단, Service 단) 따위는 유연성을 따지는 것은 오바고, 다양한 외부인터페이싱이 요구될 가능성이 있는 DB 접속 (예를들어 MVC 경우 Repository단) 같은 경우에도 PostgreSQL 을 사용하다가 InfluxDB 를 추가시 기존에 공통 인터페이스가 없더라도 후딱 만들어 넣어야 한다는 야그~
'소프트웨어 사색 ' 카테고리의 다른 글
왜 커링 (currying) 이 더 좋아? (1) | 2018.03.28 |
---|---|
언어 선택의 기준 (0) | 2018.03.20 |
쓰레스세이프하다? 란 과연 무엇인가? (0) | 2018.03.02 |
블럭체인/비트코인 (1) | 2018.01.31 |
소프트웨어는 유기물 (0) | 2018.01.15 |