Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-01-2007, 18: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, 19: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 19:41.
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 19: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, 21: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 20: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, 08: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, 15: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 20:44.
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2007, 17: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


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
Exynos 2700, Samsung già lavora a...
Microsoft rilascia Windows 11 26H1: cosa...
Apple vola in Cina: il merito è d...
WhatsApp Web sta per colmare la sua pi&u...
Spotify chiude un trimestre da record: i...
Samsung potrebbe riproporre smartphone c...
AirPods Pro 3 a 219€, AirTag da 4 pezzi ...
Sconto di 300€ su un MacBook Air e un Pr...
La Cina lancia un servizio simile a Dire...
SpaceX: Elon Musk torna a parlare dei pr...
G.Skill risarcisce 2,4 milioni di dollar...
Test degli annunci su ChatGPT avviati: '...
TSMC approva investimenti record da quas...
L'IA agentica arriva anche sullo storage...
Euro digitale, il Parlamento UE cambia r...
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: 09:09.


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