[DOCS] Update reference types.

This commit is contained in:
chriseth 2018-09-19 16:11:52 +02:00
parent c43bbd1a68
commit fb8617f059

View File

@ -648,21 +648,27 @@ Another example that uses external function types::
.. index:: ! type;reference, ! reference type, storage, memory, location, array, struct .. index:: ! type;reference, ! reference type, storage, memory, location, array, struct
Reference Types Reference Types
================== ===============
Complex types, i.e. types which do not always fit into 256 bits have to be handled Values of reference type can be modified through multiple different names.
more carefully than the value-types we have already seen. Since copying Contrast this with value types where you get an independent copy whenever
them can be quite expensive, we have to think about whether we want them to be a variable of value type is used. Because of that, reference types have to be handled
stored in **memory** (which is not persisting) or **storage** (where the state more carefully than value types. Currently, reference types comprise structs,
variables are held). arrays and mappings. If you use a reference type, you always have to explicitly
provide the data area where the type is stored: ``memory`` (whose lifetime is limited
to a function call), ``storage`` (the location where the state variables are stored)
or ``calldata`` (special data location that contains the function arguments,
only available for external function call parameters).
An assignment or type conversion that changes the data location will always incur an automatic copy operation,
while assignments inside the same data location only copy in some cases for storage types.
.. _data-location: .. _data-location:
Data location Data location
------------- -------------
Every reference type, i.e. *arrays* and *structs*, has an additional
Every complex type, i.e. *arrays* and *structs*, has an additional
annotation, the "data location", about where it is stored. There are three data locations: annotation, the "data location", about where it is stored. There are three data locations:
``memory``, ``storage`` and ``calldata``. Calldata is only valid for parameters of external contract ``memory``, ``storage`` and ``calldata``. Calldata is only valid for parameters of external contract
functions and is required for this type of parameter. Calldata is a non-modifiable, functions and is required for this type of parameter. Calldata is a non-modifiable,