Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-01-2009, 13:12   #1
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
[C++] qualche domandina su array e iteratori

Salve a tutti
Per un progetto universitario dovrei realizzare un'implementazione di coda FIFO che utilizzi una struttura dati di tipo array.
Ora ecco le mie perplessità:
-se io avessi una struct fatta così:
Codice:
struct Dato {
    int a;
    double b;
    string c;
}
e mi creassi un array di tale struttura, dove verrebbe allocato tare array?
Codice:
Dato dati[100]; //è allocato nello stack o nello heap??? (suppongo stack)
Dato *dati = new Dato[100]; //stessa domanda di prima (suppongo heap)
-come potrei realizzare un iteratore che mi iteri su un array?

Spero di non aver contravvenuto a nessuna regola chiedendovi queste cose Ovviamente con la seconda domanda non vi chiedo l'implementazione di un iteratore su array ma soltanto un idea di come realizzarlo

Grazie e saluti
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2009, 14:41   #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
Nel primo caso il vettore è allocato nello stack, ma ciò non esclude che l'elemento c possa allocare spazio nello heap (è una string).

Nel secondo caso il puntatore dati è allocato nello stack, la memoria puntata da dati è allocata nello heap.

Spiega meglio il caso in cui ti serve questo iteratore.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2009, 14:59   #3
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
Ok allora la questione degli array è come la supponevo io
Quell'iteratore mi serve per un accesso in lettura e scrittura dei dati contenuti nell'array.
Ora non capisco però a cosa mi serva iterare su una coda fifo...dopotutto devo solo aggiungere elementi in coda e prelevarli in testa
Può essere che l'iteratore mi serva proprio per la gestione degli inserimenti/estrazioni dei dati?

Grazie per la risposta
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2009, 15:22   #4
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 chiedevo appunto di chiarire meglio la questione dell'iteratore.
Mi sembra di capire che tu non voglia usare gli iteratori del C++, ma crearti un tuo iteratore non "imparentato" con quelli.
Sicuramente puoi costruirti un iteratore per scorrere tutti gli elementi dalla testa alla coda o viceversa.
La Fifo mi immagino che sia circolare...giusto ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2009, 15:41   #5
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
Non è che non voglio usarli eheh è che non posso
Fosse stato per me non mi sarei nemmeno messo a reinventarmi la ruota con un progetto del genere dopotutto nelle stl la collezione queue gia esiste
Ora vedo di buttare giu del codice che qualche idea mi è venuta

Grazie mille per le risposte
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2009, 16:02   #6
Vincenzo1968
Bannato
 
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
In effetti non hai bisogno di un iteratore. Per implementare una coda tramite array(si può implementare anche con lista concatenata), devi mantenere due indici. Il primo, head, punta al primo elemento; il secondo, tail, punta all'ultimo.

Il codice seguente implementa una coda di interi(è in C ma puoi facilmente adattarlo ):

Codice:
#include <stdio.h>

#define max 50

static int queue[max+1], head, tail;

void queue_put(int v)
{
	queue[tail++] = v;
	if ( tail > max )
		tail = 0;
}

int queue_get()
{
	int t = queue[head++];
	if ( head > max )
		head = 0;
	return t;
}

void queue_init()
{
	head = tail = 0;
}

int queue_empty()
{
	return head == tail;
}

int main()
{
	queue_init();

	queue_put(5);
	queue_put(8);
	queue_put(13);
	queue_put(21);
	queue_put(55);

	while ( !queue_empty() )
		printf("%d\n", queue_get());

	return 0;
}
Vincenzo1968 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2009, 10:40   #7
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
Sono riuscito ad implementare sta maledetta coda appoggiandomi su un array circolare che viene riallocato quando è pieno. Ho anche implementato gli iteratori (che ovviamente sono inutili su una coda, ma che il prof ci ha richiesto), ma ora stò maledettamente appeso su una cosa....l'operator=
Vi posto il codice incriminato:
file coda_i.hpp
Codice:
template <typename T>
coda<T>::coda(const coda<T>& c) : n_elementi(0), max_elementi(5), h_index(0), t_index(0) {
    if(c.isEmpty())
        return;
    n_elementi = c.n_elementi;
    max_elementi = c.max_elementi;
    dati = new typename coda<T>::dato_t[max_elementi];
    for(int i = 0; i < n_elementi; i++) dati[i] = c.dati[i];
    h_index = c.h_index;
    t_index = c.t_index;
}

template <typename T>
coda<T>& coda<T>::operator=(const coda<T>& c) {
    if(this == &c)
        return *this;
    coda<T> tmp(c); //non lavora correttamente e non sò perchè!!!
    tmp.swap(*this);
    return *this;
}

template <typename T>
void coda<T>::swap(coda<T>& c) {
    std::swap(c.n_elementi, n_elementi);
    std::swap(c.max_elementi, max_elementi);
    std::swap(c.h_index, h_index);
    std::swap(c.t_index, t_index);
    std::swap(c.dati, dati);
}
file main.cpp
Codice:
void testCostruttori() {
    coda<char*> c;
    c.enqueue("ciao");
    c.enqueue("sono");
    c.enqueue("una");
    c.enqueue("stringa");
    cout << c << endl;

    coda<char*> c1(c);
    c1.dequeue();
    cout << c1 << endl;

    /*Codice che genera l'errore!!!
    coda<char*> c2;
    c2 = c1;
    c2.dequeue();
    cout << c2 << endl;*/
}
Quando tento di eseguire il codice nel main che vi ho postato, l'applicazione esplode!!!
Sono riuscito a risalire all'esatta riga che fallisce ed è quella boldata in doda_i.hpp. Praticamente creo una coda temporanea mediante il copy constructor (che funziona alla grande, l'ho provato miliardi di volte), e poi vado a scambiare i valori della mia coda con quelli della coda temporanea che a fine scope verrà automaticamente distrutta...Il problema è che se vado a stampare quella coda temporanea subito dopo la sua creazione, mi sono accorto che, a differenza delle altre code che creo per copia e che sono perfette, questa contiene un array di dati che è sbagliato!!! Solo che non sò come mai
Suggerimenti??

Grazie in anticipo

Saluti
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 12:00   #8
Maurogiuseppe
Junior Member
 
Iscritto dal: Jan 2009
Messaggi: 2
Ancora problemi?

Ma a te interessa la coda con puntatori o con vettore circolare? Se ti servono entrambe posso mandarti tutto tramite mail.
Maurogiuseppe è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2009, 12:33   #9
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
Tranco ho risolto tutto facevo boiate io eheheh
Cmq a me interessa una coda implementata mediante array circolare sulla quale poi ci devo appoggiare degli iteratori, per poterla usare con gli algoritmi della stl (mi bastano i forward_iterator).
Ora, io ho fatto tutto ma voci di corridoio dicono che la mia implementazione non piaccia molto, praticamente negli iteratori scorro l'array mediante indici, mentre il prof preferirebbe l'utilizzo di puntatori...ora vedo se riesco a tirare fuori il coniglio dal cilindro
La mia idea per far contento il prof era questa:
-uso un array circolare per la mia coda
-faccio gli enqueue e dequeue in modo opportuno (sistemando gli indici con il gioco del modulo)
-se la coda è piena la espando (con un nuovo array che poi swappo)
-quando chiamo begin (che ritorna l'iteratore corrispondente alla testa), se l'indice di testa non è in 0, sistemo la coda (sposto tutti gli elementi in modo che la testa stia in 0)
-uso degli iteratori banalissimi che mi incrementano il puntatore del mio array per scorrerlo
Il problema è che sta cosa la posso fare tranzollamente con gli iterator, ma con i const_iterator giustamente non posso modificare nulla della coda (sono appunto const) quindi non posso risistemare l'array...
Devo trovare una soluzione elegante a questo problema visto che l'alternativa è quella di sistemare l'array ad ogni dequeue e quindi dimenticarmi dell'array circolare
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Un gruppo di ladri ha usato Google Maps ...
Apple non si fida di Samsung per la real...
Windows 11: un nuovo driver nativo mette...
Vi hanno regalato buoni Amazon? Intanto ...
Via acari, polvere e sporco da materassi...
Cuffie Beats in super offerta su Amazon,...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
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: 05:24.


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