📚 전체글176 📓 은총알은 없다. (오브젝트 0장) 현대의 '패러다임(paradigm)'이라는 단어는 '한 시대의 사회 전체가 공유하는 이론이나 방법, 문제의식 등의 체계'를 의미한다. 1962년 토마스 쿤은 의 책에서 과학이 단순히 계단식 발전의 형태를 이루는 것이 아니라 새로운 발견이 기존의 과학적 견해를 붕괴시키는 혁명적인 과정을 거쳐 발전해왔다고, 이를 '과학혁명', '패러다임 전환' 이라고 주장했다. 예를 들어 천동설에서 지동설로 변화한 사건처럼 말이다. 이 책(오브젝트)은 절차형 패러다임에서 객체지향 패러다임의 변화를 이야기한다. 하지만 과학혁명과는 다르게 프로그래밍 패러다임은 절차지향 패러다임을 붕괴시키고 객체지향 패러다임이 바뀐 혁명적인 패러다임이 아닌 서로 상호 보완, 발전적인 패러다임을 이야기한다. 객체지향 프로그래밍을 하는 개발자들이 .. 2021. 11. 23. 책 '오브젝트(Object)' 소개 📓 오브젝트 - YES24 역할, 책임, 협력을 향해 객체지향적으로 프로그래밍하라!객체지향으로 향하는 첫걸음은 클래스가 아니라 객체를 바라보는 것에서부터 시작한다. 객체지향으로 향하는 두번째 걸음은 객체를 www.yes24.com 조영호 님의 '객체지향 프로그래밍' 관련된 책은 두 권이 있고 4가지 주제를 이야기한다.(2021년 기준) 객체지향은 클래스 중심이 아닌 객체를 바라보는 것이다. 객체는 독립적인 존재가 아니라 기능 구현을 위해 협력하는 공동체의 존재이다. 객체들에게 적절한 역할과 책임을 부여할 수 있어야 한다. 1,2,3의 내용을 요구사항에 맞게 설계하고 프로그래밍 언어로 담아내야 한다. 책 "오브젝트" 는 4가지 주제 중 3,4번을 이야기한다. 객체에 적절한 역할과 책임을 부여하는 방법과 유연하.. 2021. 11. 23. 📔 타입과 추상화 (객사오 3장) 추상화를 통한 복잡성 극복 과거 지하철 노선도는 실제 지도와 1:1 매칭 되었지만 이해하기 어려웠다. 하지만 해리 벡은 승객이 알아야 할 사실(열차 타는 곳)의 정보만 추상화하여 현실의 복잡성을 단순화했다. 실제 역의 거리와 위치는 달랐지만 목적지와 방향을 쉽게 알 수 있었고 이는 현대의 대표적인 지하철 노선도가 되었다. 객체지향과 추상화 객체지향 패러다임도 마찬가지이다. 객체라는 추상화를 통해 현실의 복잡성을 극복한다. 객체 간의 공통점을 일반화하고, 불필요한 세부 사항을 제거해 단순화한다. 타입 컴퓨터는 0,1 비트로 되어있다. 얼핏 보면 랜덤 한 숫자 같지만 데이터를 목적에 따라 분류하고 타입 시스템이 시작됐다. 1) 어떤 데이터에 어떤 연산자를 적용하느냐에 따라 그 데이터 타입이 결정되고, 2) .. 2021. 11. 21. 📔 이상한 나라의 객체 (객사오 2장) 객체지향이란 단순히 현실 세계 모방이 아니다. 사람은 태어난 지 얼마 안 된 시기부터 물체를 하나의 개념으로 인지하고, 세상을 객체들의 집합으로 바라본다. 객체 지향과 인지 능력 인간은 물리적(e.g. 자동차, 모니터, 과일) 객체뿐만 아니라 추상적인 사물(e.g. 계좌 입금, 출금) 까지도 객체로 인식할 수 있다. 객체지향 패러다임은 인간이 세상을 다양한 객체들의 집합으로 인식하는 것처럼 SW의 세계도 다양한 SW 객체들의 집합으로 모여 있다는 믿음에서 출발한다. 하지만, 객체지향 패러다임의 목적은 현실 세계를 모방하는 것이 아닌, 현실 세계 기반 새로운 세계를 창조하는 것이다. SW 세계의 객체는 현실과 다르게 전등 스스로 불을 끄고 킬 수 있고, 비행기가 사람 없이 스스로 날 수 있다. 객체, 그.. 2021. 11. 18. 유지보수하기 좋은 코드, 앞으로의 수련 🧘🏻♂️ 빠르게 변하는 세상 그리고 유지보수 세상은 빠르게 변한다. 소프트웨어도 그에 맞춰 변해야 한다. 어제 개발한 기능은 오늘 더 이상 쓰지 않을 수 있다. 매일 수많은 기능이 삭제되고 추가된다. 그렇기 때문에 좋은 소프트웨어, 개발자는 빠르게 변화에 대처해야 한다. 빠르게 대처하기 위해선 변화가 오래 걸리면 안 된다. 적은 비용을 들여 코드를 수정, 추가, 삭제해야 한다. 아쉽게도 나는 그런 사람이 아니었다. 적은 비용을 들인 다는 것은 생각하지 못했다. 그동안 했던 프로젝트들은 실제 제품이 아니었고 요구사항이 적확하여 개발이 쉽거나, 큰 규모의 서비스가 아니라 변화가 쉬웠고, 시간 부족으로 기능 개발하는 데 바빴으며, 팀이 작아 의사소통이 편했다. 무엇보다 외부에 보이는 기능은 멀쩡했기 때문에 좋은 코드 .. 2021. 11. 17. 이전 1 ··· 28 29 30 31 32 33 34 ··· 36 다음