[foreign] from memory segments to byte buffers
Maurizio Cimadamore
maurizio.cimadamore at oracle.com
Mon Mar 22 14:09:41 UTC 2021
On 22/03/2021 14:05, Pedro Lamarão wrote:
> Em seg., 22 de mar. de 2021 às 10:26, Maurizio Cimadamore
> <maurizio.cimadamore at oracle.com
> <mailto:maurizio.cimadamore at oracle.com>> escreveu:
>
> > Now that we have got a taste of being able to de-allocate a BB
> deterministically *AND* at the same time being able to pass it
> around whatever we want like before, it will be hard to go back to
> the world you are proposing, the actual semantics is very
> convenient because it doesn't require to change the existing codes.
> I don't think the "it doesn't require changes to the existing
> code" is
> really true though: if you have a byte buffer backed by a memory
> segment
> that is closeable, then your code is not sound unless you use the
> ResourceScope.acquire method when you set up the byte buffer.
>
> So my email was more about "should the API do the acquire
> automatically" ?
>
>
>
> Have you considered the interaction with asynchronous I/O?
Yes - that is why the new API has ResourceScope::acquire. That is, we
are able to make a scope (from which a segment is derived) non-closeable
for a certain span (e.g. when a buffer is enqueued for an async op).
Maurizio
> The buffer life must match the operations life, which is not bound to
> any local scope.
> Of course, in a native API, the user would be required to assure the
> buffer has an appropriate life time.
> So this particular case may reduce to a usability decision on
> asynchronous I/O,
> which may be considered advanced enough so that such requirements are
> reasonable.
>
> --
> Pedro Lamarão
> https://www.prodist.com.br
> <https://urldefense.com/v3/__https://www.prodist.com.br__;!!GqivPVa7Brio!NiXvstU26vx35ShoBrDiOvUNgq1jM9isWY0JpU1P1BD6eZ-SHKpy7hZDtRoxazKnNVKb2mU$>
> Securing Critical Systems
> Tel: +55 11 4380-6585
>
> Antes de imprimir esta mensagem e seus anexos, certifique-se que seja
> realmente necessário.
> Proteger o meio ambiente é nosso dever.
> Before printing this e-mail or attachments, be sure it is necessary.
> It is in our hands to protect the environment.
>
More information about the panama-dev
mailing list