PDA

View Full Version : [C#]Interfacce


RaouL_BennetH
06-11-2008, 11:17
Buongiorno a tutti :)

Con il mio percorso didattico sono arrivato alle interfacce.

Ho già i primi dubbi sulle cose più semplici :muro: :(

Allora.. supponendo che lo scenario sia sempre lo stesso, ovvero il classico archivio anagrafico, stavo procedendo così:



public interface IPersona
{
int ID
{
get;
}
string Cognome
{
get;
set;
}
string Nome
{
get;
set;
}


void AddPersona(Persona p);
}



procedo quindi a creare la classe Persona che implementerà quanto definito in IPersona:



public class Persona : IPersona
{
private int id;
private string cognome;
private string nome;

public int ID
{
get { return id; }
}

public string Cognome
{
get { return cognome; }
set { cognome = value; }
}

public string Nome
{
get { return nome; }
set { nome = value; }
}

//primo concetto che non ho capito:
//come implemento qui il metodo AddPersona ?



per il momento mi fermo qui (ma ho tante altre domande da fare ) :)

Grazie mille.

RaouL.

banryu79
06-11-2008, 11:21
In che senso?
Dipende da cosa deve fare quel metodo. Il nome suggerisce che debba aggiungere una Persona a qualcos'altro (magari un contenitore).

Ma a questo punto mi viene da chiederti perchè l'interfaccia IPersona stabilisca per contratto un tale comportamento... forse mi è sfuggito qualcosa?

Disclaimer: non so niente di C#

RaouL_BennetH
06-11-2008, 11:27
In che senso?
Dipende da cosa deve fare quel metodo. Il nome suggerisce che debba aggiungere una Persona a qualcos'altro (magari un contenitore).

Ma a questo punto mi viene da chiederti perchè l'interfaccia IPersona stabilisca per contratto un tale comportamento... forse mi è sfuggito qualcosa?

Ciao :)

tralasciando l'utilità della cosa, se non quella didattica, altri scopi non ve ne sono :p

anzi.. se potessi fornirmi un esempio più sensato su come si possa gestire la cosa te ne sarei davvero grato, magari restando nell'ambito "Persona" :D

Hai comunque centrato il punto:

dovrei aggiungere una persona ad un contenitore, magari una lista o similare.

Grazie mille.

RaouL.

banryu79
06-11-2008, 11:50
Premesso che:

Disclaimer: non so niente di C#

e che:

Hai comunque centrato il punto:
dovrei aggiungere una persona ad un contenitore, magari una lista o similare.

C'è una cosa che mi lascia perplesso: nel metodo addPersona dell'interfaccia IPersona il parametro è di tipo Persona.
Dunque l'interfaccia IPersona prevede l'esistenza di una classe Persona? E obbliga tutte le classi che implementeranno l'interfaccia IPersona a implementare un metodo che prende come parametro un oggetto Persona?

Non è che addPersona deve prendere in ingresso una IPersona invece di una Persona?

public interface IPersona
{
...
void AddPersona(IPersona p);
}


Sono confuso, non conosco C# quindi non so valutare con cognizione di causa questa faccenda.

Auspico l'intervento di altri utenti più esperti; avevo postato solo perchè appunto la faccenda mi sembrava un po' strana e per stimolarti a riflettere da te attraverso le mie domande (e forse qua ho peccato di presunzione, pensando di esserti di aiuto in questo modo).

Chiedo venia, ciao :)

RaouL_BennetH
06-11-2008, 12:26
Premesso che:

e che:

C'è una cosa che mi lascia perplesso: nel metodo addPersona dell'interfaccia IPersona il parametro è di tipo Persona.
Dunque l'interfaccia IPersona prevede l'esistenza di una classe Persona? E obbliga tutte le classi che implementeranno l'interfaccia IPersona a implementare un metodo che prende come parametro un oggetto Persona?

Non è che addPersona deve prendere in ingresso una IPersona invece di una Persona?

public interface IPersona
{
...
void AddPersona(IPersona p);
}



Uhm.. probabilmente si, non lo so :(

Mamma mia che confusione che ho in testa :muro:


Sono confuso, non conosco C# quindi non so valutare con cognizione di causa questa faccenda.

Auspico l'intervento di altri utenti più esperti; avevo postato solo perchè appunto la faccenda mi sembrava un po' strana e per stimolarti a riflettere da te attraverso le mie domande (e forse qua ho peccato di presunzione, pensando di esserti di aiuto in questo modo).

Chiedo venia, ciao :)

Ma figurati, probabilmente mi hai detto delle cose più che giuste ma sono io che non le capisco .

RaouL.

banryu79
06-11-2008, 12:29
Allora aspettiamo un C-Sharpiano, o un C-Sharphista, oppure... beh insomma uno con la Sharpa :D

^TiGeRShArK^
06-11-2008, 13:08
beh..
secondo me è concettualmente sbagliato implementare in un tipo "singolo" come persona un metodo AddPersona...
Quel metodo lo vederei di + in Azienda.AddImpiegato() con la classe Impiegato che implementa l'interfaccia IPersona.
In quel caso il metodo lo scriverei così:

void AddImpiegato(IPersona p)
{
impiegati.Add(p);
}

con impiegati che non è altro che una List<Impiegato> memorizzata come field nella classe Azienda...
Aggiungere una Persona a se stessa non mi pare abbia molto senso.. :stordita:

Kralizek
06-11-2008, 17:06
oddio... conosco diverse posizioni per aggiungere una persona ad un'altra... ed almeno un buon motivo! :sofico:

banryu79
06-11-2008, 17:37
oddio... conosco diverse posizioni per aggiungere una persona ad un'altra... ed almeno un buon motivo! :sofico:
Cavoli, per fare sta battuta in un thread di programmazione bisogna proprio avere l'ormone galoppante :asd:

RaouL_BennetH
06-11-2008, 17:48
oddio... conosco diverse posizioni per aggiungere una persona ad un'altra... ed almeno un buon motivo! :sofico:

:rotfl: :sbonk:

^TiGeRShArK^
beh..
secondo me è concettualmente sbagliato implementare in un tipo "singolo" come persona un metodo AddPersona...
Quel metodo lo vederei di + in Azienda.AddImpiegato() con la classe Impiegato che implementa l'interfaccia IPersona.
In quel caso il metodo lo scriverei così:


Codice:
void AddImpiegato(IPersona p)
{
impiegati.Add(p);
}

con impiegati che non è altro che una List<Impiegato> memorizzata come field nella classe Azienda...
Aggiungere una Persona a se stessa non mi pare abbia molto senso..


In effetti... beh, la mia idea era una classe Persone :stordita:

^TiGeRShArK^
06-11-2008, 20:28
:rotfl: :sbonk:



In effetti... beh, la mia idea era una classe Persone :stordita:

Non ha senso di solito nemmeno la classe Persone dato che una List<Persona>, se la classe Persona è ben implementata, e a meno di esigenze particolari, dovrebbe servire allo scopo. :p

Kralizek
06-11-2008, 22:50
Cavoli, per fare sta battuta in un thread di programmazione bisogna proprio avere l'ormone galoppante :asd:

lavorare con ragazze svedesi 8 ore al giorno ha i suoi contro...

Ad ogni modo trovo inutile fare questi discorsi sulla liceità del metodo nell'interfaccia dato che l'interfaccia IPersona ha poco senso di suo! :P

gugoXX
06-11-2008, 23:34
lavorare con ragazze svedesi 8 ore al giorno ha i suoi contro...

Ad ogni modo trovo inutile fare questi discorsi sulla liceità del metodo nell'interfaccia dato che l'interfaccia IPersona ha poco senso di suo! :P

Confermo (A parte le 8 svedesi)
Un'interfaccia viene tipicamente usata per modellare un comprtamento "Can do", mentre la derivazione classica viene usata per modellare "is-a"

Quindi IPersona, che sa tanto di un "is-a", non e' ortodosso come modello ad interfaccia, sebbene permesso.

Kralizek
06-11-2008, 23:54
Un'interfaccia viene tipicamente usata per modellare un comprtamento "Can do", mentre la derivazione classica viene usata per modellare "is-a"

non avrei saputo dirlo meglio! :P

^TiGeRShArK^
07-11-2008, 02:47
Confermo (A parte le 8 svedesi)
Un'interfaccia viene tipicamente usata per modellare un comprtamento "Can do", mentre la derivazione classica viene usata per modellare "is-a"

Quindi IPersona, che sa tanto di un "is-a", non e' ortodosso come modello ad interfaccia, sebbene permesso.

bravo :O
Io sono proprio di religione greco-ortodossa e quindi mi hai offeso PESANTEMENTE :mad:





..ovviamente no..
Ma non sapevo come spiegare meglio di così che l'interfaccia in quel modo era concettualmente errata..
anche se mi vengono in mente un paio di casi particolari in cui l'interfaccia iPersona avrebbe anche un suo senso :Perfido:

banryu79
07-11-2008, 09:35
bravo :O
...cut...
anche se mi vengono in mente un paio di casi particolari in cui l'interfaccia iPersona avrebbe anche un suo senso :Perfido:
Per esempio?

^TiGeRShArK^
07-11-2008, 12:41
Per esempio?

beh..
per esempio un ipotetico gioco in cui abbiamo personaggi umani e personaggi animali con caratteristiche e abilità diverse...

banryu79
07-11-2008, 12:50
Ok capito, grazie :)

RaouL_BennetH
07-11-2008, 17:03
Ok ragazzi, ora le cose mi sono più chiare.

Credo comunque che sia tutto molto più complesso di come determinati concetti vengano spiegati su alcune documentazioni.

Fortuna che tutti voi, almeno per me, siate una fonte didattica molto preziosa.


Grazie davvero :)

RaouL.