ну что, хаскелисты, наведете душноты?
Наверное, кто-то спросит, а что вообще такое "чистая функция" (в Go)?
Первая функция недетерминированная, свойство ссылочной прозрачности не соблюдается, поэтому функция не является чистой
(ну, там производится вызов time.Now(). думаю, в Haskell без грязных хаков из чистой функции получить текущее время нельзя)
Если без сложных формулировок, мне кажется, что что-то, что не меняет окружающее состояние и всегда при выполнении выдаёт на один и тот же вход один и тот же выход. А такое, в общем-то, в любом языке провернуть можно.
> Если без сложных формулировок, мне кажется, что что-то, что не меняет окружающее состояние и всегда при выполнении выдаёт на один и тот же вход один и тот же выход. исходя из этой формулировки — нет, потому что time.Now() будет возвращать разное значение (выход разный), хотя входные данные одинаковые
правильно думаете. потому что вы не хотите работать с чистой функцией, зависящей от текущего времени. если вычисление зависит от времени, то это уже процедура, и вы захотите работать с таким вычислением именно как с процедурой
Ни одна. Что в первой, что во второй, r переданый в функцию, после её вызова будет изменён. Первая ещё и .Now() вызывает, которая не является чистой, потому что каждый раз возвращает разный результат.
Ссылочная прозрачность подразумевает, что любой вызов функции с заранее известным аргументом можно заменить на результат вызова раз и навсегда и смысл программы при этом не поменяется. Ни первую, ни вторую функции заменить нельзя. Первая не деретминирована, замена второй перестанет менять внешнее состояние
Ты попался на кликбейт
Вот "каждый раз возвращает разный результат" - враки же? Не так определение даете или натягиваете сову на глобус? Func a b = a+b чистая ?
А-а-а-а-а
Обсуждают сегодня