Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
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


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Sottile, veloce e con un'ottima autonomi...
Il top di gamma compatto di OnePlus &egr...
Modificare l'indirizzo Gmail è finalment...
Perché le GeForce RTX con pi&ugra...
Più tempo online non equivale a più disa...
Amazon Weekend: iPhone 17 Pro, robot asp...
TV OLED 65'' top di gamma al 50%: 144Hz,...
Londra si prepara al terremoto 'intellig...
Scope elettriche in offerta su Amazon: f...
iPhone 17 Pro a un nuovo minimo storico ...
DJI Mini 4 Pro Fly More Combo a 859€ su ...
Roborock in offerta su Amazon: QV 35A e ...
Crisi della RAM: Intel rassicura sul mer...
Dreame taglia i prezzi su Amazon: L40 Ul...
ChatGPT, arrivano gli annunci pubblicita...
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: 16:06.


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