Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-10-2013, 17:59   #1
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
[C/C++] Manipolare nomi di variabili con MACRO

Ciao,
sto scrivendo una classe con tante proprietà, e vorrei farlo tramite una macro: anzichè ripetere ogni volta getter e setter:
Codice:
private:
    int m_var;
public:
    int var() const { return m_var; }
    void setVar(int newVar) { m_var = newVar; }
vorrei usare una macro. Finora ho partorito questo:
Codice:
#define DECLARE_QPROPERTY(type, name)											\
	private: type m_##name = 3;													\
	public: type name() const { return m_##name; }								\
	public: void setname(type new##name) { m_##name = new##name; }
però così il setter sarebbe, ad esempio per una variabile pippo, setpippo() anzichè setPippo(). C'è un modo fare questa cosa via macro o devo ricorrere a set_pippo?
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2013, 18:06   #2
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
E dare semplicemente ai campi di classe nomi che iniziato con lettera maiuscola?

ps: la nomenclatura classica per i getter/setter solitamente non è getValue, setValue?
ps2: odio con tutta la mia anima i getter/setter. Siano lodate le property (alla C# per intendersi)

Ultima modifica di [Kendall] : 15-10-2013 alle 18:09.
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2013, 18:15   #3
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da [Kendall] Guarda i messaggi
E dare semplicemente ai campi di classe nomi che iniziato con lettera maiuscola?

ps: la nomenclatura classica per i getter/setter solitamente non è getValue, setValue?
ps2: odio con tutta la mia anima i getter/setter. Siano lodate le property (alla C# per intendersi)
Già, son comode, ho anche cercato vari modi per riprodurle in C++ ma alcuni hanno overhead, altri non ce l'hanno ma funzionano solo con POD...
Cmq non sono indispensabili, non mi infastidisce troppo il dover scrivere i getter/setter.

Niente lettere maiuscole per i campi privati, te lo insegnano anche in C#
La nomenclatura standard prevede getValue, ma solo value() mi sembra molto pulito e cmq logico, anzi, più pulito di getValue, semanticamente, in certi usi. Infatti, considera la proprietà "inSecondFunction" della mia calcolatrice. Nella UI scriverei:
if (casio.inSecondFunction)
anzichè
if (casio.getInSecondFunction)
molto meglio

Cmq ho provato così:
Codice:
#define DECLARE_QPROPERTY(type, name, readonly, notify)								\
	private: type m_##name;														\
	public: type name() const { return m_##name; }									\
#if !readonly
	public Q_SLOTS: void set_##name(type n##name) { m_##name = n##name; }		\
#endif
#if notify
	Q_SIGNALS: void name##Changed();
#endif
ma a quanto pare non posso usare #if dentro alla dichiarazione della macro...vorrei rendere alcune funzioni (tra cui il setter) opzionali. Oscure ste macro, e poi non c'è neanche tanta documentazione in giro!

Ultima modifica di vendettaaaaa : 15-10-2013 alle 18:27.
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2013, 18:29   #4
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Già, son comode, ho anche cercato vari modi per riprodurle in C++ ma alcuni hanno overhead, altri non ce l'hanno ma funzionano solo con POD...
Cmq non sono indispensabili, non mi infastidisce troppo il dover scrivere i getter/setter.
Prendi mano con le property C# e poi dimmi ...

Riguardo ai nomi dei campi, io uso sempre la nomenclatura _value, a mio modo di vedere la migliore per identificarli in maniera precisa e "ad occhio".
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2013, 18:32   #5
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Penso che questa soluzione sia ragionevole:
Codice:
#define DECLARE_QPROPERTY(type, name)				\
	private: type m_##name;						\
	public: type name() const { return m_##name; }	\
	Q_PROPERTY(type name READ name)

#define DECLARE_QPROPERTY_WRITE(type, name)									\
	private: type m_##name;												\
	public: type name() const { return m_##name; }							\
	public Q_SLOTS: void set_##name(type n##name) { m_##name = n##name; }	\
	Q_PROPERTY(type name READ name WRITE set_##name)

#define DECLARE_QPROPERTY_NOTIFY(type, name)								\
	private: type m_##name;												\
	public: type name() const { return m_##name; }							\
	Q_SIGNALS: void name##Changed();										\
	Q_PROPERTY(type name READ name WRITE set_##name)

#define DECLARE_QPROPERTY_WRITE_NOTIFY(type, name)							\
	private: type m_##name;												\
	public: type name() const { return m_##name; }							\
	public Q_SLOTS: void set_##name(type n##name) { m_##name = n##name; }	\
	Q_SIGNALS: void name##Changed();										\
	Q_PROPERTY(type name READ name WRITE set_##name NOTIFY name##Changed)
@Kendall: ho scritto qualche migliaio di righe di C#, non troppo ma abbastanza da avere la mano E riconosco che son comode, ci mancherebbe!
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
Le nuove offerte Amazon, con aggiornamen...
5 motivi per comprare oggi Motorola Edge...
I produttori di memorie non vogliono inv...
VMware Hosted Private Cloud, il cloud pr...
Le cuffie per giocatori JBL Quantum 910X...
Xiaomi Watch S3 a prezzo dimezzato: 15 g...
Nothing Phone (2a) a poco più di ...
OnePlus prepara due nuovi tablet Android...
ASUS Zenbook supera MacBook Air in tutto...
Amazfit Active 2 a 71,49€ protagonista d...
Tutti gli iPhone avranno display ProMoti...
DLSS 5 irriso sul web, secondo il CEO di...
Scoperta al CERN una particella mai vist...
Stampante HP a 37,99€: Wi-Fi, scanner e ...
OPPO annuncia l'arrivo in Italia della A...
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: 10:47.


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