SqueakByExample:3.6: Difference between revisions

From 흡혈양파의 번역工房
Jump to navigation Jump to search
(용어수정)
 
(번역수정)
Line 1: Line 1:
==간단하게 살펴보는 조건과 루프 (Conditionals and loops in a nutshell)==
==간단하게 살펴보는 조건과 루프 (Conditionals and loops in a nutshell)==


스몰토크는 제어 구성을 위한 특별한 구문을 제공하지 않습니다. 대신에, 컨트롤 구성은 인수로서의 블록과 함께, 메시지를 Boolean, 숫자 그리고 컬렉션에 보내어 표현합니다.
스몰토크는 제어문 구성을 위한 특별한 문법을 제공하지 않습니다. 대신에, 제어문은 인수로서의 블록과 함께, 메시지를 Boolean, 숫자 그리고 컬렉션에 보내어 표현함으로서 만들어집니다.


조건들은 메시지 '''ifTrue:''', '''ifFalse:''' 또는 '''ifTrue:ifFalse:''' 들 중 하나를 Boolean 표현식의 결과에 보내어 표현합니다. Boolean에 대해 좀 더 많은 내용을 원하시면 8장을 보십시오.  
조건들은 메시지 '''ifTrue:''', '''ifFalse:''' 또는 '''ifTrue:ifFalse:''' 들 중 하나를 Boolean 표현식의 결과에 보내어 표현합니다. Boolean에 대해 좀 더 많은 내용을 원하시면 8장을 보십시오.  
Line 11: Line 11:
</syntaxhighlight>
</syntaxhighlight>


반복문은 메시지를 블록, 정수 또는 컬렉션을 블록에 보냄으로써 전형적으로 표현하였습니다. 루프를 위한 나가기 조건을 반복적으로 계산하므로, 루프는 Boolean 값 보다는 블록이 되어야 합니다. 여기에 절차적 반복문에 대한 예가 있습니다:  
 
반복문은 일반적으로 블록, 정수 또는 컬렉션에 메세지를 보내는것으로 표현됩니다. 루프의 종료 조건을 반복적으로 계산하기 때문에, 루프는 Boolean 값보다는 블락이 되어야 합니다. Boolean은 종료조건이 한번에 끝나버릴 수 있기 때문이죠. 여기에 절차적 반복문에 대한 예가 있습니다:  


<syntaxhighlight lang="smalltalk">
<syntaxhighlight lang="smalltalk">
Line 18: Line 19:
n    ⇒    1024
n    ⇒    1024
</syntaxhighlight>
</syntaxhighlight>


'''whileFalse:''' 나가기 조건을 뒤바꿉니다.
'''whileFalse:''' 나가기 조건을 뒤바꿉니다.
Line 27: Line 29:
</syntaxhighlight>
</syntaxhighlight>


'''timesRepeat:''' 고정 반복을 실행하기 위한 간단한 방법을 제공합니다:
 
'''timesRepeat:''' 고정 반복을 실행하기 위한 간단한 방법도 제공됩니다:


<syntaxhighlight lang="smalltalk">
<syntaxhighlight lang="smalltalk">
Line 35: Line 38:
</syntaxhighlight>
</syntaxhighlight>


메시지 '''to:do'''를 반복 카운터의 초기 값의 역할을 하는 숫자에 보낼 수 있습니다. 두 개의 인수는 상한과 자신의 인수로서 반복 카운터의 현재 값을 취하는 블록입니다:
 
메시지 '''to:do'''를 반복 카운터의 초기 역할을 하는 숫자에 보낼 수 있습니다. 두 개의 인수는 상한과 자신의 인수로서 반복 카운터의 현재 값을 취하는 블록입니다:


<syntaxhighlight lang="smalltalk">
<syntaxhighlight lang="smalltalk">
Line 42: Line 46:
result    ⇒    '1 2 3 4 5 6 7 8 9 10 '
result    ⇒    '1 2 3 4 5 6 7 8 9 10 '
</syntaxhighlight>
</syntaxhighlight>


===오름차순 반복 처리자(High-order lterators)===
===오름차순 반복 처리자(High-order lterators)===
Line 54: Line 60:
result    ⇒    '1 2 3 4 5 6 7 8 9 10 '
result    ⇒    '1 2 3 4 5 6 7 8 9 10 '
</syntaxhighlight>
</syntaxhighlight>


collect: 각 구성요소를 변화시켜, 동일한 크기의 새로운 컬렉션을 만듭니다.
collect: 각 구성요소를 변화시켜, 동일한 크기의 새로운 컬렉션을 만듭니다.
Line 60: Line 67:
(1 to: 10) collect: [ :each | each * each ]    ⇒    #(1 4 9 16 25 36 49 64 81 100)
(1 to: 10) collect: [ :each | each * each ]    ⇒    #(1 4 9 16 25 36 49 64 81 100)
</syntaxhighlight>
</syntaxhighlight>


새로운 컬렉션을 만들고, 각각의 컬렉션은 Boolean 블록 조건을 만족하는 구성요소의 서브세트<sup>subset</sup>를 포함합니다. detect:는 조건을 만족시키는 첫 번째 구성요소를 리턴 합니다. 문자열 또한 컬렉션이므로 모든 문자들을 반복 처리 할 수 있다는 것을 잊지 말아주십시오.
새로운 컬렉션을 만들고, 각각의 컬렉션은 Boolean 블록 조건을 만족하는 구성요소의 서브세트<sup>subset</sup>를 포함합니다. detect:는 조건을 만족시키는 첫 번째 구성요소를 리턴 합니다. 문자열 또한 컬렉션이므로 모든 문자들을 반복 처리 할 수 있다는 것을 잊지 말아주십시오.
Line 68: Line 76:
'hello there' detect: [ :char | char isVowel ]    ⇒    $e  
'hello there' detect: [ :char | char isVowel ]    ⇒    $e  
</syntaxhighlight>
</syntaxhighlight>


마지막으로, 컬렉션이 inject:into: 메소드에서 ''functionalstyle fold operator''를 지원한다는 것에 주의해야 합니다. 이것은 씨앗값(seed value)으로 시작하고, 컬렉션의 각 구성요소를 주입하는 표현식을 사용하여 누적 결과를 발생시킵니다. 합계와 곱셈 결과는 전형적인 예입니다.
마지막으로, 컬렉션이 inject:into: 메소드에서 ''functionalstyle fold operator''를 지원한다는 것에 주의해야 합니다. 이것은 씨앗값(seed value)으로 시작하고, 컬렉션의 각 구성요소를 주입하는 표현식을 사용하여 누적 결과를 발생시킵니다. 합계와 곱셈 결과는 전형적인 예입니다.
Line 74: Line 83:
(1 to: 10) inject: 0 into: [ :sum :each | sum + each ]    ⇒    55
(1 to: 10) inject: 0 into: [ :sum :each | sum + each ]    ⇒    55
</syntaxhighlight>
</syntaxhighlight>


이것은 0+1+2+3+4+5+6+7+8+9+10와 동등합니다.
이것은 0+1+2+3+4+5+6+7+8+9+10와 동등합니다.

Revision as of 02:32, 22 February 2013

간단하게 살펴보는 조건과 루프 (Conditionals and loops in a nutshell)

스몰토크는 제어문 구성을 위한 특별한 문법을 제공하지 않습니다. 대신에, 제어문은 인수로서의 블록과 함께, 메시지를 Boolean, 숫자 그리고 컬렉션에 보내어 표현함으로서 만들어집니다.

조건들은 메시지 ifTrue:, ifFalse: 또는 ifTrue:ifFalse: 들 중 하나를 Boolean 표현식의 결과에 보내어 표현합니다. Boolean에 대해 좀 더 많은 내용을 원하시면 8장을 보십시오.

(17 * 13 > 220)
  ifTrue: [ 'bigger' ]
  ifFalse: [ 'smaller' ]        'bigger'


반복문은 일반적으로 블록, 정수 또는 컬렉션에 메세지를 보내는것으로 표현됩니다. 루프의 종료 조건을 반복적으로 계산하기 때문에, 루프는 Boolean 값보다는 블락이 되어야 합니다. Boolean은 종료조건이 한번에 끝나버릴 수 있기 때문이죠. 여기에 절차적 반복문에 대한 예가 있습니다:

n := 1.
[ n < 1000 ] whileTrue: [ n := n*2 ].
n        1024


whileFalse: 나가기 조건을 뒤바꿉니다.

n := 1.
[ n > 1000 ] whileFalse: [ n := n*2 ].
n        1024


timesRepeat: 고정 반복을 실행하기 위한 간단한 방법도 제공됩니다:

n := 1.
10 timesRepeat: [ n := n*2 ].
n        1024


메시지 to:do를 반복 카운터의 초기 값 역할을 하는 숫자에 보낼 수 있습니다. 두 개의 인수는 상한과 자신의 인수로서 반복 카운터의 현재 값을 취하는 블록입니다:

result := String new.
1 to: 10 do: [:n | result := result, n printString, ' '].
result        '1 2 3 4 5 6 7 8 9 10 '


오름차순 반복 처리자(High-order lterators)

컬렉션들은 수 많은 다양한 클래스로 이루어져 있으며, 그들 중 대부분의 클래스는 동일한 프로토콜을 지원합니다. 이러한 컬렉션들을 위해 반복 처리하는 가장 중요한 메시지는 do:, collect:, select:, reject:, detect: 그리고 inject:into:.을 포함합니다. 이러한 메시지들은, 고도로 압축된 코드를 쓰기 위한 고급 반복 처리자high-level iterators를 정의할 수 있도록 해줍니다.

인터벌interval은 시작부터 끝까지 숫자의 시퀀스를 반복처리 해주는 컬렉션입니다. 1 to:10은 1에서 10까지의 인터벌을 나타내며, 메시지 do:를 인터벌에 보낼 수 있습니다. 인수는 컬렉션의 각 구성요소를 위해 계산되는 블록입니다.

result := String new.
(1 to: 10) do: [:n | result := result, n printString, ' '].
result        '1 2 3 4 5 6 7 8 9 10 '


collect: 각 구성요소를 변화시켜, 동일한 크기의 새로운 컬렉션을 만듭니다.

(1 to: 10) collect: [ :each | each * each ]        #(1 4 9 16 25 36 49 64 81 100)


새로운 컬렉션을 만들고, 각각의 컬렉션은 Boolean 블록 조건을 만족하는 구성요소의 서브세트subset를 포함합니다. detect:는 조건을 만족시키는 첫 번째 구성요소를 리턴 합니다. 문자열 또한 컬렉션이므로 모든 문자들을 반복 처리 할 수 있다는 것을 잊지 말아주십시오.

'hello there' select: [ :char | char isVowel ]        'eoee'
'hello there' reject: [ :char | char isVowel ]        'hll thr'
'hello there' detect: [ :char | char isVowel ]        $e


마지막으로, 컬렉션이 inject:into: 메소드에서 functionalstyle fold operator를 지원한다는 것에 주의해야 합니다. 이것은 씨앗값(seed value)으로 시작하고, 컬렉션의 각 구성요소를 주입하는 표현식을 사용하여 누적 결과를 발생시킵니다. 합계와 곱셈 결과는 전형적인 예입니다.

(1 to: 10) inject: 0 into: [ :sum :each | sum + each ]        55


이것은 0+1+2+3+4+5+6+7+8+9+10와 동등합니다.

컬렉션에 대한 좀 더 많은 내용은 9장에서 보실 수 있습니다.

Notes


[[Category:SqueakByExample]