|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
|
[C++] alcune domande sulle list
Ciao a tutti,
ho il mio bell'oggetto file_fs creato con una classe Codice:
class file_fs{ ... }
Codice:
list<file_fs> archivio; Avevo pensato a qualcosa del genere: Codice:
void repository::unregister_file(file_fs x)
{
if(archivio.empty()){
sys_warn("Archivio Vuoto");
return;
}
list<file_fs>::iterator it;
for(it=archivio.begin(); it != archivio.end(); it++){
file_fs y = it.????;
if(y.equals(x)) it = archivio.erase(it);
}
}
NB: equals(file_fs x) è un metodo che mi sono implementato io nella classe file_fs ed è il seguente: Codice:
bool file_fs::equals(file_fs x)
{
string nf = x.get_file_name();
string ip = x.get_fs_ip();
int port = x.get_fs_port();
if((nome_file.compare(nf) == 0) && (fs_ip.compare(ip) == 0) && (fs_port == port)) return true;
else return false;
}
E se volessi usare il metodo remove() di <list> che rimuove dalla lista un oggetto con un determinato valore? In Java avrei dovuto implementare Comparable e ridefinire il metodo compareTo()... qui come si fa?
__________________
|
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
|
Questa soluzione è corretta?
Quote:
__________________
|
|
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
|
Altra domandina
Per un metodo che deve cercare un oggetto file_fs sulla lista e ritornarlo avevo pensato di fare: Quote:
Codice:
strutture/repository.cpp: In member function ‘file_fs repository::get_file_fs(std::string)’: strutture/repository.cpp:44: error: conversion from ‘int’ to non-scalar type ‘file_fs’ requested strutture/repository.cpp:55: error: conversion from ‘int’ to non-scalar type ‘file_fs’ requested
__________________
|
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
|
Cosi su due piedi nn ricordo come funziona remove su oggetti creati da te. Volendo puoi usare remove_if passando un opportuno operatore di confronto.
Per quanto riguarda il get fatto da te è concettualmente errato. Da quel che leggo sembri essere ancora troppo legato alla programmazione java. Un get fatto cosi ti ritorna un istanza di file_fs vera e propria. Per quello che il compilatore si arrabbia. NULL (o anche 0) non è compatibile con file_fs. Per correggerlo basta che gli fai tornare un reference o un puntatore. Ovviamente spero di nn aver scritto vaccate immani e confido che qualcuno molto più saggio di me passi a dare un occhio Saluti
__________________
iMac 27" 5K |
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
|
Quote:
Ho studiato un po' Codice:
file_fs* repository::get_file_fs(string nomefile)
{
//controllo che l'archivio non sia vuoto
if(archivio.empty()){
sys_warn("Archivio Vuoto");
return NULL;
}
list<file_fs>::iterator it;
for(it=archivio.begin(); it != archivio.end(); it++){
if((*it).get_file_name().compare(nomefile) == 0)
return &(*it);
}
return NULL;
}
Ora è giusto?
__________________
|
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:10.




















