mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
[DOCS] Update reference types.
This commit is contained in:
parent
c43bbd1a68
commit
fb8617f059
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user