The hardware and bandwidth for this mirror is donated by METANET, the Webhosting and Full Service-Cloud Provider.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]metanet.ch.
Methods that alter Container objects usually come in two versions
providing either copy or reference semantics where the latter start with
‘ref_’ to note the reference semantic, for example, add()
and ref_add()
.
Since reference semantics changes the original object, it can be used to save some typing.
Although these days this usually can be achieved equally easy using pipes.
Still there might be use cases, where it makes your life a bit easier. Consider the following silly example.
odds = container()
evens = container()
isOdd = function(x) {x %% 2 == 1}
res = sapply(1:10, function(i)
if(isOdd(i)) ref_add(odds, i) else ref_add(evens, i)
)
odds
# [1L, 3L, 5L, 7L, 9L]
evens
# [2L, 4L, 6L, 8L, 10L]
Using reference semantics for it’s side effects (as in the above example) should be really done with care though and in most cases is probably best avoided as you risk introducing unnecessary coupling into your code.
Last but not least, reference semantics can make sense when you are dealing with very large objects to avoid copying. Although, these days R often is smart enough to only copy those parts of an objects, for which a copy is really needed (copy-on-modify).
To summarize, the container
package does provide
reference semantics, but it should be used with care.
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.