Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-01-2007, 17:26   #1
stella_650
Member
 
Iscritto dal: Dec 2006
Messaggi: 104
[C-UNIX] Consiglio di implementazione...

Ciao a tutti!
Avrei bisogno di un consiglio per l'implementazione di un problema relativo alla realizzazione di un progetto
io ho un modello client-server: un client scrive sulla socket una struct relativa ad un'ordinazione e la manda al server, questo server la legge e deve memorizzare questa struct da qualche parte...

Ora il consiglio che ora chiedo è proprio relativo a questa parte(colorata), cioè cercare di trovare una "struttura dati" che al meglio mi consenta di memorizzare quelle informazioni della struct, tenendo in considerazione le seguenti cose:
1.Man mano che si effettuano ordinazioni, in maniera sequenziale, le struct dovranno essere "accodate in memoria"
2.Tutto questo serve perchè devo fare in modo che una ricerca,per un particolare campo, cioè tavolo, mi prelevi alcune informazioni a me necessarie per gestire altre applicazioni.

La struct che deve essere letta e scritta su socket è:
Codice:
struct info_client{
        char  pietanza[10];
        int   tavolo;
        int   portata;
}s;
P.S.: avevo pensato all'inizio tipo anche ad un file , come struttura di memorizzazione per l'intera struct ma non so, anche per il problema della ricerca, la vedevo una idea poco efficiente, per cui se conoscete un modo per gestire al meglio quanto ho esposto, ne sarei davvero grata!

Vi ringrazio a priori e spero di avere reply
stella_650 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 18:28   #2
jappilas
Senior Member
 
L'Avatar di jappilas
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 4747
siccome mi pare di notare che si tratti di un sistema per ristoranti )(dove il numero di di tavoli non cambia più di tanto (a runtime), e siccome noto un disaccopiamento tra le transazioni e l' "in_memory model" dell' applicazione lato server
credo una soluzione potrebbe essere una semplice struttura hash - like composta in questo caso da un vettore, dimensionato sul numero di tavoli, in cui ogni elemento è un puntatore ad una struttura dati queue - la queue servirà per contenere e serializzare le transazioni pendenti , cioè le pietanze ordinate ma non ancora servite
ora, come realizzare una queue in C... se non ricordo male, con una struct contenente < dato , pointer all' elemento successivo > per ogni elemento, e
due puntatori esterni head e tail (rispettivamente al primo e all' ultimo elemento della coda ) puntatori che saranno in questo caso contenuti nella singola entry "tavolo" dell' array di cui sopra

quindi il tuo server quando riceverà l' ordinazione:
rileverà il tavolo a cui corrisponde,
malloc() -erà una nuova struct (),
la appenderà al puntatore "next" dell' oggetto attualmente in coda,
aggiornando di conseguenza il puntatore "tail" di Tables[currentTable]

certo, poi occorre implementare le funzioni di estrazione e inserimento nelle code, però le operazioni dovrebbero avvenire con complessità o(1)
e per ora ci si risparmia la serializzazione su file ... se serve ci si pensa in secondo tempo

tutto rigorosamente "se non sbaglio"
__________________
Jappilas is a character created by a friend for his own comic - I feel honored he allowed me to bear his name
Saber's true name belongs to myth - a Heroic Soul out of legends, fighting in our time to fullfill her only wish
Let her image remind of her story, and of the emotions that flew from my heart when i assisted to her Fate

Ultima modifica di jappilas : 12-01-2007 alle 18:41.
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 18:55   #3
stella_650
Member
 
Iscritto dal: Dec 2006
Messaggi: 104
humm mi servirebbe qualche dettaglio maggiore per l'aspetto implementativo, perchè onestamente neanche io ricordo come fare..,anche solo qualche dettaglio in più sulla struttura dati mi tornerebbe utile...grazie
stella_650 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 20:53   #4
jappilas
Senior Member
 
L'Avatar di jappilas
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 4747
praticamente si tratta di una lista di elementi struct, solo con inserimento in coda e prelievo in testa
per semplificare parto dal presupposto che esaminare la prossima transazione in sospeso la "consumi" (solo insert / extract), ma puo' darsi a te serva una funzione a parte passa internamente al successivo fino a trovarne uno che rispetti qualche altro criterio di ricerca
in questo caso avresti accesso con complessita' costante sui tavoli e lineare, ad es, sul campo pietanza, a meno di non complicare la struttura dati con - ad es - un secondo vettore di indici

Codice:
#include <string.h>

#define NUM_TAVOLI 25  //valore arbitrario

typedef struct {
        char  pietanza[10];
        int   tavolo;
        int   portata;
}info_client;

typedef struct {
    char pietanza[10];
    int portata;
    void * successivo;
}info_ordine;

typedef struct{
    info_ordine * primo;
    info_ordine *ultimo;
}info_tavolo;


info_tavolo vettore_tavoli[NUM_TAVOLI];

void inizializzazione_vettore(void){
    int i;
    i=0;
    for (i = 0 ; i < NUM_TAVOLI;i++){
        vettore_tavoli[i].primo = NULL;
        vettore_tavoli[i].ultimo = NULL;
   }
}

BOOL aggiunta_ordine_al_tavolo (info_client * cliente ) {
    
    int num_tavolo;
    info_ordine * ordine;

    num_tavolo= cliente->tavolo;
    ordine= malloc(sizeof(info_ordine));

    //se la creazione del nuovo elemento fallisce esco e ritorno false
    if(ordine==NULL)
        return FALSE;

    //salvo le informazioni sull' ordinazione preventivamente recuperate dal socket
    ordine->successivo = NULL;
    ordine->portata = cliente->portata;
    strcpy(ordine->pietanza, cliente->pietanza);

    //se entrambi i puntatori per il tavolo sono nulli, questo e' il primo oggetto inserito
    //quindi la coda lo vedrà sia come primo che come ultimo 
    if ((vettore_tavoli[num_tavolo].primo == NULL) && (vettore_tavoli[num_tavolo].ultimo == NULL)){
       vettore_tavoli[num_tavolo].primo = ordine;
       vettore_tavoli[num_tavolo].ultimo = ordine;
    }
    //altrimenti diventa il nuovo "ultimo"
    else {   
        vettore_tavoli[num_tavolo].ultimo->successivo = ordine;
        vettore_tavoli[num_tavolo].ultimo = ordine;
    }

    return TRUE;
}



//ritorno true se l' operazione riesce, false altrimenti 
BOOL prelievo_ordine_per_tavolo (int num_tavolo, info_ordine * ordine ) {

    info_ordine * nuovo_ordine_tavolo;
    info_ordine * ordine_tavolo = vettore_tavoli[num_tavolo].primo;      


    //se non c' e' un elemento di testa per la coda di questo tavolo, la ricerca fallisce
    if (ordine_tavolo == NULL) 
        return FALSE;

    //salvo il puntatore all' elemento ordinazione successivo nella coda, 
    //prima che venga perso eliminando l' oggetto corrente
    nuovo_ordine_tavolo = ordine_tavolo->successivo;        

    //recupero le informazioni sull' ordinazione
    ordine->portata = ordine_tavolo->portata;
    strcpy(ordine->pietanza, ordine_tavolo->pietanza); 
    
    //elimino l' oggetto corrente
    //notare che i due puntatori nel vettore_tavoli[..] restano temporaneamente appesi: 
    //verranno corretti subito dopo        
    free(ordine_tavolo);     
    
    //se i due puntatori erano uguali , vuol dire che quello estratto era l' unico elemento
    //devo reimpostare a NULL il puntatore all' oggetto finale della coda
    if (ordine_tavolo == vettore_tavoli[num_tavolo].ultimo) {
        vettore_tavoli[num_tavolo].ultimo = NULL;
    }
    
    //aggiorno la posizione di testa per il tavolo fin qui usato
    //se l' oggetto era l' unico, il suo campo "successivo" era già NULL 
    vettore_tavoli[num_tavolo].primo = nuovo_ordine_tavolo;
    
    return TRUE;
}
spero di non aver fatto "troppi" errori, lavorando su java ho il C un po' arrugginito
inoltre questo non è il mio solito modo di scrivere codice..
__________________
Jappilas is a character created by a friend for his own comic - I feel honored he allowed me to bear his name
Saber's true name belongs to myth - a Heroic Soul out of legends, fighting in our time to fullfill her only wish
Let her image remind of her story, and of the emotions that flew from my heart when i assisted to her Fate

Ultima modifica di jappilas : 13-01-2007 alle 19:38. Motivo: corretta funzione di estrazione, per gestire il caso di singolo elemento in coda - ora è simmetrica rispetto all' inserimento
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2007, 07:23   #5
stella_650
Member
 
Iscritto dal: Dec 2006
Messaggi: 104
wow secondo me sei stato più che gentile;
forse la mia richiesta poteva sembrare "eccessiva" e ti ringrazio per avermi aiutato.
Spero in questo modo di risolvere il problema.
Grazie ancora
stella_650 è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2007, 14:07   #6
jappilas
Senior Member
 
L'Avatar di jappilas
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 4747
Quote:
Originariamente inviato da stella_650
wow secondo me sei stato più che gentile;
forse la mia richiesta poteva sembrare "eccessiva" e ti ringrazio per avermi aiutato.
Spero in questo modo di risolvere il problema.
Grazie ancora
non c'è di che
non era per niente una richiesta eccessiva, anzi per studio o lavoro mi hanno chiesto cose molto peggiori
è che oltre ad essere lento a scrivere e un tantino distratto, nell' ultimo periodo mi ero abituato a scrivere codice puramente object oriented, in inglese e senza commenti

ps: ho fatto un po' di correzioni al codice in generale e una modifica alla seconda funzione per gestire un caso particolare, così dovrebbe andare meglio
__________________
Jappilas is a character created by a friend for his own comic - I feel honored he allowed me to bear his name
Saber's true name belongs to myth - a Heroic Soul out of legends, fighting in our time to fullfill her only wish
Let her image remind of her story, and of the emotions that flew from my heart when i assisted to her Fate

Ultima modifica di jappilas : 13-01-2007 alle 19:44.
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2007, 16:59   #7
stella_650
Member
 
Iscritto dal: Dec 2006
Messaggi: 104
Quote:
è che oltre ad essere lento a scrivere e un tantino distratto, nell' ultimo periodo mi ero abituato a scrivere codice puramente object oriented, in inglese e senza commenti
per questo allora è da apprezzare ancora di più
Grazie davvero
stella_650 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
HONOR Watch 6: batteria infinita, modali...
Windows 11, addio alle ricerche sul web:...
La vera sfida dell’IA non è adott...
Signal contro l'AI agentica: dare ai cha...
Amazon: l'human-in-the-loop non basta a ...
HONOR 600 Lite: design in metallo e batt...
Ultima: il creatore potrebbe riacquisire...
Amazon Business porta in Italia “Prodott...
Un'insegnante toglie ogni schermo dalla ...
Backdoor di fabbrica: fino a 500 milioni...
Hong Kong, apre il primo minimarket aper...
L'Italia batte quasi tutta Europa sulle ...
Steam Frame: spuntano nuove immagini rea...
Droni militari russi: i vecchi smartphon...
Giocare ai titoli più complessi con le s...
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: 15:27.


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