digraph edges and improper lists
Fred Youhanaie
fly@REDACTED
Mon Dec 20 18:12:28 CET 2021
Hi Dmytro
Many thanks for the explanation and the links.
So, we save memory when using an improper list instead of proper list of 2 elements.
How about 2-element tuples? It seems to be similar to the improper list, but I haven't read text properly yet!
Cheers,
Fred
On 20/12/2021 16:28, Dmytro Lytovchenko wrote:
> A list of 2 elements will consume:
> 1 list cell (2 words of memory) to store $n and pointer to second cell
> 1 list cell (2 more words) to store N and [] (that's nil, end of proper list)
> total: 4 words of memory, on a 64 bit machine that's 32 bytes
>
> An improper list of 2 elements will consume:
> 1 list cell (2 words of memory) to store $n and tail is stored as N
> total 16 bytes of memory on 64 bit machine
>
> http://beam-wisdoms.clau.se/en/latest/indepth-memory-layout.html#lists-cons <http://beam-wisdoms.clau.se/en/latest/indepth-memory-layout.html#lists-cons>
> http://beam-wisdoms.clau.se/en/latest/indepth-data-sizes.html#list <http://beam-wisdoms.clau.se/en/latest/indepth-data-sizes.html#list>
>
> On Mon, 20 Dec 2021 at 17:23, Fred Youhanaie <fly@REDACTED <mailto:fly@REDACTED>> wrote:
>
> Hi
>
> The digraph module uses the term ['$e'|N] to represent an edge.
>
> Is there an advantage in using an improper list, as opposed to the more intuitive tuple format {'$e', N}?
>
> I recently came across a situation where the following crashed because logger tried to flatten the list of improper lists!
>
> logger:notice(#{ edges => digraph:edges(G) }).
>
> However, these two were OK:
>
> logger:notice(#{ edges => { digraph:edges(G) } }). %% Note the extra braces
> logger:notice("edges = ~w", [digraph:edges(G)] ).
>
> For me this was a temporary annoyance, but I'm just curious about the choice of list structure. Is this explained anywhere, such as docs or a blog?
>
> Cheers,
> Fred
>
More information about the erlang-questions
mailing list