Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-09-2009, 18:52   #1
Ikon O'Cluster
Registered User
 
Iscritto dal: May 2009
Messaggi: 300
[C++] Urgente: Magheggi con funzioni friend

Volevo sapere se si può e se no come si può fare qualcosa del genere:

Codice:
class A;

class B {
   void funB(A a) {a.funA();} // VORREI CHE SIA CORRETTO (ORA E' SEGNALATO COME ERRORE PERCHE' funA NON E' DEFINITA)
   void funC(A a) {a.funA();} // DEVE ESSERE RILEVATO COME ERRORE
}

class A {
   friend void B::funB(A a);

   protected:
      void funA() {/*...*/};
}
So che si può dichiarare friend la classe B, ma io voglio che solo funB possa chiamare funA, mentre funC non deve poterlo fare.

Ultima modifica di Ikon O'Cluster : 03-09-2009 alle 19:21.
Ikon O'Cluster è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2009, 22:32   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Direi che quello che vuoi fare non è fattibile e oltretutto pone di fronte ad errori di progettazione.
Perchè mai solo un metodo di B dovrebbe accedere ad A?
Se spieghi meglio il contesto forse è possibile trovare una soluzione differente.

funB e funC fanno parte dello stesso contesto ovvero class B, e se funC richiamasse funB più o meno direttamente dovrebbe segnalarti errore?
Credo che la richiesta non sia ragionevole, anche perchè allora potresti pensare che funC richiami un metodo di class C dichiarata come friend di class B che a sua volta richiama funB, risultato atteso?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 09:57   #3
Ikon O'Cluster
Registered User
 
Iscritto dal: May 2009
Messaggi: 300
Perchè volevo che la classe B accedesse ad A soltanto con una funzione membro e non con tutte le funzioni membro. In realtà la mia situazione è questa.

Codice:
class A;

class B {
   void funC(A a) {a.funB(a);} // PUO' ACCEDERE AD A SOLO SE CHIAMA funB

   protected:
   void funB(A a) {a.funA();} // VORREI CHE SIA CORRETTO (ORA E' SEGNALATO COME ERRORE PERCHE' funA NON E' DEFINITA)
}

class A {
   friend void B::funB(A a);

   protected:
      void funA() {/*...*/};
}
Io voglio che la classe B abbia una funzione membro funB incaricata di accedere ad A (perchè unica friend), mentre il resto di B deve per forza far riferimento a funB.

Perchè funA è incaricata di modificare A. E funB è l'unica incaricata di accedere a B. Vorrei che funB-funA siano una specie di "ponte" tra A e B...

Ultima modifica di Ikon O'Cluster : 04-09-2009 alle 10:05.
Ikon O'Cluster è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 11:14   #4
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Secondo me, devi riorganizzare il codice e lasciar stare friend...

spesso quando c'è la stretta necessità di usare friend c'è un errore "di dominio": cioè, se B dipende così strettamente da alcune funzioni di A tanto da dover essere dichiarata friend, probabilmente quelle funzioni non stanno bene dove stanno.

Potresti incapsularle in una classe C che le rende pubbliche, potresti spostarle in B, ecc.

Magari se spieghi meglio il contesto possiamo aiutarti in questo...
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 16:27   #5
Ikon O'Cluster
Registered User
 
Iscritto dal: May 2009
Messaggi: 300
Il codice sottomano non posso pubblicarlo perchè è secretato, ma il concetto è questo:

1) Esistono dei "semi-lavorati":
Codice:
class SemiLavorato {
protected:
   Tipo1 campo1;
   TipoN campoN;
public:
   void set1(Tipo1 t) {campo1 = t;}
   void setN(TipoN t) {campoN = t;}

   Tipo1 get1() {return campo1;}
   TipoN getN() {returncampoN;}
}
2) Esiste una classe che esegue la lavorazione:
Codice:
class Lavorazione {
protected:
   Prodotto output;
   void lavorazione(Semilavorato sl) {output.tick(); output.trasformazione(sl);}
public:
   void acquisisci(SemiLavorato sl) {qualcosa(); lavorazione(sl);}
   Prodotto estrai() {return p;}
}
3) I prodotti sono del tipo:
Codice:
class Product {
protected:
   unsigned int time1;
   unsigned int timeN;
   TipoFinito1 campo1;
   TipoFinitoN campoN;
   void tick() {time1++; timeN++;} // Deve poter essere eseguita solo da Lavorazione::lavorazione 
public:
   void trasformazione(SemiLavorato sl) {/* Lavora solo alcuni TipiFiniti ma non si sa quali a priori, quindi per quelli lavorati imposta timeX=0 per gli altri li lascia inalterati. */}
}

Quello che voglio è che solo Lavorazione possa effettuare lavorazioni su Prodotto. Una volta finita la lavorazione chi ottiene prodotto con estrai() non può più lavorarci sopra. Ma anche chi maneggia Lavorazione non deve poter arbitrariamente operare su Prodotto. In particolare non deve toccare i timeX e quindi invocare la tick(). Perlomeno deve poterci operare solo se effettua una acquisisci() o altre funzioni che richiamano trasformazione().

Ultima modifica di Ikon O'Cluster : 04-09-2009 alle 16:31.
Ikon O'Cluster è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 17:34   #6
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Boh, mi sembra confuso

Cmq una cosa che potresti fare molto semplice è mettere dentro a prodotto un bel bool "finalized" e un bel metodo void finalize();

così finalize è pubblico, ma quando viene chiamato "blocca" le modifiche a Prodotto.

Altrimenti puoi sempre usare la convenzione _metodo() affiancata da un bel commento che invita a non usarlo sul metodo che vuoi rendere interno...
ricorda che protected è pur sempre una convenzione, non è strettamente *necessario*.

Nella quasi totalità delle librerie OOP è facile trovare metodi pubblici cosiddetti "internal" che servono proprio a questo scopo...
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 19:03   #7
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Ikon O'Cluster Guarda i messaggi
Quello che voglio è che solo Lavorazione possa effettuare lavorazioni su Prodotto.
E se lavorazione la definisci come un "ProductProcessing" che deriva da Product tramite ereditarietà privata?
A questo punto hai accesso a tutti i metodi protected.
Dopotutto è un altro modo per rappresentare la composizione di oggetti, come l'avevi fatta te, solo che il legame diventa più stretto e sei sicuro che non si possa casta un ProductProcessing a Product

Quote:
Una volta finita la lavorazione chi ottiene prodotto con estrai() non può più lavorarci sopra.
Come sopra, rispetteresti il requisito, in quanto un oggetto Product non è modificabile se non da ProductProcessing.

Quote:
Ma anche chi maneggia Lavorazione non deve poter arbitrariamente operare su Prodotto. In particolare non deve toccare i timeX e quindi invocare la tick(). Perlomeno deve poterci operare solo se effettua una acquisisci() o altre funzioni che richiamano trasformazione().
Idem come sopra, non puoi lavorare su un oggetto Product, ma lo fai solo tramite i metodi pubblici di ProductProcessing.

Ultima modifica di tomminno : 04-09-2009 alle 19:06.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2009, 19:07   #8
Ikon O'Cluster
Registered User
 
Iscritto dal: May 2009
Messaggi: 300
Uhm... ci studio un po', cmq mi sembra pacifico il ragionamento di tommino. In ogni caso io ora ho definito friend l'intera classe e sostanzialmente è altrettanto pulito in termini di leggibilità/comprensione (anche dati i commenti).

Grazie per le risposte.
Ikon O'Cluster è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
TSMC spinge i chip per smartphone verso ...
OpenAI prepara un modello per la cybersi...
Il CMF Phone 3 Pro sta arrivando: tra le...
Le migliori offerte Amazon di oggi: robo...
Altro che ridimensionamento: OnePlus sta...
YouTube batte Netflix come rivale della ...
I nuovi ASUS ROG Zephyrus G14 e G16 (202...
Meno di 200€ per un robot aspirapolvere ...
La CPU torna protagonista: 400 milioni s...
Il nuovo pannello OLED top di gamma di S...
Offerte LEGO Amazon: Formula 1, Harry Po...
Il Motorola Edge 70 Pro sta arrivando e ...
Amazon pronta a sfidare NVIDIA? La lette...
L'IA ridurrà drasticamente il lav...
Il primo pieghevole di Apple sta arrivan...
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:16.


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