'허니몬의 IT 이야기'에 해당되는 글 397건

허니몬의 IT 이야기/프로그래머, '코드 엔지니어'

  잘 만들어진 코드란 요구사항을 정확히 만족하는 코드이다. 그런데 현실에선 요구사항들이 끊임없이 변하기 때문에 만족시키기란 쉽지 않다. 결론적으로 변화하는 요구사항을 안정적으로 잘 동작시키는 코드가 잘 짠 코드라고 말 할 수 있다. 그런 의미에서 객체지향이 관심의 대상이 되고 각광받는 이유는 구조적 프로그래밍으로 대변되는 기존의 방식들에 비해 요구사항을 보다 유연하고 안정적으로 만족시키기 때문이다.


개발하기에 가장 좋은 방법은 수준 높은 개발자들 여럿이서 서로 원하는 수준에서 활발히 커뮤니케이션을 하면서 일하는 것이다. 하지만 우리가 일하는 현실을 돌아보자. 회사 내에서 모든 개발자가 같은 수준에서 개발할 수는 없다. 중급 개발자와 초급 개발자가 똑같은 수준에서 개발을 할 수는 없을 것이다.


통일성이나 수정의 용이성 같은 말은 사실 아주 쉬운 의미이다. 함수들의 공통점을 묶고 나아가 클래스간의 공통점을 묶고 컴포넌트간의 공통점을 묶고 이렇게 잘 묶어서 정리하다보면 그게 바로 객체지향 프로그래밍이고 컴포넌트 프로그래밍이다. 물론 프로그램의 크기가 커질수록 묶는 개념도 커지고 요구사항이나 제품의 방향에 따라 고려해야할 것도 많아지지만 언제나 기본에 충실하라. 공통점 묶기가 객체지향의 초석임을 잊지 말자.


공통점 묶기와 조금만 알기는 객체지향 언어에서 상속, 다형성, 캡슐화보다 더 중요한 개념이다. 공통점을 묶고 조금만 알기 위해 노력하다 보니 상속, 다형성, 캡슐화가 필요하게 되고 더불어 추상화(Abstaction), 일반화(Generalization)라고 세분화(Specialization)도 이루어지는 것이다.

  모든 이론이나 개념은 경험적 발전과 필요에 의해 탄생한 것이고 왜 필요하게 된 것인지를 이해하는 것이 단순히 그 정의와 내용을 공부하는 것보다 훨씬 중요하다. 객체지향의 결정판이라고 알려진 디자인 패턴을 어렵게 느끼는 이유 중 하나는 경험의 산물로 보지 않고 공부해서 익혀야 되는 것으로 인식하기 때문이다. 또 캡슐화에 관해 모든 변수를 반드시 private으로 선언해야 한다는 법이 있는 것은 아니다. 모든 개발자가 어떤 변수는 직접 접근하고 어떤 변수는 접근하면 안된다는 것을 안다면 왜 안되겠는가? 하지만 현실적으로 모두가 똑같은 지식과 레벨에서 개발할 수 없으므로 언어가 이런 점들을 지원해주는 것이다.

  언어는 개발자의 실수를 언어가 최대한 막아주어 생산성을 높이는 방향으로 발전한다는 점을 기억하자.


  모든 클래스는 하나의 책임만을 가진다.


  "이 클래스가 무슨 일을 하는 클래스입니까?" 라는 질문에 "이 클래스는 A라는 일을 합니다." 라고 간단히 대답할 수 있어야 한다. "이 클래스는 맑은 날엔 A라는 일을 하고 비오는 날엔 B라는 일을 하고 안개 낀 날에는 C라는 일을 합니다."라고 대답한다면 클래스의 의미를 정확히 파악할 수 없다. 우리가 클래스를 만드는 이유가 관련된 데이터를 하나로 묶어서 이해하기 쉽도록 하는 것인데 클레스가 너무 많은 책임을 가지면 이해하기가 쉽지 않다. 만약 이렇게 여러가지 책임을 가져야 한다면 클래스를 나눌 것을 강력 추천한다. 객체지향에서 제일 어려운 일 중 하나는 관련된 정보로만 클래스를 구성하는 일이다. 변수 하나, 함수 하나를 넣을 때 "과연 이 기능이 이 클래스에 들어가는 것이 맞을까?"에 대해 고민해야 한다. 클래스 하나가 이일 저일 다하게 되는 신(GOD) 클래스가 된다면 그건 그냥 거대한 코드 덩어리일 뿐 어떠한 방법론의 코드도 아니다.

  클래스는 하나의 책임만을 가진다라는 대명제를 중심에 놓는다면 상속으로 이루어진 클래스 트리 전체는 하나의 책임으로 묶인다고 볼 수 있다. 이런 이유로 Java는 단일 상속만을 지원하지만 부족함이 없는 것이다(Java의 상속은 extends 키워드를 사용한다).


  인터페이스 상속(Java에서는 implements)에 대해 알아보자. 앞서 클래스는 하나의 책임을 가짐과 동시에 상속받는 클래스 트리는 하나의 책임으로 묶여진다고 이야기 했다. 하지만 C++의 다중 상속이나 Java의 인터페이스 구현은 필요하기 때문에 존재하는 것이다. 여기서 혼란이 올 수 있다. 두 클래스에서 상속을 받으면 상속받은 자식 클래스는 두 개의 책임을 지는 것이 되니 하나의 책임을 지는 룰에 위배된다고 생각할 수 있다. 하지만 클래스 상속과 인터페이스 상속은 그 의미가 분명히 다르다. 클래스 상속은 분명 부모와 자식간에 같은 책임을 가지지만 작동하는 형태가 다른 것을 의미한다. 반면 인터페이스 상속기능을 추가하거나 클래스 간의 통신을 하기 위한 방법을 제공한다는 의미이다.

  모든 클래스는 하나의 책임만을 가지고 이런 클래스들이 서로 통신하면서 동작하는 것이 객체지향 프로그래밍이다. 이 때 클래스들이 만나는 방법(사전에서 경계면, 접점으로 표현한 부분)을 인터페이스라고 부른다.   Java에서는 모든 함수가 가상 함수(Virtual Function)로 동작하므로 virtual 키워드를 붙이지 않아도 된다. 어쨌든 Java에서는 class 키워드 대신에 더 의미가 분명한 interface 키워드를 제공한다.


  객체지향에서는 클래스 하나를 작성하는 것보다 클래스 사이의 관계를 작성하는 것이 더 중요하다. 클래스 자체가 문제라면 문제 범위를 클래스로 좁힐 수 있지만 클래스 사이의 관계가 문제가 되면 관련된 모든 클래스의 동작 방식이 문제가 되기 때문이다.


  완전한 클래스와 인터페이스 사이에 있는 개념이 추상 클래스이다. 추상 클래스는 인터페이스 개념을 잘 이해하였다면 쉽게 이해할 수 있다. 추상 클래스는 그 이름에서 알 수 있듯이 클래스의 한 종류이다. 하지만 클래스 전체를 다 구현하지 않고 자식 클래스에서 구현의 일부를 위임하기 때문에 실제(Concrete) 클래스라고 부르지 않고 추상(Abstract) 클래스라고 부르는 것이다. Java에서는 추상 클래스를 위한 키워드로 abstract라는 키워드를 지원하여 의미를 더욱 분명히 하였다. 엄밀히 따지면 인터페이스를 작성할 때 구현을 하지 않는 것을 원칙으로 한다. 하지만 인터페이스를 잘 정의하지 못한 상황에서 인터페이스 구현을 하다 보면 자식 클래스들에서 중복으로 구현되는 기능들이 있다. 이런 기능들의 공통점 묶기를 써서 부모 클래스, 즉 인터페이스에 일부 구현하는 경우가 있다. 이 때 java에서는 명백히 인터페이스를 추상 클래스로 변경하도록 컴파일러가 요구한다. 정석대로라면 추상 클래스는 상속 계층에서 책임을 지는 부모 클래스로만 만드는 것이 좋고 인터페이스는 다른 클래스와의 관계만을 기술하므로 구현이 없는 것이 좋다. 하지만 개발을 하다 보면 편의상 인터페이스에 일부 구현을 할 수 있으며 이때는 구현이 있다고 추상 클래스로 보는 것보다는 원래 목적대로 인터페이스로 보는 것이 타당하다.

 

정리

  객체지향 프로그래밍의 기본 단위는 클래스이다. 모든 클래스는 단 하나의 책임을 가지는 것이 좋다. 레고 부품을 조립하는 것처럼 각자의 책임을 가지는 클래스를 우리가 어떻게 조립하는가에 따라 결과물이 달라진다. 객체지향을 통한 재사용의 강력함은 이 분해와 조립에 있다고 할 수 있다. 클래스를 조립할 때 서로 다른 책임의 클래스를 연결하는 방법은 클래스들을 직접적으로 연관시켜서 할 수 있지만 이 방법은 결합도와 복잡도를 증가시키므로 좋은 방법이 아니다. 결합도와 복잡도는 클래스를 연결시켜주는 인터페이스 사용을 통해 낮출 수 있다. 한편 결합도와 복잡도를 낮춘다는 의미는 확장성을 높인다는 의미로 해석할 수 있다. 인터페이스도 클래스 사이를 연결시켜 주는 책임을 가지는 또 다른 클래스의 형태라고 할 수 있다.

이 글은 스프링노트에서 작성되었습니다.

허니몬의 IT 이야기

오페라 브라우저 내에 내장되어 있는 Opera Mail을 오늘 아침 처음 써보게 되는군요. ^^

구글에서 IMAP 방식을 지원하기 때문에 메일주소와 비밀번호만 입력을 해주면 오페라 메일에서 편하게 사용을 할 수가 있게 되어 있군요. +_+) 구글 웹메일을 쓰게 되니까, 굳이 아웃룩이나 선버드 같은 프로그램을 쓸 필요가 없네요. 인터넷이 되는 곳이면 어디서든 쓸 수 있으니까 말이죠. 흐음.... +_+)> 다만 오페라가 메모리를 좀 많이 차지하기는 하네요. 다른 프로그램에 비해서 그런 부분이 조금 있기는 하네요. 그래도 메모리 자체는 충분하니까~ >ㅅ<)/
허니몬의 IT 이야기/리눅스 이야기, 우분투
참고 : http://shapley.pe.kr/18

오페라 10 설치 후 패키지 정보 갱신시 GPG 에러가 발생

아래의 명령어들을 한줄씩 실행시켜 주면 처리가 된다.
gpg --keyserver subkeys.pgp.net --recv F9A2F76A9D1A0061
gpg --export --armor F9A2F76A9D1A0061 | sudo apt-key add -

gpg 설치화면


인증 오류(GPG error) 발생하면 처하시면 될듯.
허니몬의 IT 이야기/리눅스 이야기, 우분투
가볍고 웹표준을 지키는 브라우저로 유명한 오페라(Opera) 10 버전을 설치했습니다. ^^; 우분투에서 firefox는 3.0을 기본으로 내장하고 있으나, 우분투의 firefox는 3.5로 업그레이드가 되지 않습니다. 그래서 별도로 소스를 받아서 실행해야하는 불편함이 있습니다.

  요즘 몇몇 분들이 오페라를 사용하는 모습을 보고서, 저도 우분투에 설치를 해보자 하고 사이트로 갔습니다.
  오페라 사이트 : http://www.opera.com/


  오페라는 사용자에게 필요한 기능들이 합쳐져 있는 웹표준 준수하는 브라우저로서 우수한 성능 때문에 개발자들 사이에서 각광을 받고 있는 브라우저 입니다. ㅡ_-)> 우리나라에서 사용하기에는 약간 문제가 있기는 하겠지만, 외국 사이트나 웹표준 준수사이트에서는 그 우수한 성능을 발휘하는 브라우저로 정평이 나있습니다.

  사이트로 이동해서 Download Opera를 클릭하면 다음 페이지로 이동합니다.


  자동으로 운영체제를 파악해서 다운로드 파일 화면을 보여줍니다. 우분투는 데비안 계열의 리눅스 이기 때문에 .deb(데비안 패키지) 으로 제공을 합니다. 우분투에서는 손쉽게 설치할 수가 있습니다. ^^


  제가 설정을 제대로 하지 못해서 그런지, deb 파일을 그대로 GDebi 설치 프로그램으로 열기를 하면 정상적인 설치가 진행되지 않더군요. 그래서 우선 파일을 저장(다운로드) 한 후에 더블클릭을 해서 설치 프로그램을 실행하는 방식으로 설치를 합니다.


  Opera.deb 파일을 다운받아서 설치를 진행합니다. 아래에 보시는 것처럼 GDebi 패키지 설치프로그램이 실행되고 '패키지 설치(I)'를 클릭하시면 프로그램의 설치가 정상적으로 진행이 됩니다. ^^


설치가 끝난 Opera10 버전의 모습입니다. ㅡ_-)> 비행기가 날렵해보이니 멋지군요. 후훗...


터미널에서 실행하실 때에는
## sudo apt-get install opera
하시면 됩니다. ^^

오페라를 찬찬히 써봐야겠습니다.


허니몬의 IT 이야기/리눅스 이야기, 우분투
이 방법은 그리 추천해드릴 상황이 아닌 것 같습니다. 가급적이면 우분투 64bit desktop 버전을 설치하시길 추천합니다. ^^; 저의 경우에는 9.04 64bit desktop 버전이 네트워크를 정상적으로 인식하지 못하는 문제 때문에 쓰지 못하고 있습니다. 9.10 버전도 마찬가지네요.


출처 : http://www.cyberciti.biz/faq/ubuntu-linux-4gb-ram-limitation-solution/
Ubuntu 4GB Ram Limitation and Solution

Q. I've total 8 GB RAM installed in my dual boot Ubuntu Linux 8.10 (32 bit) version HP workstation. But free -m command only shows 3291 (3G) memory. How do I use 8GB RAM under Ubuntu Linux?

A. You need to install Physical Address Extension (PAE) aware kernel under 32 bit Ubuntu Linux. It is a feature of x86 and x86-64 processors that allows more than 4 Gigabytes of physical memory to be used in 32-bit systems.

Without PAE kernel, you should see something as follows:
$ free -m


Sample output:
                   total       used         free     shared    buffers     cached
Mem:          3291        801       2489              0           95         342
-/+ buffers/cache:      363       2927
Swap:         1906          0         1906

You have two options here as follows:
Option # 1: Use 64 bit Ubuntu Linux

64 bit Linux kernel will take care of 4G or more memory. Just grab latest 64 bit version and install it.
Option #2: Install PAE enabled kernel

Open terminal and type the following command:
$ sudo apt-get update
$ sudo apt-get install linux-headers-server linux-image-server linux-server


Once kernel images installed, just reboot your workstation, type:
$ sudo reboot


After reboot, login into your system and type the following command to verify memory usage:
$ free -m


Sample output:
                   total        used         free     shared    buffers     cached
Mem:          8105       1292       6812              0          38           483
-/+ buffers/cache:       770       7334
Swap:         1906          0          1906


  ㅡ_-);; 오페라를 설치하고 나니까 apt-get update 할 때 공개키 때문에 충돌이 난다!!
  그래서 찾아보고 또 바로 포스팅!!
  GPG Error 처리 : http://ihoney.pe.kr/522
1 ··· 48 49 50 51 52 53 54 ··· 80
블로그 이미지

Email : ihoneymon@gmail.com 안녕하세요, 꿀괴물 입니다. ^^ 멋진 비행을 준비 하는 블로그 입니다. 만능형 인간이 되어 많은 이들에게 인정받고, 즐겁고 행복하게 살기를 간절히 원합니다!! 달콤살벌한 꿀괴물의 좌충우돌 파란만장한 여정을 지켜봐주세요!! ^^

허니몬