기본 콘텐츠로 건너뛰기

[루비] 루비 관련 전자책(HTML/PDF) 링크

source: http://jhrogue.blogspot.kr/2013/01/blog-post_26.html

루비 프로그래밍 언어는 간결하면서도 표현력이 막강한 객체지향형 스크립트 언어로 松本行弘가 1995년에 만들었다. 웹 개발을 위한 오픈 소스 프레임워크인 루비 온 레일즈에 이어 최근에는 시스템 관리 부문의 오픈 소스에서도 많이 사용되면서 인기를 끌고 있으므로 다들 관심이 많을 것이다. 오늘은 오라일리의 'The Ruby Programming Language'의 한국어판인 '루비 프로그래밍 언어'를 소개하고, 부록으로 참고할만한 다른 전자책 링크를 정리해보겠다.

프로그래밍 언어 서적의 마술사인 데이비드 플래너건과 루비의 창시자인 유키히로 마츠모토가 공동으로 집필했기에 기대치가 상당히 높았다. 아니나 다를까 인터넷에서 살펴본 다른 전자책과는 달리 루비 프로그래밍 언어의 철학과 동작 원리를 꼼꼼하게 설명하려고 노력한 결과 루비 프로그래밍 언어에 대한 미묘한 부분까지도 짚고 넘어간다(1.8과 1.9의 차이점에 대해서도 상당히 세부적으로 파고든다). 하지만 기존 스크립트 형식의 프로그래밍 언어(특히 파이썬이나 펄)에 익숙한 개발자이거나 함수형 언어를 이해하는 개발자에게는 좋은 친구로 다가올지 몰라도, 처음으로 스크립트 언어를 배우는 사람이 읽기에는 구성이나 설명 방식이 절대 만만하지 않다. 오라일리 책의 공통적인 특성인 코드 조각 내기로 인해 뭔가를 따라서 진행하고픈 초보자들에게도 장벽은 높기 마련이다. 하지만 손쉬운 지침서만 읽어서는 독학으로 알아내기 어려운 여러 가지 루비 언어의 특성을 설명하고 있기에 일단 쉬운 책부터 한 권 독파하고 이 책으로 넘어오면 어떨까 하는 생각이 들었다.

목차를 보면 '소개' 부분이 나오고 차례로 프로그램 구조/실행 방법, 데이터형/객체, 표현식/연산자, 문장/제어구문, 메서드/proc/lambda/클로저, 클래스/모듈, 리플렉션/메타프로그래밍, 루비 플랫폼, 루비 환경 순서로 설명이 전개된다. 문제는 프로그래밍 서적의 일반적인 특성(?)인 딱딱한 구성으로 인해 마치 K&R의 "The C Programming Language"를 독파하는 각오로 책을 읽어야 한다는 데 있다. 실제 프로그래밍을 배우는 좋은 방법으로 '부딪혀보기'가 있는데, 이 책으로 '부딪히'다가는 온 몸에 멍이 들지도 모른다는 걱정을 해본다(몸이 근질거린다면 뒤에 소개하는 전자책 링크를 먼저 따라가보자.). 게다가 함수형 언어 등에서 아주 유용하게 나오는 개념과 최신 프로그래밍 이론에서 나오는 개념들이 돌직구처럼 던져지므로 절반을 넘기는 지점부터는 상당히 괴로울지도 모르겠다. 루비 자체가 파이썬보다 학습 곡선이 무척 가파르다는 사실을 감안하더라도 책이 다소 어렵게 전개된다는 느낌을 지울 수 없다. 물론 이 책을 다 읽고 나서도 루비스럽게 코드를 작성할 때까지는 상당한 연습과 노력이 필요하다.

번역 상태는 프로그래밍 서적을 번역하면 생기는 동일한 문제가 그대로 등장한다(이 부분은 누가 하더라도 풀기 어렵다). 즉, 읽어도 이해가 잘 안가는 부분이 많으므로 한번 더 읽을 셈치고 일단 읽고 넘어가는 편이 정신 건강에 이로울 테다. 그래도 잘 이해가 가지 않으면 원서도 참고하고 루비 공식 문서도 살펴보고 직접 프로그램도 짜면서 머리가 아니라 몸으로 느끼기 바란다.

애독자 여러분을 위해 읽을만한 루비 관련 전자책(HTML/PDF) 링크를 정리해보았다. 모두 영어라서 부담이 있긴 하지만... 온라인에서 무료로 읽고 예제도 (Copy & Paste로) 바로 실행해볼 수 있다는 장점이 있으므로 필요에 따라 골라서 읽어보기 바란다.

  • 루비 공식 문서: 루비 프로그래밍 과정에서 반드시 참조해야 하는 필수 사이트!
  • Programming Ruby The Pragmatic Programmer's Guide: The Pragmatic 시리즈로 나온 루비 프로그래밍 서적. 간결하면서도 빠짐없다.(난이도: 중하)
  • The Book of Ruby: 전형적인 No Starch 책(난이도: 중).
  • The Little Book of Ruby: 사례 중심의 루비 기본서(난이도: 중하). The Book of Ruby의 경량 버전
  • Poignant Guide to Ruby: 이야기식으로 루비 프로그래밍 기법을 전개(난이도: 중). 문화적인 차이로 인해 영어권 유머에 익숙하지 않는 분들께는 권장하지 않음
  • Ruby User's Guide: 깊이가 얕은 대신 넓은 주제를 사례 중심으로 소개(난이도: 하)
  • Humble Little Ruby Book: 짧고 빠르게 루비를 독파하고픈 사람에게 추천(난이도: 중)
  • The Bastards Book of Ruby: 시원시원한 그림을 곁들여 유머러스하면서도 정곡을 찌르는 내용을 제공(난이도: 중상)
  • Ruby Essentials: 예제 중심으로 쉽게 설명한 루비 입문자용 문서(난이도: 하)
  • Ruby Best Practices: 루비스런 코드를 작성하기 위한 우수 사례 소개(난이도: 최상)


자, 루비 세상으로 출발할 준비가 끝났는가? 즐거운 여행 되시기를 바란다. :)

EOB

댓글

이 블로그의 인기 게시물

[인코딩] MS949부터 유니코드까지

UHC = Unified Hangul Code = 통합형 한글 코드 = ks_c_5601-1987 이는 MS사가 기존 한글 2,350자밖에 지원하지 않던 KS X 1001이라는 한국 산업 표준 문자세트를 확장해 만든 것으로, 원래 문자세트의 기존 내용은 보존한 상태로 앞뒤에 부족한 부분을 채워넣었다. (따라서 KS X 1001에 대한 하위 호환성을 가짐) 그럼, cp949는 무엇일까? cp949는 본래 코드 페이지(code page)라는 뜻이라 문자세트라 생각하기 십상이지만, 실제로는 인코딩 방식이다. 즉, MS사가 만든 "확장 완성형 한글 ( 공식명칭 ks_c_5601-1987 ) "이라는 문자세트를 인코딩하는 MS사 만의 방식인 셈이다. cp949 인코딩은 표준 인코딩이 아니라, 인터넷 상의 문자 송수신에 사용되지는 않는다. 하지만, "확장 완성형 한글" 자체가 "완성형 한글"에 대한 하위 호환성을 고려해 고안됐듯, cp949는 euc-kr에 대해 (하위) 호환성을 가진다. 즉 cp949는 euc-kr을 포괄한다. 따라서, 윈도우즈에서 작성되어 cp949로 인코딩 되어있는 한글 문서들(txt, jsp 등등)은 사실, euc-kr 인코딩 방식으로 인터넷 전송이 가능하다. 아니, euc-kr로 전송해야만 한다.(UTF-8 인코딩도 있는데 이것은 엄밀히 말해서 한국어 인코딩은 아니고 전세계의 모든 문자들을 한꺼번에 인코딩하는 것이므로 euc-kr이 한국어 문자세트를 인코딩할 수 있는 유일한 방식임은 변하지 않는 사실이다.) 물론 이를 받아보는 사람도 euc-kr로 디코딩을 해야만 문자가 깨지지 않을 것이다. KS X 1001을 인코딩하는 표준 방식은 euc-kr이며 인터넷 상에서 사용 가능하며, 또한 인터넷상에서 문자를 송수신할때만 사용.(로컬하드에 저장하는데 사용하는 인코딩방식으로는 쓰이지 않는 듯하나, *nix계열의 운영체제에서는 LANG을 euc-kr로 설정 가능하기도 한걸

[linux] 뻔하지 않은 파일 퍼미션(file permissions) 끄적임. 정말 속속들이 아니?

1. [특수w]내 명의의 디렉토리라면 제아무리 루트가 만든 파일에 rwxrwxrwx 퍼미션이라 할지라도 맘대로 지울 수 있다. 즉 내 폴더안의 파일은 뭐든 지울 수 있다. 2. [일반rx]하지만 읽기와 쓰기는 other의 권한을 따른다. 3.[일반rwx]단 남의 계정 폴더는 그 폴더의 퍼미션을 따른다. 4.[일반]만약 굳이 sudo로 내 소유로 파일을 넣어놓더라도 달라지는건 없고, 단지 그 폴더의 other퍼미션에 write권한이 있으면 파일을 만들고 삭제할 수 있다. 5.디렉토리의 r권한은 내부의 파일이름 정도만 볼 수있다. 하지만 ls 명령의 경우 소유자, 그룹, 파일크기 등의 정보를 보는 명령어므로 정상적인 실행은 불가능하고, 부분적으로 실행됨. frank@localhost:/export/frankdir$ ls rootdir/ ls: cannot access rootdir/root: 허가 거부 ls: cannot access rootdir/fa: 허가 거부 fa  root #이처럼 속한 파일(폴더)만 딸랑 보여준다. frank@localhost:/export/frankdir$ ls -al rootdir/ # al옵션이 모두 물음표 처리된다.. ls: cannot access rootdir/root: 허가 거부 ls: cannot access rootdir/..: 허가 거부 ls: cannot access rootdir/.: 허가 거부 ls: cannot access rootdir/fa: 허가 거부 합계 0 d????????? ? ? ? ?             ? . d????????? ? ? ? ?             ? .. -????????? ? ? ? ?             ? fa -????????? ? ? ? ?             ? root 하지만 웃긴건, r에는 읽기 기능이 가능하므로 그 폴더 안으로 cd가 되는 x권한이 없더라도 어떤 파일이 있는지 목록 정도는 알 수 있다. 하지만 r이라고

[hooking, 후킹, 훅킹] Hooking이란?

source: http://jinhokwon.blogspot.kr/2013/01/hooking.html Hooking 이란? [출처] http://blog.daum.net/guyya/2444691 훅킹(Hooking)이란 이미 작성되어 있는 코드의 특정 지점을 가로채서 동작 방식에 변화를 주는 일체의 기술 이다. 훅이란 낚시바늘같은 갈고리 모양을 가지는데 여기서는 코드의 중간 부분을 낚아채는 도구라는 뜻으로 사용된다. 대상 코드의 소스를 수정하지 않고 원하는 동작을 하도록 해야 하므로 기술적으로 어렵기도 하고 운영체제의 통상적인 실행 흐름을 조작해야 하므로 때로는 위험하기도 하다. 훅킹을 하는 방법에는 여러 가지가 있는데 과거 도스 시절에 흔히 사용하던 인터럽터 가로채기 기법이나 바로 앞에서 알아본 서브클래싱도 훅킹 기법의 하나라고 할 수 있다. 이외에도 미리 약속된 레지스트리 위치에 훅 DLL의 이름을 적어 주거나 BHO(Browser Helper Object)나 응용 프로그램 고유의 추가 DLL(Add in)을 등록하는 간단한 방법도 있고 PE 파일의 임포트 함수 테이블을 자신의 함수로 변경하기, CreateRemoteThread 함수로 다른 프로세스의 주소 공간에 DLL을 주입(Injection)하는 방법, 메모리의 표준 함수 주소를 덮어 쓰는 꽤 어려운 방법들도 있다. 이런 고급 훅킹 기술은 이 책의 범위를 벗어나므로 여기서는 소개만 하고 다루지는 않기로 한다. 이 절에서 알아볼 메시지 훅은 윈도우로 전달되는 메시지를 가로채는 기법으로 다양한 훅킹 방법중의 하나이다. 메시지 기반의 윈도우즈에서는 운영체제와 응용 프로그램, 또는 응용 프로그램 사이나 응용 프로그램 내부의 컨트롤끼리도 많은 메시지들을 주고 받는다. 훅(Hook)이란 메시지가 목표 윈도우로 전달되기 전에 메시지를 가로채는 특수한 프로시저이다. 오고 가는 메시지를 감시하기 위한 일종의 덫(Trap)인 셈인데 일단 응용 프로그램이 훅 프로시저를 설치하면 메시지가 윈도우로 보내지기