mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Split Constant State Variables doc
This commit is contained in:
parent
aca9e58145
commit
1da2c1f7e4
@ -441,41 +441,7 @@ all symbols visible from the function are visible in the modifier. Symbols
|
|||||||
introduced in the modifier are not visible in the function (as they might
|
introduced in the modifier are not visible in the function (as they might
|
||||||
change by overriding).
|
change by overriding).
|
||||||
|
|
||||||
.. index:: ! constant
|
.. include:: contracts/constant-state-variables.rst
|
||||||
|
|
||||||
************************
|
|
||||||
Constant State Variables
|
|
||||||
************************
|
|
||||||
|
|
||||||
State variables can be declared as ``constant``. In this case, they have to be
|
|
||||||
assigned from an expression which is a constant at compile time. Any expression
|
|
||||||
that accesses storage, blockchain data (e.g. ``now``, ``address(this).balance`` or
|
|
||||||
``block.number``) or
|
|
||||||
execution data (``msg.value`` or ``gasleft()``) or makes calls to external contracts is disallowed. Expressions
|
|
||||||
that might have a side-effect on memory allocation are allowed, but those that
|
|
||||||
might have a side-effect on other memory objects are not. The built-in functions
|
|
||||||
``keccak256``, ``sha256``, ``ripemd160``, ``ecrecover``, ``addmod`` and ``mulmod``
|
|
||||||
are allowed (even though, with the exception of ``keccak256``, they do call external contracts).
|
|
||||||
|
|
||||||
The reason behind allowing side-effects on the memory allocator is that it
|
|
||||||
should be possible to construct complex objects like e.g. lookup-tables.
|
|
||||||
This feature is not yet fully usable.
|
|
||||||
|
|
||||||
The compiler does not reserve a storage slot for these variables, and every occurrence is
|
|
||||||
replaced by the respective constant expression (which might be computed to a single value by the optimizer).
|
|
||||||
|
|
||||||
Not all types for constants are implemented at this time. The only supported types are
|
|
||||||
value types and strings.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
pragma solidity >=0.4.0 <0.6.0;
|
|
||||||
|
|
||||||
contract C {
|
|
||||||
uint constant x = 32**22 + 8;
|
|
||||||
string constant text = "abc";
|
|
||||||
bytes32 constant myHash = keccak256("abc");
|
|
||||||
}
|
|
||||||
|
|
||||||
.. index:: ! functions
|
.. index:: ! functions
|
||||||
|
|
||||||
|
35
docs/contracts/constant-state-variables.rst
Normal file
35
docs/contracts/constant-state-variables.rst
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
.. index:: ! constant
|
||||||
|
|
||||||
|
************************
|
||||||
|
Constant State Variables
|
||||||
|
************************
|
||||||
|
|
||||||
|
State variables can be declared as ``constant``. In this case, they have to be
|
||||||
|
assigned from an expression which is a constant at compile time. Any expression
|
||||||
|
that accesses storage, blockchain data (e.g. ``now``, ``address(this).balance`` or
|
||||||
|
``block.number``) or
|
||||||
|
execution data (``msg.value`` or ``gasleft()``) or makes calls to external contracts is disallowed. Expressions
|
||||||
|
that might have a side-effect on memory allocation are allowed, but those that
|
||||||
|
might have a side-effect on other memory objects are not. The built-in functions
|
||||||
|
``keccak256``, ``sha256``, ``ripemd160``, ``ecrecover``, ``addmod`` and ``mulmod``
|
||||||
|
are allowed (even though, with the exception of ``keccak256``, they do call external contracts).
|
||||||
|
|
||||||
|
The reason behind allowing side-effects on the memory allocator is that it
|
||||||
|
should be possible to construct complex objects like e.g. lookup-tables.
|
||||||
|
This feature is not yet fully usable.
|
||||||
|
|
||||||
|
The compiler does not reserve a storage slot for these variables, and every occurrence is
|
||||||
|
replaced by the respective constant expression (which might be computed to a single value by the optimizer).
|
||||||
|
|
||||||
|
Not all types for constants are implemented at this time. The only supported types are
|
||||||
|
value types and strings.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
pragma solidity >=0.4.0 <0.6.0;
|
||||||
|
|
||||||
|
contract C {
|
||||||
|
uint constant x = 32**22 + 8;
|
||||||
|
string constant text = "abc";
|
||||||
|
bytes32 constant myHash = keccak256("abc");
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user