Re: Array vs. Linked List Traversal

Liste des GroupesRevenir à c arch 
Sujet : Re: Array vs. Linked List Traversal
De : chris.m.thomasson.1 (at) *nospam* gmail.com (Chris M. Thomasson)
Groupes : comp.arch
Date : 01. Aug 2024, 23:12:06
Autres entêtes
Organisation : A noiseless patient Spider
Message-ID : <v8gtn7$2cpd9$1@dont-email.me>
References : 1 2
User-Agent : Mozilla Thunderbird
On 8/1/2024 12:14 PM, Stefan Ram wrote:
jseigh <jseigh_es00@xemaps.com> wrote or quoted:
It's claimed that array traversal is faster than linked list
traversal.  What would be the reasons for that?
    Array traversal is hella faster than linked list traversal for a few
   key reasons:
    Cache Magic: Arrays stack elements right next to each other in
   memory, so when you hit one element, the CPU cache scoops up the
   neighbors too. It's like grabbing a whole burrito instead of just
   one bean at a time.
[...]
Fwiw, wrt a "special case" a linked list that is "sorted" can sometimes be pretty fast for traversal. ;^)
l2 = cache line
An array aligned on a cache line boundary { l2, l2, l2 }
a linked list
n(&array[0])->n(&array[1])->n(&array[2])->nullptr
If you can use an array, use an array. Fwiw, here is a tweak I did to a pretty darn nice bounded multi-producer/consumer FIFO queue:
https://groups.google.com/g/lock-free/c/acjQ3-89abE/m/a6-Di0GZsyEJ
Wrt region allocators, properly align a bunch of cache lines in an array. Feed off that array if a local node cannot be allocated or until its all used up. Something akin to:
node* allocate()
{
     node* local = allocate_local();
     if (! local)
     {
         local = allocate_global();
         if (! local)
         {
             local = allocate_region();
             if (! local)
             {
                 local = allocate_region_expand();
                 if (! local)
                 {
                     // humm... really out of memory here?
                 }
             }
         }
     }
     return local;
}
Just a quick outline.

Date Sujet#  Auteur
1 Aug 24 * Array vs. Linked List Traversal7jseigh
1 Aug 24 +* Re: Array vs. Linked List Traversal2MitchAlsup1
2 Aug 24 i`- Re: Array vs. Linked List Traversal1Lawrence D'Oliveiro
1 Aug 24 +- Re: Array vs. Linked List Traversal1Anton Ertl
1 Aug 24 `* Re: Array vs. Linked List Traversal3Stefan Ram
1 Aug 24  +- Re: Array vs. Linked List Traversal1Chris M. Thomasson
2 Aug 24  `- Re: Array vs. Linked List Traversal1Stephen Fuld

Haut de la page

Les messages affichés proviennent d'usenet.

NewsPortal