HOME > Detail View

Detail View

(Programming in) Scala : 창시자가 직접 집필한 스칼라 언어의 바이블

Material type
단행본
Personal Author
Odersky, Martin Spoon, Lex, 저 Venners, Bill, 저 오현석, 역 반영록, 역 이동욱, 역
Title Statement
(Programming in) Scala : 창시자가 직접 집필한 스칼라 언어의 바이블 / 마틴 오더스키, 렉스 스푼, 빌 베너스 지음 ; 오현석, 반영록, 이동욱 옮김
Publication, Distribution, etc
서울 :   에이콘,   2021  
Physical Medium
922 p. : 삽화 ; 24 cm
Series Statement
에이콘 프로그래밍 언어 시리즈
Varied Title
Programming in Scala (4th ed.)
기타표제
프로그래밍 인 스칼라
ISBN
9791161754871
General Note
부록: A. 유닉스와 윈도우에서의 스칼라 스크립트 사용 ; B. 용어 해설  
Bibliography, Etc. Note
참고문헌(p.899-902)과 색인수록
Subject Added Entry-Topical Term
프로그래밍 언어[--言語] 컴퓨터 프로그래밍[computer programming]
000 00000cam c2200205 c 4500
001 000046069747
005 20210506151735
007 ta
008 210223s2021 ulka b 001c kor
020 ▼a 9791161754871 ▼g 93000
035 ▼a (KERIS)BIB000015749606
040 ▼a 211009 ▼c 211009 ▼d 211009
041 1 ▼a kor ▼h eng
082 0 4 ▼a 005.133 ▼2 23
085 ▼a 005.133 ▼2 DDCK
090 ▼a 005.133 ▼b S279 2021
100 1 ▼a Odersky, Martin
245 1 0 ▼a (Programming in) Scala : ▼b 창시자가 직접 집필한 스칼라 언어의 바이블 / ▼d 마틴 오더스키, ▼e 렉스 스푼, ▼e 빌 베너스 지음 ; ▼e 오현석, ▼e 반영록, ▼e 이동욱 옮김
246 1 9 ▼a Programming in Scala ▼g (4th ed.)
246 1 3 ▼a 프로그래밍 인 스칼라
260 ▼a 서울 : ▼b 에이콘, ▼c 2021
300 ▼a 922 p. : ▼b 삽화 ; ▼c 24 cm
490 1 0 ▼a 에이콘 프로그래밍 언어 시리즈
500 ▼a 부록: A. 유닉스와 윈도우에서의 스칼라 스크립트 사용 ; B. 용어 해설
504 ▼a 참고문헌(p.899-902)과 색인수록
650 8 ▼a 프로그래밍 언어[--言語]
650 8 ▼a 컴퓨터 프로그래밍[computer programming]
700 1 ▼a Spoon, Lex, ▼e
700 1 ▼a Venners, Bill, ▼e
700 1 ▼a 오현석, ▼e
700 1 ▼a 반영록, ▼e
700 1 ▼a 이동욱, ▼e
830 0 ▼a 에이콘 프로그래밍 언어 시리즈
900 1 0 ▼a 오더스키, 마틴, ▼e
900 1 0 ▼a 스푼, 렉스, ▼e
900 1 0 ▼a 베너스, 빌, ▼e

Holdings Information

No. Location Call Number Accession No. Availability Due Date Make a Reservation Service
No. 1 Location Sejong Academic Information Center/Science & Technology/ Call Number 005.133 S279 2021 Accession No. 151353924 Availability Available Due Date Make a Reservation Service C

Contents information

Book Introduction

스칼라는 여러 함수 언어적 기법과 객체지향 기법이 어우러져 루비나 파이썬 같은 동적 언어 못지않게 간결하면서 풍부한 표현력을 가진 언어다. 스칼라는 빅데이터나 머신러닝 등의 최첨단 분야에 널리 쓰이고 있다. 스칼라를 만든 마틴 오더스키 등이 집필한 이 책은 스칼라의 다양한 측면을 완벽하게 설명한 스칼라 언어의 바이블이다.

이 책은 함수, 트레이트, 암시적 변환, 모듈 등 스칼라의 기본 문법과 컬렉션 사용법, 컬렉션의 내부 구조, 객체지향 및 함수 프로그래밍을 활용하는 방법을 다룬다. 또한 퓨처를 사용한 동시성 프로그래밍, 자바와의 조합, 파싱, GUI 프로그래밍 같은 응용을 설명한 2판의 내용을 수정, 보완했으며, 최신 버전에 맞춰서 문자열 인터폴레이션이나 와일드카드 타입, 변경된 컬렉션 프레임워크에 대한 내용이 추가됐다. 차근차근 따라 하다 보면 숙련된 스칼라 개발자가 될 수 있고, 동시에 다양한 프로그래밍 패러다임을 한 언어에 자연스럽게 녹이는 방법과, 각각을 적재적소에 활용하는 방법을 배울 수 있다.

★ 이 책의 대상 독자 ★

주 대상 독자층은 스칼라로 프로그램을 작성하는 법을 배우고 싶은 프로그래머다. 다음 프로젝트를 스칼라로 진행하고 싶다면 이 책이 바로 당신을 위한 것이다. 또한 새로운 개념을 배워서 생각의 지평을 넓히고 싶은 프로그래머도 재미있게 읽을 수 있을 것이다. 예를 들어, 자바 프로그래머는 이 책을 읽음으로써 다양한 함수형 프로그래밍 개념을 익히고 더 발전된 객체지향 아이디어도 배울 수 있다. 스칼라와 그 아이디어를 배우고 나면 분명 더 나은 프로그래머가 돼 있으리라 믿는다.
독자 여러분이 일반적인 프로그래밍 지식을 갖췄다고 가정한다. 스칼라 자체는 프로그래밍을 처음 배울 때도 적합한 언어이긴 하지만, 이 책이 프로그래밍을 가르쳐주지는 않는다.
하지만 프로그래밍 언어에 대한 선행 지식이 필요하지는 않다. 대부분의 프로그래머가 스칼라를 자바 플랫폼에서 사용하기는 하지만, 독자들이 자바에 대해 알고 있으리라 가정하지는 않는다. 그러나 많은 독자가 자바에 익숙하리라 예상하기 때문에 때때로 자바와 스칼라를 비교해서 자바 개발에 익숙한 독자들의 이해를 도울 것이다

★ 이 책의 구성 ★

1장, '확장 가능한 언어' 스칼라 설계와 그 이유를 설명하고, 배경 역사를 설명한다.
2장, '스칼라 첫걸음' 기초 프로그래밍 과업을 스칼라로 처리하는 방법을 보여준다. 각각이 왜 작동하는지를 자세히 설명하지는 않는다. 2장의 목표는 독자 여러분이 스칼라 코드를 직접 타이핑하고 실행해보게 하는 것이다.
3장, '스칼라 두 번째 걸음' 스칼라에 더 빨리 적응할 수 있도록 기본 프로그래밍 과제를 좀 더 보여준다. 3장을 마치고 나면 간단한 스크립트 작업에 스칼라를 활용할 수 있을 것이다.
4장, '클래스와 객체' 스칼라의 기본 객체지향 빌딩 블록을 자세히 설명하고, 스칼라 애플리케이션을 컴파일하고 실행하는 방법을 보여준다.
5장, '기본 타입과 연산' 스칼라의 기본 타입과 그 리터럴을 설명한다. 그리고 각 타입에 사용할 수 있는 연산과 우선순위 및 결합 법칙을 설명한다. 마지막으로, 풍부한 래퍼(wrapper)에 대해 설명한다.
6장, '함수형 객체' 스칼라의 객체지향적 측면을 더 깊이 파고든다. 변경 불가능한 함수형 유리수(functional rational number)를 예제로 사용한다.
7장, '내장 제어 구문' 스칼라가 제공하는 제어 구조인 if, while, for, try, match를 어떻게 활용할 수 있는지 보여준다.
8장, '함수와 클로저' 함수 언어의 기본 빌딩 블록인 함수에 대해 자세히 설명한다.
9장, '흐름 제어 추상화' 어떻게 독자가 스스로 제어 추상화를 만들어서 스칼라의 기본 제어 구조를 보완할 수 있는지 설명한다.
10장, '상속과 구성' 스칼라가 객체지향 프로그래밍을 어떻게 지원하는지 논의한다. 다루는 주제는 4장만큼 기초적인 부분은 아니지만, 실무에서는 더 자주 부딪치는 부분이다.
11장, '스칼라의 계층구조' 스칼라의 상속 계층을 설명하고, 모든 계층에서 사용할 수 있는 일반적인 메서드와 바닥(최하층) 타입에 대해 설명한다.
12장, '트레이트' 스칼라의 믹스인(mixin) 조합의 메커니즘을 다룬다. 12장에서는 트레이트(trait)가 어떻게 작동하는지를 보여주고, 일반적인 용례를 설명하며 트레이트가 전통적인 다중 상속을 어떻게 향상시키는지 보여준다.
13장, '패키지와 임포트' 대규모 프로그래밍에서 생기는 문제점을 논의한다. 최상위 패키지, 임포트 명령, protected나 private 같은 접근 제어 수식자 등에 대해 설명한다.
14장, '단언문과 테스트' 스칼라의 단언문(assert) 메커니즘을 다루고, 스칼라에서 사용할 수 있는 여러 테스트 도구를 간략히 살펴본다. 특히, 스칼라테스트(ScalaTest)에 초점을 맞춰 설명한다.
15장, '케이스 클래스와 패턴 매치' 캡슐화하지 않은 일반적인 데이터 구조를 작성하도록 지원하는 구성요소 쌍을 소개한다. 특히 케이스 클래스(case class)와 패턴 매치(pattern match)는 트리 구조 같은 재귀적 데이터를 만들 때 유용하다.
16장, '리스트' 스칼라 프로그램에서 가장 일반적으로 사용하는 데이터 구조인 리스트에 대해 자세히 설명한다.
17장, '컬렉션' 리스트, 배열, 튜플(tuple), 집합(set), 맵(map) 같은 기본 스칼라 컬렉션 사용법을 보여준다.
18장, '변경 가능한 객체' 변경 가능한 객체를 설명하고, 스칼라에서 이를 표현하는 방법을 배운다. 18장 뒷부분에서는 변경 가능한 객체를 실제 활용하는 이산 이벤트 시뮬레이션(discrete event simulation)을 다룬다.
19장, '타입 파라미터화' 13장에서 소개한 정보 은닉 기법의 일부를 구체적인 예를 들어 설명한다. 예제는 완전히 함수형인 큐 클래스를 만드는 것이다. 19장에서는 타입 파라미터의 변성(variance)에 대해 설명하고, 변성과 정보 은닉의 관계를 이야기한다.
20장, '추상 멤버' 스칼라가 지원하는 모든 추상 멤버를 설명한다. 메서드뿐 아니라 필드나 타입도 추상 멤버로 정의할 수 있다.
21장, '암시적 변환과 암시적 파라미터' 소스 코드에서 프로그래머가 지겨워할 수 있는 부분을 생략해도 컴파일러가 대신 필요한 내용을 채워 넣도록 돕는 두 가지 요소를 알려준다.
22장, '리스트 구현' List 클래스 구현을 설명한다. 스칼라 리스트가 어떻게 동작하는지 이해하는 일은 중요하다. 더 나아가, 이 구현을 통해 스칼라의 특징 중 몇 가지를 활용하는 방법을 보여주기도 한다.
23장, 'for 표현식 다시 보기' for 표현식을 어떻게 map, flatMap, filter, foreach 등을 호출하는 명령으로 바꿀 수 있는지 보여준다.
24장, '컬렉션 자세히 들여다보기' 스칼라 컬렉션 라이브러리를 자세히 설명한다.
25장, '스칼라 컬렉션의 아키텍처' 컬렉션 라이브러리를 어떻게 만들었는지 보여주고, 독자 여러분이 컬렉션을 직접 구현하는 방법을 설명한다.
26장, '익스트랙터' 케이스 클래스뿐 아니라, 임의의 클래스에 대해 패턴 매치를 어떻게 할 수 있는지 보여준다.
27장, '애노테이션' 애노테이션(annotation)을 통한 언어 확장을 사용하는 방법을 알려준다. 표준 애노테이션에 대해 설명하고, 직접 애노테이션을 만드는 방법도 알아본다.
28장, 'XML 다루기' 스칼라로 XML을 처리하는 방법을 설명한다. XML을 생성하고, 파싱하고, 파싱한 XML을 처리할 수 있는 여러 숙어를 보여준다.
29장, '객체를 사용한 모듈화 프로그래밍' 스칼라의 객체를 모듈 시스템으로 활용하는 방법을 알려준다.
30장, '객체의 동일성' equals 메서드를 작성할 때 고려해야 할 사항을 설명한다. 피해야 할 함정이 몇 가지 있다.
31장, '스칼라와 자바의 결합' 스칼라와 자바를 한 프로젝트에서 함께 사용할 경우 생기는 문제를 논의하고, 그 해결책을 제안한다.
32장, '퓨처와 동시성' 스칼라의 Future 사용법을 보여준다. 자바의 동시성 기본 요소나 라이브러리를 스칼라 프로그램에 활용할 수도 있지만, 퓨처를 사용하면 전통적인 '스레드와 락'을 사용한 접근 방식을 감염시키곤 하는 교착 상태와 경합 조건을 피하는 데 도움이 된다.
33장, '콤비네이터 파싱' 스칼라의 파서 콤비네이터(parser combinator) 라이브러리를 사용해 파서를 만드는 방법을 보여준다.
34장, 'GUI 프로그래밍' 스칼라 라이브러리로 간단한 스윙 GUI 프로그래밍을 하는 과정을 보여준다.
35장, 'SCells 스프레드시트' 지금까지 배운 것을 한데 모아서 스칼라로 완전한 스프레드시트 애플리케이션을 작성한다.


Information Provided By: : Aladin

Author Introduction

마틴 오더스키(지은이)

스칼라 언어의 창시자다. 스위스 로잔 EPFL의 교수이며, 타입세이프 사(Typesafe Inc.)의 공동 창업자다. 프로그래밍 언어와 시스템 분야에서 일해왔으며, 주로 객체지향과 함수형 프로그래밍을 조합하는 분야를 연구해왔다. 2001년 이후, 스칼라를 설계하고 구현하고 다듬는 일에 집중해왔다. 이전에는 자바 제네릭스 설계자의 일원으로 자바 개발에 영향을 미쳤으며, 현재 사용 중인 javac 참조 컴파일러를 맨 처음 작성한 프로그래머다. ACM의 펠로우f(ellow)이기도 하다.

렉스 스푼(지은이)

셈믈(Semmle)의 소프트웨어 엔지니어다. EPFL에서 박사 후 과정(post-doc)으로 2년간 스칼라를 사용했다. 조지아텍(Georgia Tech)에서 전산학 박사학위를 받았으며, 동적 언어에 대한 정적 분석 분야를 전공했다. 렉스는 스칼라와 더불어 다양한 프로그래밍 언어를 사용한 경험이 있다. 스몰토크(SmallTalk) 같은 동적언어부터 로직블록스(LogicBlox)를 뒷받침하는 논리언어인 X10 등을 경험했다. 현재 아내와 함께 애틀랜타에서 고양이 두 마리, 치와와, 거북이와 함께 살고 있다.

빌 베너스(지은이)

아티마 개발자 웹사이트를 출판하는 회사인 아티마(Artima, Inc.)의 회장이며, 에스컬레이트 소프트웨어 유한회사(Escalate Software), LLC.의 공동 창립자다. 「자바월드(JavaWorld)」 잡지에 실리는 그의 유명한 칼럼은 자바 내부, 객체지향 설계, Jini 등을 다룬다. Jini가 태동할 무렵부터 Jini 커뮤니티에서 계속 활동해왔으며 Jini 커뮤니티의 서비스UIServiceUI 프로젝트를 이끌어왔다. 서비스UI는 Jini 서비스에 대한 사용자 인터페이스로 일종의 산업표준처럼 쓰이고 있다. 또한 스칼라와 자바 개발자를 위한 오픈소스 테스트 도구인 스칼라테스트(ScalaTest)의 설계자이자 리드 프로그래머이기도 하다.

오현석(옮긴이)

비사이드소프트(BSIDESOFT) 이사로 일하면서 매일 고객의 요청에 따라 코드를 만들고 있는 현업 개발자다. 어릴 때 처음 접한 컴퓨터에 매혹된 후 경기과학고등학교, KAIST 전산학 학사와 프로그래밍 언어 전공 석사를 취득하며 계속 컴퓨터를 사용해왔다. 직장에서는 주로 코틀린이나 자바를 사용한 서버 프로그래밍을 하고, 주말이나 빈 시간에는 번역을 하거나 공부하면서 즐거움을 찾는다. 시간이 아주 많이 남을 때는 시뮬레이션 게임을 하면서 머리를 식히며, 어떻게 하면 막둥이를 프로그래밍의 세계로 끌어들일 수 있을지 고민 중인 아빠이기도 하다. 『Kotlin in Action』(에이콘, 2017), 『배워서 바로 쓰는 스프링 프레임워크』(한빛미디어, 2020), 『Programming in Scala 4/e』(에이콘, 2021), 『한 권으로 읽는 컴퓨터 구조와 프로그래밍』(책만, 2021) 등 20권 이상의 책을 번역했다.

이동욱(옮긴이)

2009년 스칼라를 우연히 접하고, 스칼라가 제시하는 문제 해결 방법에 매력을 느껴 이를 개발자들과 공유하고자 한국 스칼라 사용자 모임을 개설했다. LG CNS R&D 부문을 거쳤으며, SK Planet의 사내 벤처인 여행 서비스 VOLO의 창립 멤버로 SK techX에서 해당 서비스를 계속 진행하고 있다.

반영록(옮긴이)

뉴욕대(NYU)에서 컴퓨터 사이언스 석사 학위를 받았다. 학부 시절부터 여러 함수형 언어에 관심이 많았고 2012년에 스칼라를 알게 돼 공부하기 시작했으며, 현업에서 애플리케이션 서버 개발에 스칼라를 많이 사용했다. 현재는 카카오에서 기계 번역 연구 및 개발에 참여하고 있다.

Information Provided By: : Aladin

Table of Contents

1장. 확장 가능한 언어
1.1 여러분의 마음에서 점점 자라가는 언어
1.2 스칼라의 확장성이 가능한 이유
1.3 왜 스칼라인가?
1.4 스칼라의 뿌리
1.5 결론

2장. 스칼라 첫걸음
2.1 1단계: 스칼라 인터프리터 사용법을 익히자
2.2 2단계: 변수를 정의해보자
2.3 3단계: 함수를 정의해보자
2.4 4단계: 스칼라 스크립트를 작성해보자
2.5 5단계: while로 루프를 돌고, if로 결정해보자
2.6 6단계: foreach와 for를 사용해 이터레이션해보자
2.7 결론

3장. 스칼라 두 번째 걸음
3.1 7단계: 배열에 타입 파라미터를 지정해보자
3.2 8단계: 리스트를 사용해보자
3.3 9단계: 튜플을 사용해보자
3.4 10단계: 집합과 맵을 써보자
3.5 11단계: 함수형 스타일을 인식하는 법을 배우자
3.6 12단계: 파일의 내용을 줄 단위로 읽자
3.7 결론

4장. 클래스와 객체
4.1 클래스, 필드, 메서드
4.2 세미콜론 추론
4.3 싱글톤 객체
4.4 스칼라 애플리케이션
4.5 App 트레이트
4.6 결론

5장. 기본 타입과 연산
5.1 기본 타입
5.2 리터럴
5.3 문자열 인터폴레이션
5.4 연산자는 메서드다
5.5 산술 연산
5.6 관계 연산과 논리 연산
5.7 비트 연산
5.8 객체 동일성
5.9 연산자 우선순위와 결합 법칙
5.10 풍부한 래퍼
5.11 결론

6장. 함수형 객체
6.1 분수 클래스 명세
6.2 Rational 생성
6.3 toString 메서드 다시 구현하기
6.4 선결 조건 확인
6.5 필드 추가
6.6 자기 참조
6.7 보조 생성자
6.8 비공개 필드와 메서드
6.9 연산자 정의
6.10 스칼라의 식별자
6.11 메서드 오버로드
6.12 암시적 타입 변환
6.13 주의사항
6.14 결론

7장. 내장 제어 구문
7.1 if 표현식
7.2 while 루프
7.3 for 표현식
7.4 try 표현식으로 예외 다루기
7.5 match 표현식
7.6 break와 continue 문 없이 살기
7.7 변수 스코프
7.8 명령형 스타일 코드 리팩토링
7.9 결론

8장. 함수와 클로저
8.1 메서드
8.2 지역 함수
8.3 1급 계층 함수
8.4 간단한 형태의 함수 리터럴
8.5 위치 표시자 문법
8.6 부분 적용한 함수
8.7 클로저
8.8 특별한 형태의 함수 호출
8.9 꼬리 재귀
8.10 결론

9장. 흐름 제어 추상화
9.1 코드 중복 줄이기
9.2 클라이언트 코드 단순하게 만들기
9.3 커링
9.4 새로운 제어 구조 작성
9.5 이름에 의한 호출 파라미터
9.6 결론

10장. 상속과 구성
10.1 2차원 레이아웃 라이브러리
10.2 추상 클래스
10.3 파라미터 없는 메서드 정의
10.4 클래스 확장
10.5 메서드와 필드 오버라이드
10.6 파라미터 필드 정의
10.7 슈퍼클래스의 생성자 호출
10.8 override 수식자 사용
10.9 다형성과 동적 바인딩
10.10 final 멤버 선언
10.11 상속과 구성 사용
10.12 above, beside, toString 구현
10.13 팩토리 객체 정의
10.14 높이와 너비 조절
10.15 한데 모아 시험해보기
10.16 결론

11장. 스칼라의 계층구조
11.1 스칼라의 클래스 계층구조
11.2 여러 기본 클래스를 어떻게 구현했는가?
11.3 바닥에 있는 타입
11.4 자신만의 값 클래스 정의
11.5 결론

12장. 트레이트
12.1 트레이트의 동작 원리
12.2 간결한 인터페이스와 풍부한 인터페이스
12.3 예제: 직사각형 객체
12.4 Ordered 트레이트
12.5 트레이트를 이용해 변경 쌓아 올리기
12.6 왜 다중 상속은 안 되는가?
12.7 트레이트냐 아니냐, 이것이 문제로다
12.8 결론

13장. 패키지와 임포트
13.1 패키지 안에 코드 작성하기
13.2 관련 코드에 간결하게 접근하기
13.3 임포트
13.4 암시적 임포트
13.5 접근 수식자
13.6 패키지 객체
13.7 결론

14장. 단언문과 테스트
14.1 단언문
14.2 스칼라에서 테스트하기
14.3 충분한 정보를 제공하는 실패 보고
14.4 명세로 테스트하기
14.5 프로퍼티 기반 테스트
14.6 테스트 조직과 실행
14.7 결론

15장. 케이스 클래스와 패턴 매치
15.1 간단한 예
15.2 패턴의 종류
15.3 패턴 가드
15.4 패턴 겹침
15.5 봉인된 클래스
15.6 Option 타입
15.7 패턴은 어디에나
15.8 복잡한 예제
15.9 결론

16장 리스트
16.1 리스트 리터럴
16.2 리스트 타입
16.3 리스트 생성
16.4 리스트 기본 연산
16.5 리스트 패턴
16.6 List 클래스의 1차 메서드
16.7 List 클래스의 고차 메서드
16.8 List 객체의 메서드
16.9 여러 리스트를 함께 처리하기
16.10 스칼라의 타입 추론 알고리즘 이해
16.11 결론

17장. 컬렉션
17.1 시퀀스
17.2 집합과 맵
17.3 변경 가능 컬렉션과 변경 불가능 컬렉션
17.4 컬렉션 초기화
17.5 튜플
17.6 결론

18장. 변경 가능한 객체
18.1 무엇이 객체를 변경 가능하게 하는가?
18.2 재할당 가능한 변수와 프로퍼티
18.3 사례 연구: 이산 이벤트 시뮬레이션
18.4 디지털 회로를 위한 언어
18.5 시뮬레이션 API
18.6 회로 시뮬레이션
18.7 결론

19장. 타입 파라미터화
19.1 함수형 큐
19.2 정보 은닉
19.3 변성 표기
19.4 변성 표기 검사
19.5 하위 바운드
19.6 반공변성
19.7 객체의 비공개 데이터
19.8 상위 바운드
19.9 결론

20장. 추상 멤버
20.1 추상 멤버 간략하게 돌아보기
20.2 타입 멤버
20.3 추상 val
20.4 추상 var
20.5 추상 val 초기화
20.6 추상 타입
20.7 경로에 의존하는 타입
20.8 세분화한 타입
20.9 열거형
20.10 사례 연구: 통화 변환
20.11 결론

21장. 암시적 변환과 암시적 파라미터
21.1 암시적 변환
21.2 암시 규칙
21.3 예상 타입으로의 암시적 변환
21.4 호출 대상 객체 변환
21.5 암시적 파라미터
21.6 맥락 바운드
21.7 여러 변환을 사용하는 경우
21.8 암시 디버깅
21.9 결론

22장. 리스트 구현
22.1 List 클래스 개괄
22.2 ListBuffer 클래스
22.3 실제 List 클래스
22.4 외부에서 볼 때는 함수형
22.5 결론

23장. for 표현식 다시 보기
23.1 for 표현식
23.2 n 여왕 문제
23.3 for 식으로 질의하기
23.4 for 표현식 변환
23.5 역방향 적용
23.6 for 일반화
23.7 결론

24장 컬렉션 자세히 들여다보기 577
24.1 변경 가능, 변경 불가능 컬렉션
24.2 컬렉션 일관성
24.3 Iterable 트레이트
24.4 시퀀스 트레이트: Seq, IndexedSeq, LinearSeq
24.5 집합
24.6 맵
24.7 변경 불가능한 구체적인 컬렉션 클래스
24.8 변경 가능한 구체적인 컬렉션 클래스
24.9 배열
24.10 문자열
24.11 성능 특성
24.12 동일성
24.13 뷰
24.14 이터레이터
24.15 컬렉션 처음 만들기
24.16 자바와 스칼라 컬렉션 변환하기
24.17 결론

25장 스칼라 컬렉션 아키텍처 647
25.1 공통 연산 한데 묶기
25.2 새로운 컬렉션 추가하기
25.3 결론

26장. 익스트랙터
26.1 예제: 전자우편 주소 추출
26.2 익스트랙터
26.3 변수가 없거나 1개만 있는 패턴
26.4 가변 인자 익스트랙터
26.5 익스트랙터와 시퀀스 패턴
26.6 익스트랙터와 케이스 클래스
26.7 정규표현식
26.8 결론

27장. 애노테이션
27.1 애노테이션이 왜 필요한가?
27.2 애노테이션 문법
27.3 표준 애노테이션
27.4 결론

28장. XML 다루기
28.1 반 구조화 데이터
28.2 XML 개요
28.3 XML 리터럴
28.4 직렬화
28.5 XML 분석
28.6 역 직렬화
28.7 저장하기와 불러오기
28.8 XML에 대한 패턴 매치
28.9 결론

29장. 객체를 사용한 모듈화 프로그래밍
29.1 문제
29.2 조리법 애플리케이션
29.3 추상화
29.4 모듈을 트레이트로 분리하기
29.5 실행 시점 링킹
29.6 모듈 인스턴스 추적
29.7 결론

30장. 객체의 동일성
30.1 스칼라에서의 동일성
30.2 동일성 비교 메서드 작성
30.3 파라미터화한 타입의 동일성 정의
30.4 equals와 hashCode 요리법
30.5 결론

31장. 스칼라와 자바의 결합
31.1 스칼라를 자바에서 사용하기
31.2 애노테이션
31.3 와일드카드 타입
31.4 스칼라와 자바를 함께 컴파일하기
31.5 자바 8 통합
31.6 결론

32장. 퓨처와 동시성
32.1 낙원의 골칫거리
32.2 비동기 실행과 Try
32.3 Future 사용하기
32.4 Future 테스트
32.5 결론

33장. 콤비네이터 파싱
33.1 예제: 산술식
33.2 파서 실행
33.3 기본 정규표현식 파서
33.4 또 다른 예: JSON
33.5 파서의 결과
33.6 콤비네이터 파서 구현
33.7 문자열 리터럴과 정규표현식
33.8 어휘 분석과 파싱
33.9 오류 보고
33.10 백트래킹과 LL(1)
33.11 결론

34장. GUI 프로그래밍
34.1 첫 번째 스윙 애플리케이션
34.2 패널과 레이아웃
34.3 이벤트 처리
34.4 예제: 섭씨/화씨 변환기
34.5 결론

35장. SCells 스프레드시트
35.1 화면 프레임워크
35.2 데이터 입력과 화면 표시 분리하기
35.3 식
35.4 식의 파싱
35.5 계산
35.6 연산 라이브러리
35.7 변경 전파
35.8 결론

부록 A. 유닉스와 윈도우에서의 스칼라 스크립트 사용
부록 B. 용어 해설
부록 C. 참고 문헌


Information Provided By: : Aladin

New Arrivals Books in Related Fields