Cons (original) (raw)
cons je jednou ze základních funkcí jazyka Lisp. Jejími parametry jsou dva objekty a výstupem je jejich . Například volání cons x y vytvoří uspořádaný pár ( x . y ). Levý prvek tohoto páru je tradičně označován zkratkou a pravý prvek zkratkou .
Property | Value |
---|---|
dbo:abstract | cons je jednou ze základních funkcí jazyka Lisp. Jejími parametry jsou dva objekty a výstupem je jejich . Například volání cons x y vytvoří uspořádaný pár ( x . y ). Levý prvek tohoto páru je tradičně označován zkratkou a pravý prvek zkratkou . (cs) In computer programming, cons (/ˈkɒnz/ or /ˈkɒns/) is a fundamental function in most dialects of the Lisp programming language. cons constructs memory objects which hold two values or pointers to two values. These objects are referred to as (cons) cells, conses, non-atomic s-expressions ("NATSes"), or (cons) pairs. In Lisp jargon, the expression "to cons x onto y" means to construct a new object with (cons x y). The resulting pair has a left half, referred to as the car (the first element, or contents of the address part of register), and a right half, referred to as the cdr (the second element, or contents of the decrement part of register). It is loosely related to the object-oriented notion of a constructor, which creates a new object given arguments, and more closely related to the constructor function of an algebraic data type system. The word "cons" and expressions like "to cons onto" are also part of a more general functional programming jargon. Sometimes operators that have a similar purpose, especially in the context of list processing, are pronounced "cons". (A good example is the :: operator in ML, Scala, F#, Lean and Elm or the : operator in Haskell, which adds an element to the beginning of a list.) (en) consは、ほとんどのLisp方言における基本的な関数である。cons は、2つの、値もしくは値へのポインタを保持するオブジェクトを構成(construct)する。これによって作られたオブジェクトは、(cons)セル、cons、non-atomic S式(NATS式)、(cons)対などと呼ばれる。cons の結果のペアの左側(第一要素)は carと呼ばれ、右側(その残り)は cdrと呼ばれる。 (ja) In informatica, cons è una funzione fondamentale dei dialetti Lisp. Essa costruisce (in inglese construct) in memoria oggetti contenenti due valori o puntatori a valore. Questi oggetti vengono chiamati celle cons, coppie cons o semplicemente cons. Nel gergo Lisp, l'espressione "fare il cons di x su y" significa costruire un nuovo oggetto tramite (cons x y). L'oggetto risultante è una coppia, la cui metà sinistra è indicata con car (il primo elemento) e la metà destra (il secondo elemento) con cdr. Questa funzione è legata alla nozione di costruttore presente nella programmazione orientata agli oggetti, che crea un nuovo oggetto a partire da alcuni argomenti, e, più da vicino, è legata alla funzione costruttore dei sistemi a tipo dati algebrico. La parola "cons" e l'espressione "fare il cons su" vengono anche utilizzate più genericamente nel gergo della programmazione funzionale. A volte operatori che compiono una funzione simile, specialmente quando si lavora con le liste, sono pronunciati "cons". Un esempio è l'operatore :: del linguaggio ML, che aggiunge un elemento all'inizio di una lista. (it) В программировании cons (/ ˈkɒnz / или / ˈkɒns /) является фундаментальной функцией в большинстве диалектов языка программирования Лисп. cons создает объекты памяти, которые содержат два значения или два указателя на значения. Название функции было образовано как сокращение от слова construct, то есть конструирование. Имелось ввиду, что cons конструирует в памяти новый объект из имеющихся двух. Эти объекты также называют cons-ячейками, cons-ами, неатомарными S-выражениями («NATS») или cons-парами. В английском языке, в жаргоне ЛИСП-программистов, слово cons используется также в качестве глагола. Выражение «to cons x onto y» равнозначно «сконструировать новый объект при помощи следующего кода: (cons x y)». Среди пользователей функциональных языков программирования и в контексте работы со списками, «cons» также используется как жаргонное наименование аналогичных по назначению операторов аналогичного назначения, которые записываются совершенно по-другому. Хорошими примерами являются операторы :: в языках ML, Scala, F# и Elm или оператор : в языке Haskell, которые добавляют элемент в голову списка. (ru) В програмуванні, cons (/ˈkɒns/) фундаментальна функція більшості діалектів LISP. cons конструює (англ. constructs, звідки й назва) об'єкти в пам'яті, які містять два значення чи вказівники на значення. Такі об'єкти називають комірками (англ. cells), консами (англ. conses), неатомарними S-виразами ("NATSes") або парами. Ліву частину пари (перший елемент) називають , праву (другий елемент) — . Також цей трохи пов'язаний з поняттям конструктора в ООП, який створює новий об'єкт за аргументами і трохи більше пов'язаний з функцією конструктором у системах алгебричних типів даних. Слово "cons" та вираз "зконсити" є частиною більш загального жаргону функціонального програмування. Іноді оператори які мають подібну мету, особливо в контексті обробки списків, вимовляються як "cons". (Гарним прикладом є оператор :: в ML, Elm та Scala, який додає елемент до початку списку.) (uk) 列表構造函數是用來構造列表的基本函數,在大多數 LISP 體系的計算機編程語言中,使用的函數名稱是cons。 cons構成了存放兩個變量與其指針的記憶體物件,這個物件被稱為單元、非原子的 S 表達式或對。LISP 編程中表達要把 x 加入 y 的語法:(cons x y),構造了一個新物件。產生的結果具備了左半部,稱為CAR(第一元素或暫存器位址的內容);以及右半部稱為CDR(其餘元素或遞減暫存器的內容)。 以上約略地和物件導向的構造器概念相關,即產生一個給定參數的新物件,而其與代數數據類型系統的構造函數,有更密切相關。“cons”和諸如“cons onto”的詞句,也是函數編程的通用術語。有時運算子有類似作用,特別是在列表處理的情況下,被讀作“CONS”。(例如 ML,Scala,F#和 Elm 編程的 ::運算符,或 Haskell 編程的 :運算符,都是向列表的開頭添加一個元素。) (zh) |
dbo:thumbnail | wiki-commons:Special:FilePath/Cons-cells.svg?width=300 |
dbo:wikiPageExternalLink | https://www.cs.cmu.edu/~dst/Lisp/sdraw/ |
dbo:wikiPageID | 208153 (xsd:integer) |
dbo:wikiPageLength | 7857 (xsd:nonNegativeInteger) |
dbo:wikiPageRevisionID | 1122211964 (xsd:integer) |
dbo:wikiPageWikiLink | dbr:Scala_(programming_language) dbr:Scheme_(programming_language) dbr:Binary_tree dbc:Composite_data_types dbr:Append dbr:ML_programming_language dbr:Common_Lisp dbr:Concatenation dbr:Object-oriented_programming dbr:Elm_(programming_language) dbr:Lisp_(programming_language) dbr:Subroutine dbr:Computer_programming dbr:Functional_programming dbr:Ordered_pair dbc:Functional_programming dbr:Hash_consing dbr:Leaf_node dbr:Linked_list dbr:List_(information) dbr:Algebraic_data_type dbc:Data_types dbr:Dynamic_memory_allocation dbr:F_Sharp_(programming_language) dbr:Church_encoding dbr:Haskell_(programming_language) dbr:Java_(programming_language) dbc:Lisp_(programming_language) dbc:Articles_with_example_Lisp_(programming_language)_code dbr:Lambda_calculus dbr:Lean_(proof_assistant) dbc:Articles_with_example_Scheme_(programming_language)_code dbr:CAR_and_CDR dbr:Operator_(programming) dbr:Side_effect_(computer_science) dbr:First-class_function dbr:S-expressions dbr:Constructor_(computer_science) dbr:File:Cons-cells.svg |
dbp:wikiPageUsesTemplate | dbt:About dbt:Citation_needed dbt:Clear dbt:IPAc-en dbt:Lowercase_title dbt:More_citations_needed dbt:Short_description dbt:Data_types dbt:Lisp2 |
dct:subject | dbc:Composite_data_types dbc:Functional_programming dbc:Data_types dbc:Lisp_(programming_language) dbc:Articles_with_example_Lisp_(programming_language)_code dbc:Articles_with_example_Scheme_(programming_language)_code |
gold:hypernym | dbr:Function |
rdf:type | dbo:Disease |
rdfs:comment | cons je jednou ze základních funkcí jazyka Lisp. Jejími parametry jsou dva objekty a výstupem je jejich . Například volání cons x y vytvoří uspořádaný pár ( x . y ). Levý prvek tohoto páru je tradičně označován zkratkou a pravý prvek zkratkou . (cs) consは、ほとんどのLisp方言における基本的な関数である。cons は、2つの、値もしくは値へのポインタを保持するオブジェクトを構成(construct)する。これによって作られたオブジェクトは、(cons)セル、cons、non-atomic S式(NATS式)、(cons)対などと呼ばれる。cons の結果のペアの左側(第一要素)は carと呼ばれ、右側(その残り)は cdrと呼ばれる。 (ja) 列表構造函數是用來構造列表的基本函數,在大多數 LISP 體系的計算機編程語言中,使用的函數名稱是cons。 cons構成了存放兩個變量與其指針的記憶體物件,這個物件被稱為單元、非原子的 S 表達式或對。LISP 編程中表達要把 x 加入 y 的語法:(cons x y),構造了一個新物件。產生的結果具備了左半部,稱為CAR(第一元素或暫存器位址的內容);以及右半部稱為CDR(其餘元素或遞減暫存器的內容)。 以上約略地和物件導向的構造器概念相關,即產生一個給定參數的新物件,而其與代數數據類型系統的構造函數,有更密切相關。“cons”和諸如“cons onto”的詞句,也是函數編程的通用術語。有時運算子有類似作用,特別是在列表處理的情況下,被讀作“CONS”。(例如 ML,Scala,F#和 Elm 編程的 ::運算符,或 Haskell 編程的 :運算符,都是向列表的開頭添加一個元素。) (zh) In computer programming, cons (/ˈkɒnz/ or /ˈkɒns/) is a fundamental function in most dialects of the Lisp programming language. cons constructs memory objects which hold two values or pointers to two values. These objects are referred to as (cons) cells, conses, non-atomic s-expressions ("NATSes"), or (cons) pairs. In Lisp jargon, the expression "to cons x onto y" means to construct a new object with (cons x y). The resulting pair has a left half, referred to as the car (the first element, or contents of the address part of register), and a right half, referred to as the cdr (the second element, or contents of the decrement part of register). (en) In informatica, cons è una funzione fondamentale dei dialetti Lisp. Essa costruisce (in inglese construct) in memoria oggetti contenenti due valori o puntatori a valore. Questi oggetti vengono chiamati celle cons, coppie cons o semplicemente cons. Questa funzione è legata alla nozione di costruttore presente nella programmazione orientata agli oggetti, che crea un nuovo oggetto a partire da alcuni argomenti, e, più da vicino, è legata alla funzione costruttore dei sistemi a tipo dati algebrico. (it) В программировании cons (/ ˈkɒnz / или / ˈkɒns /) является фундаментальной функцией в большинстве диалектов языка программирования Лисп. cons создает объекты памяти, которые содержат два значения или два указателя на значения. Название функции было образовано как сокращение от слова construct, то есть конструирование. Имелось ввиду, что cons конструирует в памяти новый объект из имеющихся двух. Эти объекты также называют cons-ячейками, cons-ами, неатомарными S-выражениями («NATS») или cons-парами. В английском языке, в жаргоне ЛИСП-программистов, слово cons используется также в качестве глагола. Выражение «to cons x onto y» равнозначно «сконструировать новый объект при помощи следующего кода: (cons x y)». (ru) В програмуванні, cons (/ˈkɒns/) фундаментальна функція більшості діалектів LISP. cons конструює (англ. constructs, звідки й назва) об'єкти в пам'яті, які містять два значення чи вказівники на значення. Такі об'єкти називають комірками (англ. cells), консами (англ. conses), неатомарними S-виразами ("NATSes") або парами. Ліву частину пари (перший елемент) називають , праву (другий елемент) — . Також цей трохи пов'язаний з поняттям конструктора в ООП, який створює новий об'єкт за аргументами і трохи більше пов'язаний з функцією конструктором у системах алгебричних типів даних. (uk) |
rdfs:label | Cons (en) Cons (cs) Cons (it) Cons (Lisp) (ja) Cons (ru) 列表構造函數 (zh) Cons (uk) |
owl:sameAs | freebase:Cons http://sw.cyc.com/concept/Mx4rGxWKc1L1EdaCtgACs0uXdw wikidata:Cons dbpedia-cs:Cons dbpedia-fa:Cons dbpedia-it:Cons dbpedia-ja:Cons dbpedia-ru:Cons dbpedia-uk:Cons dbpedia-zh:Cons https://global.dbpedia.org/id/3QQ6z |
prov:wasDerivedFrom | wikipedia-en:Cons?oldid=1122211964&ns=0 |
foaf:depiction | wiki-commons:Special:FilePath/Cons-cells.svg |
foaf:isPrimaryTopicOf | wikipedia-en:Cons |
is dbo:wikiPageDisambiguates of | dbr:Cons_(disambiguation) |
is dbo:wikiPageRedirects of | dbr:Snoc dbr:Cons_cell dbr:Cons_pair |
is dbo:wikiPageWikiLink of | dbr:Scheme_(programming_language) dbr:Memory_address dbr:Tail_call dbr:Append dbr:Unification_(computer_science) dbr:Initial_algebra dbr:Colon_(punctuation) dbr:Order_of_operations dbr:Clean_(programming_language) dbr:MultiLisp dbr:Conc-tree_list dbr:Maclisp dbr:Comparison_of_programming_languages_(associative_array) dbr:Pointer_(computer_programming) dbr:CDR_coding dbr:Hash_consing dbr:Linked_list dbr:F_Sharp_(programming_language) dbr:PDP-6 dbr:Church_encoding dbr:Fold_(higher-order_function) dbr:S-expression dbr:Reference_(computer_science) dbr:Iota_and_Jot dbr:Thriller_(genre) dbr:CAR_and_CDR dbr:Cons_(disambiguation) dbr:Refal dbr:Snoc dbr:Tracing_garbage_collection dbr:Cons_cell dbr:Cons_pair |
is rdfs:seeAlso of | dbr:Church_encoding |
is owl:differentFrom of | dbr:Conc-tree_list |
is foaf:primaryTopic of | wikipedia-en:Cons |