Функции в Clojure обладают следующими свойствами:
; определение функции, вычисляющей сумму двух чисел
(fn [x y] (+ x y))
В примере выше определяется функция с двумя аргументами. Определение функции начинается со слова fn
. Вторым элементом в форме определения функции идёт список аргументов. Третий и последующие элементы — тело функции. То есть тело может состоять из нескольких форм (как минимум из одной):
(fn []
(println "one")
(println "two"))
Обратите внимание на отсутствие инструкции return
. В отличие от большинства других языков, в Lisp-языках "инструкций" практически нет. Всё есть выражение. А выражения всегда возвращают результат. Если хорошо подумать, то такое поведение следует из самой структуры Lisp-программы. Фактически мы имеем дерево, которое должно вычисляться в какое-то значение, значит на каждом уровне должен создаваться возврат, поднимающийся выше по дереву, и так до самого корня. Возвращается всегда последнее вычисленное выражение.
Пара примеров для закрепления:
; печать на экран
(fn [] (println "hello!"))
; куб числа
(fn [n] (* n n n))
; среднее между двумя числами
(fn [num1 num2] (/ (+ num1 num2) 2))
Определение функции само по себе мало полезно, особенно если мы захотим использовать её несколько раз. Для повторного использования нужно создать объявление, в которое запишется функция. Такое возможно благодаря тому, что форма определения функции — это выражение, возвращающее саму функцию.
(def cube (fn [n] (* n n n)))
Теперь попробуем вызвать:
(cube 2) ; 8
(cube 3) ; 27
Помимо связи анонимной функции с объявлением существует упрощенный вариант объявления функции и связи ее с идентификатором. Делается это с помощью формы defn
, которая делает процесс объявления функции удобнее (в таком способе объявления возможно даже написать документацию на объявляемую функцию!).
(defn cube [n] (* n n n))
(cube 2) ; => 8
(cube 3) ; => 27
(defn increment
"Function that increments passed number by one."
[n] (+ n 1))
(increment 2) ; => 3
Создайте функцию с именем square
, которая вычисляет квадрат переданного числа
(square 3) ; 9
Команда проекта находится в телеграм-сообществе по ссылке https://ttttt.me/HexletLearningBot. Там можно задать любой вопрос и повлиять на проект
Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "Обсуждение". Как правильно задать вопрос:
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества
Привет! Я Тота и моя задача помочь в обучении. Чтобы активировать меня, нужно зарегистрироваться или залогиниться, если у вас уже есть аккаунт
Ваше упражнение проверяется по этим тестам
1(ns define-fun-test
2 (:require [test-helper :refer [assert-solution]]
3 [index :refer [square]]))
4
5(assert-solution [[1] [2] [3] [4]] [1 4 9 16] square)
6
Решение учителя откроется через: