Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-10-2006, 21:26   #1
Abdujaparov
Senior Member
 
Iscritto dal: Aug 2004
Città: Palermo
Messaggi: 1079
C#: come trasformare classi in byte da inviare su udp?

Salve a tutti sto scrivendo un client ed un server udp che si scambiano dei dati.
Girando su internet ho trovato esempi di come fare in modo che due host si scambino stringhe:
1)la stringa viene convertita in array di byte
2)la stringa viene inviata sul socket.

Ora la conversione in array di byte la faccio in questo modo:

Codice:
string daInviare = "Messaggio da inviare";
                    Byte[] sendBytes = Encoding.ASCII.GetBytes(daInviare);
e i dati li riconverto da byte a string in quest'altro modo:
Codice:
int recv;
byte[] data = new byte[1024];
recv = newsock.ReceiveFrom(data, ref Remote);
                    Console.WriteLine(Encoding.ASCII.GetString(data));
Ora se io volessi inviare una classe o una struct per implementare un mio protocollo che mi garantisca affidabilità su udp (non voglio il tcp, devo implementare un protocollo simile su udp per esercizio) come convertirei le classi (o le strutture) in un array di byte?
Grazie a tutti, ciao ciao.
Abdujaparov è offline   Rispondi citando il messaggio o parte di esso
Old 26-10-2006, 21:57   #2
okay
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 906
Quote:
Originariamente inviato da Abdujaparov
Salve a tutti sto scrivendo un client ed un server udp che si scambiano dei dati.
Girando su internet ho trovato esempi di come fare in modo che due host si scambino stringhe:
1)la stringa viene convertita in array di byte
2)la stringa viene inviata sul socket.

Ora la conversione in array di byte la faccio in questo modo:

Codice:
string daInviare = "Messaggio da inviare";
                    Byte[] sendBytes = Encoding.ASCII.GetBytes(daInviare);
e i dati li riconverto da byte a string in quest'altro modo:
Codice:
int recv;
byte[] data = new byte[1024];
recv = newsock.ReceiveFrom(data, ref Remote);
                    Console.WriteLine(Encoding.ASCII.GetString(data));
Ora se io volessi inviare una classe o una struct per implementare un mio protocollo che mi garantisca affidabilità su udp (non voglio il tcp, devo implementare un protocollo simile su udp per esercizio) come convertirei le classi (o le strutture) in un array di byte?
Grazie a tutti, ciao ciao.
che fai... l'encoding? ... ma dai!!

fai un &cast:

(const char*) &Dati //dati della struttura

N.B.
sul client e il server devi avere le stesse strutture di sizeoff()
//uguali! se no cosa comunicano...

esempio:

//invio
send (socket, (const char*) &Dati, sizeof(MiaStruct), 0);
//ricezione
char rec(1024);
bytes = recv(socket, rec, sizeof(MiaStruct), 0);

Ultima modifica di okay : 26-10-2006 alle 22:01.
okay è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2006, 07:33   #3
Abdujaparov
Senior Member
 
Iscritto dal: Aug 2004
Città: Palermo
Messaggi: 1079
Ciao, grazie mille, le stesse strutture di sizeof in che senso?
Invece mi chiedo un'altra cosa se comunicano due computer diversi non ci possono essere problemi differenti per quanto riguarda la dimensione della struct, l'ordinamento di byte (little o big endian)?
Questi problemi se li gestisce in automatico il CLR oppure devo fare tutto a mano come capitava in C (ho programmato qualche socket in C tempo fa e ricordo cose simili)?
Grazie, ciao ciao.
Abdujaparov è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2006, 08:56   #4
okay
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 906
Quote:
Originariamente inviato da Abdujaparov
Ciao, grazie mille, le stesse strutture di sizeof in che senso?.
//client
struct miastruct
int a
char b
;

//server
struct miastruct
int a
char b//se commenti char b la dimensione della struttura cambia
// e avrai un crash al prg se tenti di prendere b che non c'è
;

Quote:
Originariamente inviato da Abdujaparov
Invece mi chiedo un'altra cosa se comunicano due computer diversi non ci possono essere problemi differenti per quanto riguarda la dimensione della struct, l'ordinamento di byte (little o big endian)?
.
Il formato di memorizazione dei byte nei processori Intel è diverso dal formato utilizzato da Internet. Intel utilizza un formato little endian mentre le Winsock richiedono in ingresso un formato big endian.

winsock big endian
bit alto 7 + significativo 0 bit basso meno significativo
7 | 0 | 0 | 0

target.sin_port = htons (wPort);

La funzione htons (Host to Network) converte un numero nel formato del computer locale in quello della rete (è stato scelto il Big-Endian per internet vedi sopra). Anche se si sa che il computer locale è Big-Endian è ottima cosa usare lo stesso questa funzione, che in tal caso sarà solo una macro vuota.

ciao
okay è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2006, 18:14   #5
Abdujaparov
Senior Member
 
Iscritto dal: Aug 2004
Città: Palermo
Messaggi: 1079
Ecco io mi riferivo proprio a queste operazioni. In C ricordo che dovevo farle per forza dato che lavoravo a basso livello, in C# cercando di lavorare ad un livello più alto, utilizzando le sue librerie questi controlli li posso evitare?
Ricordo, anche se in modo non preciso, che controlli simili in java non erano necessari, ci pensava la JVM. In C# non ci pensa il CLR?
Grazie, ciao ciao.
Abdujaparov è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2006, 21:18   #6
U-Boat
Member
 
Iscritto dal: Dec 2001
Città: Cernobbio -Co-
Messaggi: 47
Il modo più semplice per inviare oggetti sulla rete è quello di ricorrere alla serializzazione.

Ti riporto un esempio molto semplice, dove l'oggetto che si invia contiene una stringa

Crea la classe in questo modo:
Codice:
[Serializable]
public class ClassToSend
{
	private string message;

	public ClassToSend(string message)
	{
		this.message = message;
	}

	public override string ToString()
	{
		return "Message: " + this.message;
	}
}
Il client (ho usato TCPListener, tu puoi usare UDPListener che funziona nello stesso modo)
Codice:
public class Client
{
	public void SendMessage(string message, int port)
	{
		ClassToSend messageContainer = new ClassToSend(message);

		TcpClient tcpClient = new TcpClient("localhost", port);
		NetworkStream stream = tcpClient.GetStream();

		BinaryFormatter binaryFormatter = new BinaryFormatter();
		binaryFormatter.Serialize(stream, messageContainer);

		stream.Close();
	}
}
e il server così (se lo lanci come processo separato puoi evitare di ricorrere ai thread)
Codice:
public class Server
{
	TcpListener listener;

	public Server(int port)
	{
		listener = new TcpListener(port);
	}

	public void Start()
	{
		Thread listenThread = new Thread(Listen);
		listenThread.Start();
	}

	private void Listen()
	{
		Console.WriteLine("In attesa...");
		listener.Start();
		TcpClient client = listener.AcceptTcpClient();
		Stream stream = client.GetStream();
		BinaryFormatter binaryFormatter = new BinaryFormatter();
		ClassToSend message = (ClassToSend)binaryFormatter.Deserialize(stream);

		Console.WriteLine(message.ToString());
	}
}
infine il programma principale:
Codice:
static void Main(string[] args)
{
	Server server = new Server(1234);
	server.Start();

	Client client = new Client();
	client.SendMessage("ciao", 1234);

	Console.ReadLine();
}
__________________
micheledellatorre.net
U-Boat è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2007, 17:20   #7
abe.flagg
Senior Member
 
Iscritto dal: Sep 2001
Città: Piazzola sul Brenta (PD)
Messaggi: 262
mi riaggancio a questo thread per una questione che mi sta assillando da qualche giorno:

ho una libreria scritta in C++ con la quale scambio da un applicativo all'altro dei pacchetti di dimensione variabile.
precisamente invio su un socket il numero di byte che trasmetterò, e successivamente il buffer di char che codifica la mia struttura.
questo tramite una funzione write(void *pcMem, int iSize)...

se io volessi replicare lo stesso concetto sotto c#(per comunicare con gli applicativi scritti in c++!), dovrei fare il marshalling della struttura che voglio inviare prima di serializzarla...in modo da assicurarmi che l'allineamento dei dati replichi quello implementato dal compilatore c.
però una struttura a dimensione variabile tipo questa:

[StructLayout(LayoutKind.Sequential, Pack = 1)]
struct T_MY_DATA
{
public uint uiSize;
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 32)];
public byte[] pcMem; //
};

mi permette di inviare SOLAMENTE strutture con array di 32 byte(o in generale il numero di byte specificati in SizeConst...)...e questo non è buono...

in attesa di illuminazione...

thk
__________________
linux user #344456
abe.flagg è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
'Non avrete aumenti': la decisione shock...
TIM lancia il Pass Mondiali DAZN: 104 pa...
Tesla Roadster, promessa o miraggio? La ...
Mark Hamilton, la tavola periodica del m...
Hanger 13 annuncia Uomo d'Onore: espansi...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
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:54.


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