Dope vector

struttura dati che rappresenta il layout di memoria di un oggetto

Nella teoria della programmazione, il dope vector (in italiano "vettore di informazione") è una struttura dati che contiene le informazioni su un oggetto[1] (ad esempio un array) e in particolare il suo layout in memoria. È tipicamente usato nei compilatori dei linguaggi di programmazione ad alto livello per passare array alle subroutine.[2]

Il dope vector di un array contiene usualmente almeno rango (numero di dimensioni), extent (intervalli degli indici) e stride (la distanza in memoria tra due elementi consecutivi, che può differire dall'effettiva dimensione dell'elemento per via dell'allineamento della memoria), oltre al puntatore ad un elemento fisso rispetto al quale si calcola l'offset degli altri elementi (tipicamente l'elemento iniziale). La posizione in memoria di un generico elemento dell'array si ottiene sommando l'indirizzo di tale elemento fisso con il prodotto scalare dello stride per la differenza tra l'ennupla di indici che individuano l'elemento e l'ennupla dei valori iniziali per ogni indice (se i valori iniziali sono tutti nulli, come ad esempio in C, la differenza corrisponde all'ennupla stessa degli indici).[3]

  1. ^ Pratt T. and M. Zelkowitz, Programming Languages: Design and Implementation (Third Edition), Prentice Hall, Upper Saddle River, NJ, (1996) pp 114
  2. ^ Keith Cooper e Linda Torczon, Engineering a Compiler, 2ª ed., Elsevier, 2011, pp. 366-367, ISBN 978-0-08-091661-3.
  3. ^ John Daintith. "dope vector." A Dictionary of Computing. 2004. Encyclopedia.com. 13 Dec. 2015 <http://www.encyclopedia.com>.
  Portale Informatica: accedi alle voci di Wikipedia che trattano di informatica