| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd"><html><!-- Created on December 10, 2012 by texi2html 1.82texi2html was written by:             Lionel Cons <[email protected]> (original author)            Karl Berry  <[email protected]>            Olaf Bachmann <[email protected]>            and many others.Maintained by: Many creative people.Send bugs and suggestions to <[email protected]>--><head><title>avram - a virtual machine code interpreter: 2.7.13 List Combinators</title><meta name="description" content="avram - a virtual machine code interpreter: 2.7.13 List Combinators"><meta name="keywords" content="avram - a virtual machine code interpreter: 2.7.13 List Combinators"><meta name="resource-type" content="document"><meta name="distribution" content="global"><meta name="Generator" content="texi2html 1.82"><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><style type="text/css"><!--a.summary-letter {text-decoration: none}blockquote.smallquotation {font-size: smaller}pre.display {font-family: serif}pre.format {font-family: serif}pre.menu-comment {font-family: serif}pre.menu-preformatted {font-family: serif}pre.smalldisplay {font-family: serif; font-size: smaller}pre.smallexample {font-size: smaller}pre.smallformat {font-family: serif; font-size: smaller}pre.smalllisp {font-size: smaller}span.roman {font-family:serif; font-weight:normal;}span.sansserif {font-family:sans-serif; font-weight:normal;}ul.toc {list-style: none}--></style></head><body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000"><a name="List-Combinators"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Iteration.html#Iteration" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Map.html#Map" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="Virtual-Code-Semantics.html#Virtual-Code-Semantics" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Library-Reference.html#Library-Reference" title="Next chapter"> >> </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td><td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td><td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td><td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td></tr></table><hr size="1"><a name="List-Combinators-1"></a><h3 class="subsection">2.7.13 List Combinators</h3><a name="index-lists-5"></a><a name="index-imperative-programming-1"></a><a name="index-functional-programming-3"></a><p>There is extensive support for operations on lists in the virtual codeformat. Use of these features is encouraged because they are conduciveto tight code with explicit concurrency. Within an imperativeprogramming paradigm, these features might perhaps have to be understoodas design patterns or algorithmic skeletons. The present expositiontakes a functional view, describing them in terms of operators that takefunctions as their arguments and return functions as their result.</p><table class="menu" border="0" cellspacing="0"><tr><td align="left" valign="top"><a href="Map.html#Map">2.7.13.1 Map</a></td><td>  </td><td align="left" valign="top">                         </td></tr><tr><td align="left" valign="top"><a href="Filter.html#Filter">2.7.13.2 Filter</a></td><td>  </td><td align="left" valign="top">                      </td></tr><tr><td align="left" valign="top"><a href="Reduce.html#Reduce">2.7.13.3 Reduce</a></td><td>  </td><td align="left" valign="top">                      </td></tr><tr><td align="left" valign="top"><a href="Sort.html#Sort">2.7.13.4 Sort</a></td><td>  </td><td align="left" valign="top">                        </td></tr><tr><td align="left" valign="top"><a href="Transfer.html#Transfer">2.7.13.5 Transfer</a></td><td>  </td><td align="left" valign="top">                    </td></tr><tr><td align="left" valign="top"><a href="Mapcur.html#Mapcur">2.7.13.6 Mapcur</a></td><td>  </td><td align="left" valign="top">                      </td></tr></table><hr size="1"><p> <font size="-1">  This document was generated on <i>December 10, 2012</i> using <a href="http://www.nongnu.org/texi2html/"><i>texi2html 1.82</i></a>. </font> <br></p></body></html>
 |