Scheme/synonym: различия между версиями

Материал из ALT Linux Wiki
м Alterator/synonym» переименована в «Scheme/synonym»)
Нет описания правки
Строка 1: Строка 1:
[[Category:Sisyphus]]
{{MovedFromFreesourceInfo|AltLinux/Sisyphus/Alterator/synonym}}
== Scheme: велопипеды и синонимы ==
== Scheme: велопипеды и синонимы ==


Строка 9: Строка 6:
Сначала коллекция из srfi-1
Сначала коллекция из srfi-1


{| border="1"
{| class="standard"
|-
|-
|
|
Строка 60: Строка 57:
Ну и несколько заметок про стандартный R5RS
Ну и несколько заметок про стандартный R5RS


{| border="1"
{| class="standard"
|-
|-
|
|
Строка 105: Строка 102:




<div style="display: inline; color: red;">Опасные моменты</div>
'''Опасные моменты'''
 
*'''fold-left''' - это итеративный процесс, но '''fold-right''' - рекурсивный, соотв. , на больших списках может закончится стек.
'''fold-left''' - это итеративный процесс, но '''fold-right''' - рекурсивный, соотв. , на больших списках может закончится стек.

Версия от 15:03, 31 июля 2008

Scheme: велопипеды и синонимы

Очень часто вместо одной функции можно использовать другие, иногда это бывает полезно. Например во многих случаях программа начинает быстрее работать.

Сначала коллекция из srfi-1

Вариант 1

Вариант 2

not + pair

not-pair

car + last-pair

last

fold + reverse

fold-right

list-tail

drop, а заодно есть и take.

(delq #f)+ map

filter-map

apply + append + map

append-map

apply + append

concatenate

contatenate+ map

append-map


Ну и несколько заметок про стандартный R5RS

Вариант 1

Вариант 2

(= x 0)

(zero? x)

(> x 0)

(positive? x)

(< x 0)

(negative? x)

(lambda(x) x)

values

(list->vector x)

(apply vector x)

(and (< a b) (b c))

(< a b c)


Просто рекомендации:

Очень полезно бывает скрывать некоторые "склеивающие" операции внутри функции - выглядеть будет гораздо нагляднее. Например, (my-url "/aaa" "/bbb" "ccc") выглядит гораздо понятнее, чем (my-url (string-append "/aaaa" "/bbb" "ccc)).


Опасные моменты

  • fold-left - это итеративный процесс, но fold-right - рекурсивный, соотв. , на больших списках может закончится стек.