Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-11-2009, 15:51   #1
panda84
Senior Member
 
L'Avatar di panda84
 
Iscritto dal: Feb 2007
Messaggi: 472
[C++] Reimplementazione vector e uso iterator.

Ciao a tutti!

Per motivi vari (vecchio sistema operativo embebbed che gira dentro un vecchio e malfunzionante simulatore ARM di cui non posso fare a meno) sto reimplementando una piccola parte della classe vector in modo da poter utilizzare codice di terze parti che usa la succitata classe senza doverne modificare tutto il codice.

Sono riuscito a implementare tutti i metodi di base che mi servono dalla classe vector e sembra funzionare tutto senza problemi. Ora ho un ultimo scoglio da superare; ho letto qui:
http://www.cplusplus.com/reference/std/iterator/
che il puntatore è una forma di iteratore. Per semplicità, visto che non sono pratico di iteratori, ho utilizzato temporaneamente dei puntatori. Ad esempio invece di definire:
Codice:
iterator begin ();
come nelle STL:
http://www.cplusplus.com/reference/stl/vector/begin/
ho utilizzato:
Codice:
T* begin();
Ora però, mentre con l'implementazione STL di vector i cicli si fanno così:
Codice:
for (vector<int>::iterator it = myobject.begin(); it != myobject.end(); it++)
io devo farli così.
Codice:
for (int* it = myobject.begin(); it != myobject.end(); it++)
Cosa devo cambiare nella mia implementazione per usare la sintassi originale? Ovvero, non capisco cosa devo fare "internamente" alla mia versione di vector per ottenere "esternamente" la sintassi:
Codice:
vector<int>::iterator
Anche in questo esempio:
http://www.cplusplus.com/reference/s...ator/iterator/
ottengono:
Codice:
myiterator it=beginning
Scusate, ma credo di avere ancora qualche difficoltà con le classi template...

Grazie a chiunque proverà ad aiutarmi!
Diego


P.S.: Se volete vedere la mia "barbara" implementazione di vector posso metterla su pastebin senza problema.
panda84 è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 16:40   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ti definisci una classe iterator pubblica all'interno di vector. Al suo interno contiene un puntatore al tipo del vector. Ti devi ridefinire l'operatore ++ e l'operatore *.

Altra alternativa, magari stupida e che non ti consente tutto il controllo del normale iterator è

typedef T* iterator;

all'interno di vector.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 16:40   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da panda84 Guarda i messaggi
P.S.: Se volete vedere la mia "barbara" implementazione di vector posso metterla su pastebin senza problema.
Vai
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 17:15   #4
panda84
Senior Member
 
L'Avatar di panda84
 
Iscritto dal: Feb 2007
Messaggi: 472
Quote:
Originariamente inviato da cionci Guarda i messaggi
Ti definisci una classe iterator pubblica all'interno di vector. Al suo interno contiene un puntatore al tipo del vector. Ti devi ridefinire l'operatore ++ e l'operatore *.

Altra alternativa, magari stupida e che non ti consente tutto il controllo del normale iterator è

typedef T* iterator;

all'interno di vector.
Ottimo, grazie mille dei consigli! Domani faccio sapere l'esito degli esperimenti.


Ecco l'implementazione... se vedete qualche castrone, è normale: sono i miei primi esperimenti con C++! Se però me li fate notare vi ringrazio.
http://pastebin.com/m2b276848
Per ora mi basta che funzioni, poi gli accessori li aggiungo dopo (tipo l'array si allunga ma non si accorcia). È molto limitato, ma per quello che andrà a fare va più che benone...
panda84 è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 17:34   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ho visto che ogni volta fai una copia. Non è secondo me una buona politica. Ovviamente è l'unica utilizzando il typdef per l'iterator, ma se ti crei una classe per l'iterator allora ti conviene fare un'allocazione a blocchi.
Per simulare la continuità dell'array basta fare un'operazione del genere:
data[i / BLOCK_SIZE][i % BLOCK_SIZE]

Ovviamente in data[i / BLOCK_SIZE] ci sarà l'indirizzo del blocco allocato in memoria.
Quando allochi un nuovo blocco dovrai solo allungare il vettore data, copiandone i valori (in teoria puoi fare anche questo a blocchi di M elementi, così fai una copia solo ogni N * BLOCK_SIZE elementi inseriti nel vettore).
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 22:11   #6
panda84
Senior Member
 
L'Avatar di panda84
 
Iscritto dal: Feb 2007
Messaggi: 472
Quote:
Originariamente inviato da cionci Guarda i messaggi
Ho visto che ogni volta fai una copia. Non è secondo me una buona politica. Ovviamente è l'unica utilizzando il typdef per l'iterator, ma se ti crei una classe per l'iterator allora ti conviene fare un'allocazione a blocchi.
Per simulare la continuità dell'array basta fare un'operazione del genere:
data[i / BLOCK_SIZE][i % BLOCK_SIZE]

Ovviamente in data[i / BLOCK_SIZE] ci sarà l'indirizzo del blocco allocato in memoria.
Quando allochi un nuovo blocco dovrai solo allungare il vettore data, copiandone i valori (in teoria puoi fare anche questo a blocchi di M elementi, così fai una copia solo ogni N * BLOCK_SIZE elementi inseriti nel vettore).
Ma ne sai a pacchi!
Ti sei guadagnato una citazione nei rigraziamenti della mia tesi!

Nel frattempo ho scoperto un altro errore da niubbo: non si possono separare i template in .h e .cpp. Cioè compilare compila, ma al momento di linkare sono inni che si elevano al signore...

Domani a mente fresca sistemerò un po' il tutto, intanto grazie ancora.
panda84 è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2009, 23:07   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Di niente
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Collasso digitale alle porte? Quali sono...
Qualcomm 'schiaccia' Arm in tribunale: v...
Meta spinge sull'indipendenza da NVIDIA:...
Spotify rivoluziona la sua guida: Daniel...
Sora 2: la seconda generazione del model...
Nuovo obiettivo FE 100mm F2.8 Macro GM O...
Steelseries Arctis Nova Elite: le prime ...
30 anni di PlayStation da indossare: arr...
Amazon lancia gli Echo più potent...
Amazon rinnova la gamma Fire TV: ecco le...
Ring lancia le sue prime videocamere con...
Blink amplia la gamma di videocamere di ...
Jaguar Land Rover riprende (gradualmente...
HONOR inaugura il primo ALPHA Flagship S...
Yamaha: ecco il brevetto del 'finto moto...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 06:08.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v