Давайте напишем функцию вычисления факториалов. Математическое определение факториала от n следующее:
n! = 1 (когда n==0) = n * (n-1)! (иначе)
В Ruby это может быть записано следующим образом:
def fact(n) if n == 0 1 else n * fact(n-1) end end
Вы можете заметить, что оператор end здесь повторяется. Ruby из-за этого называют Алоголо-подобным. (На самом деле синтаксис Ruby больше походит на синтаксис языка Eiffel.) Вы можете также заметить, что отсутствует оператор return . Он не требуется поскольку Ruby возвращает последнее значение с которым вышел из функции. Использование оператора return возможно, но не обязательно.
Давайте опробуем вывод нашего факториала. Добавим одну строку кода, которая даст нам рабочую программу с выводом:
# Программа находит факториал от числа # Сохраните этот файл как fact.rb def fact(n) if n == 0 1 else n * fact(n-1) end end print fact(ARGV[0].to_i), "\n"
Здесь присутствует массив ARGV, который содержит аргументы команды, и конвертирование символов строки в целочисленную переменную (integer).
% ruby fact.rb 1 1 % ruby fact.rb 5 120
Давайте запустим программу с аргументом 40. Это может привести Ваш калькулятор к переполнению...
% ruby fact.rb 40 815915283247897734345611269596115894272000000000
Но это работает. На самом деле, Ruby может работать с любым целым числом, с которым позволяет работать память компьютера. Итак число 400! Можем вычислить факториал и для него:
% ruby fact.rb 400 64034522846623895262347970319503005850702583026002959458684 44594280239716918683143627847864746326467629435057503585681 08482981628835174352289619886468029979373416541508381624264 61942352307046244325015114448670890662773914918117331955996 44070954967134529047702032243491121079759328079510154537266 72516278778900093497637657103263503315339653498683868313393 52024373788157786791506311858702618270169819740062983025308 59129834616227230455833952075961150530223608681043329725519 48526744322324386699484224042325998055516106359423769613992 31917134063858996537970147827206606320217379472010321356624 61380907794230459736069956759583609615871512991382228657857 95493616176544804532220078258184008484364155912294542753848 03558374518022675900061399560145595206127211192918105032491 00800000000000000000000000000000000000000000000000000000000 0000000000000000000000000000000000000000000
Мы не можем проверить правильность этого вывода достаточно быстро, но он должен быть верным.
Ввод и цикл вычислений
Когда Вы вызываете Ruby без аргументов, то он считывает команды из стандартного ввода и выполняет его по окончании ввода:
% ruby print "hello world\n" print "good-bye world\n" ^D hello world good-bye world
Ruby также поставляется с программой, называемой eval.rb, которая позволяет вам вводить код Ruby с клавиатуры в интерактивном цикле, показывая вам результат по мере вашего продвижения. Это будет использоваться на протяжении данного руководства.
Если Вы имеете ANSI-совместимый терминал (это будет верным, если вы запускаете программы под UNIX; под DOS Вам потребуется установить ANSI.SYS или ANSI.COM (на момент перевода эти утилиты не понадобилось устанавливать)), Вам понадобиться использовать следующую программу eval.rb , которая добавит визуальный помощник отступов, отчёты об ошибках и подсветку синтаксиса. Или же, поищите поддиректорию sample в поставке Ruby для non-ANSI версии, которая работает в любом терминале. Ниже представлена короткая сессия eval.rb:
% ruby eval.rb ruby> print "Hello, world.\n" Hello, world. nil ruby> exit
hello world предоставляется выводом print. Следующая строка, в данном случае nil , сообщает о последнем полученном значении; Ruby не различает операторы и выражения, поэтому результат куска кода в основном означает тоже самое, что и результат выполнения функции. Здесь nil означает, что print не возвращает какого либо значения. Заметьте, что мы можем выйти из цикла интерпретатора сообщив ему exit, хотя Ctrl + D также сработает.
На протяжении этого руководства, "ruby>" помечает ввод для нашей полезной маленькой программы eval.rb.