| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 | <html lang="en"><head><title>Assignment - avram - a virtual machine code interpreter</title><meta http-equiv="Content-Type" content="text/html"><meta name="description" content="avram - a virtual machine code interpreter"><meta name="generator" content="makeinfo 4.13"><link title="Top" rel="start" href="index.html#Top"><link rel="up" href="Virtual-Code-Semantics.html#Virtual-Code-Semantics" title="Virtual Code Semantics"><link rel="prev" href="Recursion.html#Recursion" title="Recursion"><link rel="next" href="Predicates.html#Predicates" title="Predicates"><link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"><meta http-equiv="Content-Style-Type" content="text/css"><style type="text/css"><!--  pre.display { font-family:inherit }  pre.format  { font-family:inherit }  pre.smalldisplay { font-family:inherit; font-size:smaller }  pre.smallformat  { font-family:inherit; font-size:smaller }  pre.smallexample { font-size:smaller }  pre.smalllisp    { font-size:smaller }  span.sc    { font-variant:small-caps }  span.roman { font-family:serif; font-weight:normal; }   span.sansserif { font-family:sans-serif; font-weight:normal; } --></style></head><body><div class="node"><a name="Assignment"></a><p>Next: <a rel="next" accesskey="n" href="Predicates.html#Predicates">Predicates</a>,Previous: <a rel="previous" accesskey="p" href="Recursion.html#Recursion">Recursion</a>,Up: <a rel="up" accesskey="u" href="Virtual-Code-Semantics.html#Virtual-Code-Semantics">Virtual Code Semantics</a><hr></div><h4 class="subsection">2.7.10 Assignment</h4><p><a name="index-assignment-303"></a><a name="index-imperative-programming-304"></a>In an imperative programming paradigm, a machine consists partly of anensemble of addressable storage locations, whose contents are changedover time by assignment statements. An assignment statement includessome computable function of the global machine state, and the address ofthe location whose contents will be overwritten with the value computedfrom the function when it is evaluated.   <p>Compiling a language containing assignment statements into virtualmachine code suitable for <code>avram</code> might be facilitated byexploiting the following property.     <dl><dt><em>P16</em><dd>([[<code>assign</code>]] <code>(</code><var>p</var><code>,</code><var>f</var><code>)</code>) <var>x</var> = [[<code>replace</code>]] <code>((</code><var>p</var><code>,</code><var>f</var> <var>x</var><code>),</code><var>x</var><code>)</code></dl><p class="noindent">The identifier <code>assign</code> is used in <code>silly</code> to express avirtual code fragment having the form shown below, and <code>replace</code>corresponds to a further operation to be explained presently. <a name="index-g_t_0040code_007bassign_007d-305"></a>     <dl><dt><em>T18</em><dd>[[<code>assign</code>]] <code>(</code><var>p</var><code>,</code><var>f</var><code>)</code> = <code>(((</code><var>p</var><code>,</code><var>f</var><code>),nil),nil)</code></dl>   <p>This feature simulates assignment statements in the following way.  Thevariable <var>x</var> in <em>P16</em> corresponds intuitively to the setof addressable locations in the machine. The variable <var>f</var>corresponds to the function whose value will be stored in the locationaddressed by <var>p</var>. The result of a function expressed using<code>assign</code> is a new store similar to the argument <var>x</var>, butwith the part of it in location <var>p</var> replaced by <var>f</var><var>x</var>. A source text with a sequence of assignment statements couldtherefore be translated directly into a functional composition of treesin this form.   <p><a name="index-storage-locations-306"></a>The way storage locations are modeled in virtual code using this featurewould be as nested pairs, and the address <var>p</var> of a locationis a tree interpreted similarly to the trees used as operands to the<code>field</code> operator described in <a href="Field.html#Field">Field</a>, to specifydeconstructions. In fact, <code>replace</code> can be defined as a minimalsolution to the following equation. <a name="index-g_t_0040code_007breplace_007d-307"></a>     <dl><dt><em>E0</em><dd>([[<code>field</code>]] <var>p</var>) [[<code>replace</code>]] <code>((</code><var>p</var><code>,</code><var>y</var><code>),</code><var>x</var><code>)</code> = <var>y</var></dl>   <p>This equation regrettably doesnot lend itself to inferring the <code>silly</code> source for <code>replace</code><a name="index-g_t_0040code_007bisolate_007d-308"></a>using the <code>isolate</code> algorithm in <a href="Variable-Freedom.html#Variable-Freedom">Variable Freedom</a>, so an explicitconstruction is given in <a href="Replace.html#Replace">Replace</a>. This construction need not concern areader who considers the equation a sufficiently precise specificationin itself.   <p>In view of the way addresses for deconstruction are represented astrees, it would be entirely correct to infer from this equation that atuple of values computed together can be assigned to a tuple oflocations. The locations don't even have to be “contiguous”, but couldbe anywhere in the tree representing the store, and the function iscomputed from the contents of all of them prior to the update. Hence,this simulation of assignment fails to capture the full inconvenience ofimperative programming except in the special case of a single valueassigned to a single location, but fortunately this case is the only onemost languages allow.   <p>There is another benefit to this feature besides running languages withassignment statements in them, which is the support of abstract oropaque data structures. A function that takes an abstract data structureas an argument and returns something of the same type can be coded in away that is independent of the fields it doesn't use. For example, adata structure with three fields having the field identifiers<code>foo</code>, <code>bar</code>, and <code>baz</code> in some source language might berepresented as a tuple <code>((</code><var>foo contents</var><code>,</code><var>barcontents</var><code>),</code><var>baz contents</var><code>)</code> on the virtual code level. Compile timeconstants like <code>bar = ((nil,(nil,nil)),nil)</code> could be defined in aneffort to hide the details of the representation, so that the virtualcode <code>field bar</code> is used instead of <code>compose(right,left)</code>. Using field identifiers appropriately, a function that transforms such astructure by operating on the <code>bar</code> field could have the virtual<a name="index-g_t_0040code_007bfield_007d-309"></a>code <code>couple(couple(field foo,compose(f,field bar)),fieldbaz)</code>. However, this code does not avoid depending on the representationof the data structure, because it relies on the assumption of the <code>foo</code>field being on the left of the left, and the <code>baz</code> field being onthe right. On the other hand, the code <code>assign(bar,compose(f,fieldbar))</code> does the same job without depending on anything but the positionof the <code>bar</code> field. Furthermore, if this position were to changerelative to the others, the code maintenance would be limited to arecompilation.   </body></html>
 |