Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Apple MacBook Air M3: chi deve davvero comprarlo? La recensione
Apple MacBook Air M3: chi deve davvero comprarlo? La recensione
A distanza di circa 8 mesi arriva l’importante aggiornamento dei MacBook Air: nessun cambiamento estetico, ma una revisione hardware interna con l’upgrade al processore M3. Le prestazioni migliorano rispetto alle generazioni precedenti, e questo fa sorgere una domanda spontanea: a chi è rivolto oggi questo laptop? Cerchiamo di capirlo nella nostra recensione 
ASUS ROG Swift OLED PG49WCD: quando QD-OLED e ultrawide si fondono
ASUS ROG Swift OLED PG49WCD: quando QD-OLED e ultrawide si fondono
Da ASUS un monitor particolare ma molto completo: principalmente indirizzato al videogiocatore, può essere sfruttato con efficacia anche per attività creative e di produzione multimediale
Dreame L10s Pro Ultra Heat: la pulizia di casa tutta sostanza
Dreame L10s Pro Ultra Heat: la pulizia di casa tutta sostanza
Il nuovo robot aspirapolvere domestico di Dreame abbina funzionalità complete a un moccio flottante che raggiunge al meglio gli angoli delle pareti. Un prodotto tutto in uno semplice da utilizzare ma molto efficace, in grado di rispondere al meglio alle necessità di pulizia della casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-07-2021, 21:30   #1
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
Miglior modo di far comunicare linguaggi diversi

Dovendo scambiare informazioni di tipo testuale, tra Javascript, Kotlin, Python e PHP
Secondo voi qual' è il metodo migliore?
Grazie in anticipo
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 03-07-2021, 21:36   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
di solito attraverso socket client/server, ma se non si conosce la programmazione in questa direzione, si usa il solito file xml oppure un database.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2021, 07:23   #3
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
intanto grazie,
sono daccordo
un db però è "un appoggio", bisogna sempre parcheggiare i dati
anche json in teoria?

meglio però sicuramente socket e/o websocket, no?
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 05-07-2021, 07:45   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
socket è la via maestra.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2021, 18:25   #5
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
websocket anche, no?
poi json per i "dati"
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 05-07-2021, 19:24   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
secondo me per scambiare semplici testi non serve scomodare HTTP, poi dipende dalle tue abitudini e dalle tue attuali conoscenze.

Ultima modifica di misterx : 05-07-2021 alle 19:53.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2021, 21:49   #7
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
è più comodo però
soprattutto se si scambiano dati di tipo diverso
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 10:22   #8
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da gabmac2 Guarda i messaggi
websocket anche, no?
poi json per i "dati"
Hai idea di cosa sono i websocket? Perchè dovresti aggiungere un mastodontico overhead ad una comunciazione già di suo pesante via socket?

Comunque sia, il modo migliore, laddove possibile, è usare la ram. Ovvero usare la memoria condivisa o le pipe.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 11:37   #9
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
Quote:
Originariamente inviato da gabmac2 Guarda i messaggi
è più comodo però
soprattutto se si scambiano dati di tipo diverso
se hai firewall di mezzo allora si.
Nei miei programmi uso sempre socket tcp/ip e se devo comunicare con un webserver faccio una GET sempre attraverso una socket tcp/ip.
Non ho mai avuto la necessità di lavorare sulla porta 80 di default di HTTP, ma ovviamente, dipende dall'implementazione.
Di solito se invio testi, invento una sorta di protocollo dove stabilisco io inizio e fine del pacchetto atteso. Poi dipende dalle abitudini del programmatore.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 12:04   #10
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
la ram, ottima soluzione, quando è possibile, appunto, hai ragione
quando è possibile
in ogni caso non rendiamo la discussione ciclica
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 12:12   #11
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da gabmac2 Guarda i messaggi
la ram, ottima soluzione, quando è possibile, appunto, hai ragione
quando è possibile
In che senso quando è possibile? La memoria condivisa è una delle basi dell'IPC ed è raro trovare un sistema operativo che non la implementi.

Se proprio ti danno fastidio le API che implementano la memoria condivisa, taglia la testa al toro e usa un file non persistente mappato in memoria. Avrai la memoria condivisa con un'API stile file.

E francamente, a questo punto, perchè non usare le pipe? Si usano come file, hanno meccanismi di sincronizzazione interni, usano la memoria condivisa invece del disco, e hanno la semplicità d'uso dei socket e dei meccanismi di message-passing.

Il perchè ce l'ho con i socket, è che aggiungono overhead alle comunicazioni.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 13:24   #12
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
se i software girano su macchine diverse meglio socket, sono versatili
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 13:49   #13
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da misterx Guarda i messaggi
se i software girano su macchine diverse meglio socket, sono versatili
In quel caso si. Del resto non ci sono altre strade se non usare i socket per comunicare via rete.

Ho ovviamente supposto che l'OP si riferisse a programmi scritti in linguaggi diversi, ma che girano sulla stessa macchina.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 18:18   #14
gabmac2
Senior Member
 
Iscritto dal: Jun 2009
Messaggi: 4849
linguaggi diversi e macchine diverse
gabmac2 è online   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 18:24   #15
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
ti sei risposto da solo.
Ci sono passato anch'io.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 06-07-2021, 19:48   #16
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da gabmac2 Guarda i messaggi
linguaggi diversi e macchine diverse
Allora prevale il fatto che siano macchine diverse. E non c'è verso di farli comunicare senza socket.

Riguardo websocket, prendilo in considerazione se stai sviluppando le comunicazioni tramite servizi REST, questo perchè dovendo usare HTTP/HTTPS, tanto vale usare tutto il pacchetto.

Questo dipende ovviamente dall'architettura di tutto il sistema e da eventuali necessità d'interoperabilità.

Come faceva notare misterx, se tutto l'ambaradan lo realizzi tu e quei vari "servizi" comunicheranno solamente tra di loro, allora è meglio progettare un formato dati che sia ottimizzato per il problema che vai a risolvere.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2021, 08:14   #17
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3593
edit

Ultima modifica di misterx : 11-07-2021 alle 07:02.
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Apple MacBook Air M3: chi deve davvero comprarlo? La recensione Apple MacBook Air M3: chi deve davvero comprarlo...
ASUS ROG Swift OLED PG49WCD: quando QD-OLED e ultrawide si fondono ASUS ROG Swift OLED PG49WCD: quando QD-OLED e ul...
Dreame L10s Pro Ultra Heat: la pulizia di casa tutta sostanza Dreame L10s Pro Ultra Heat: la pulizia di casa t...
HONOR Magic6 Pro: come funziona Magic Portal, il modo ''intelligente'' di condividere HONOR Magic6 Pro: come funziona Magic Portal, il...
L'innovazione richiede fiducia: Workday si propone come guida nell'era dell'IA L'innovazione richiede fiducia: Workday si propo...
Italia strategica per Oracle. Arriva la ...
Sam-Bankman Fried: 25 anni di reclusione...
Mobility Analytics di WINDTRE Business p...
Il lander lunare JAXA SLIM si è r...
Warframe conquista l'iPhone: senza soluz...
Marvel Rivals!, l'inaspettato shooter Pv...
Twitch aggiorna le linee guida sui conte...
Galaxy M55 ufficiale: la nuova fascia me...
Google corregge sette vulnerabilit&agrav...
IA: le imprese italiane sono in prima li...
Garmin Dash Cam 57: un'alleata perfetta ...
Elgato Facecam MK2: come rendere ancora ...
2 iRobot Roomba al prezzo più sco...
La tua connessione in fibra ottica potre...
Il controller DualSense per PS5 con un p...
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: 19:25.


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