Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-05-2013, 23:10   #1
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
[C++] Template function dentro a una classe

Ciao,
ho una classe che contiene questi typedef:
Codice:
classe MyVector
{
public:
	// ****************** Typedefs for the user
	typedef double		   value_type;
	typedef double&		   reference;
	typedef const double&  const_reference;
	typedef double*		   iterator;
	typedef const double*  const_iterator;
	typedef std::size_t	   size_type;
	typedef std::ptrdiff_t difference_type;
};
Ho un costruttore che costruisce l'oggetto (un vettore di double) partendo da un array di double:
Codice:
MyVector(size_type n, const double* array);
che sfrutta la seguente funzione privata:
Codice:
// Private function for memory management: create a BbVector by copying another BbVector using iterators (similar to one of std::vector constructors)
void MyVector::create(const_iterator b, const_iterator e)
{
	mySize = e - b;
	myVector = alloc.allocate(mySize + 1);
	start = myVector + 1;
	limit = avail = start + mySize;
		
	uninitialized_copy(b, e, start);
}
dove alloc è uno std::allocator<double>.

Ho un altro costruttore, che prende uno std::vector:
Codice:
BbVector::BbVector(const vector<double>& vec)
{
	size_type n = vec.size();

	if (n == 0)
	{
		create();
	}
	else
	{
		create(vec.cbegin(), vec.cend());
	}
}
Purtroppo questo costruttore non compila: la funzione create prende in input un const double*, mentre qui gli passo un std::vector<double>::const_iterator, cioè
typedef __gnu_cxx::__normal_iterator<const_pointer, vector> const_iterator, con tutti i typedef del caso...

Allora ho pensato di rendere create una funzione template, scrivendo:
Codice:
template<class C>
void BbVector::create(typename C::const_iterator b, typename C::const_iterator e)
{
	mySize = e - b;
	myVector = alloc.allocate(mySize + 1);
	start = myVector + 1;
	limit = avail = start + mySize;

	uninitialized_copy(b, e, start);
}
Funziona, solo per il vector, infatti non posso più scrivere:
Codice:
create<const double*>(array, array + n);
giustamente, visto che il tipo const double* non ha un membro chiamato const_iterator...

L'unico modo per farla funzionare quando la invoco passandogli l'array di double è:
Codice:
create<MyVector>(array, array + n);
però mi sembra un po' astruso instanziare un template, definito dentro alla mia classe, usando la classe stessa...
Qualcuno sa suggerirmi una soluzione migliore? Ho appena cominciato a studiare i template in modo approfondito, e sono un po' spaesato
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 00:18   #2
balth@zar
Member
 
Iscritto dal: Jul 2012
Messaggi: 91
Quote:
Allora ho pensato di rendere create una funzione template, scrivendo:
Codice:
template<class C>
void BbVector::create(typename C::const_iterator b, typename C::const_iterator e)
{
	mySize = e - b;
	myVector = alloc.allocate(mySize + 1);
	start = myVector + 1;
	limit = avail = start + mySize;

	uninitialized_copy(b, e, start);
}
Funziona, solo per il vector, infatti non posso più scrivere:
Codice:
create<const double*>(array, array + n);
Ma se fai il template sul tipo di iteratore anzichè sulla classe che definisce il tipo di iteratore non funziona?
Cioè

Codice:
template <typename T>
void BbVector::create(T b, T e) {
  //bla bla bla
}
e poi la chiami con

create<const double*>(...)
create<std::vector<double>::const_iterator>(...)
balth@zar è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 00:59   #3
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da balth@zar Guarda i messaggi
Ma se fai il template sul tipo di iteratore anzichè sulla classe che definisce il tipo di iteratore non funziona?
Cioè

Codice:
template <typename T>
void BbVector::create(T b, T e) {
  //bla bla bla
}
e poi la chiami con

create<const double*>(...)
create<std::vector<double>::const_iterator>(...)
Se la scrivessi così non dovrei specificare gli argomenti del template come dici. Vedi ad esempio std::swap.
Cmq non mi pare la soluzione giusta in quanto non avrei controllo su cosa viene passato alla funzione. Quei T finiscono a std::uninitialized_copy, quindi devono essere dei puntatori. Se però scrivo il template in questo modo, non ho alcun filtro: potrei scrivere
Codice:
bool a, b;
create(a, b);
e il tutto compilerebbe (posto che la userei solo io, in quanto private, e in quanto solo io uso questa semplice classe ma qui voglio capire la teoria!). A quanto ho capito, uno dei punti di forza dei template è la possibilità di eseguire molti check a compile time, quindi credo che andrebbe fatto in un altro modo
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 09:51   #4
balth@zar
Member
 
Iscritto dal: Jul 2012
Messaggi: 91
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Quei T finiscono a std::uninitialized_copy, quindi devono essere dei puntatori. Se però scrivo il template in questo modo, non ho alcun filtro: potrei scrivere
Codice:
bool a, b;
create(a, b);
e il tutto compilerebbe
Non ho provato ma non dovrebbe compilare proprio perchè non compilerebbe unitialized_copy!
balth@zar è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 10:07   #5
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da balth@zar Guarda i messaggi
Non ho provato ma non dovrebbe compilare proprio perchè non compilerebbe unitialized_copy!
Giusto Tosti i template
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 11:07   #6
balth@zar
Member
 
Iscritto dal: Jul 2012
Messaggi: 91
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Giusto Tosti i template
In generale puoi fare un controllo a compile time tramite una classe "traits" che definisce le caratteristiche che deve avere la tua classe parametro.
In questo caso uninitialized_copy utilizza iterator_traits che è naturalmente definita per gli iteratori ed ha una specializzazione per i tipi puntatore (T* e const T*)
Se volessi usare un'altro tipo di iteratore che non rientra nelle casistiche predefinite basterebe scrivere una tua specializzazione di iterator_traits.
balth@zar è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2013, 11:31   #7
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da balth@zar Guarda i messaggi
In generale puoi fare un controllo a compile time tramite una classe "traits" che definisce le caratteristiche che deve avere la tua classe parametro.
In questo caso uninitialized_copy utilizza iterator_traits che è naturalmente definita per gli iteratori ed ha una specializzazione per i tipi puntatore (T* e const T*)
Se volessi usare un'altro tipo di iteratore che non rientra nelle casistiche predefinite basterebe scrivere una tua specializzazione di iterator_traits.
Hmm...in linea teorica ho capito...ora devo fare. Se tutto va bene oggi mi arriva TCPP Programming Language di Stroustrup (nuova edizione col C++11 ), quindi mi vado a leggere subito l'argomento, poi ci provo!
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Oracle Fusion Cloud Applications si pote...
OHB Italia svilupperà un satellit...
Fortinet: "Ora abbiamo una chance d...
Linux Mint chiude con gli aggiornamenti ...
Compressori portatili auto in sconto su ...
Durante il lancio della missione USSF-87...
Dopo il ritiro di Intel da Magdeburgo, l...
Xiaomi 15T scende a 388€ su Amazon: 12GB...
MSI Afterburner: arriva il monitoraggio ...
Missione cinese Chang'e-6: confermata l'...
Addio esenzione sotto i 150 euro: l'UE i...
Allarme riavvii su Windows 11 dopo il ri...
Dynatrace Intelligence: osservabilit&agr...
Jabra a ISE 2026: dalle sale riunioni mo...
La versione potenziata di Siri non &egra...
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: 17:21.


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