Torna indietro   Hardware Upgrade Forum > Software > Programmazione

GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-05-2018, 13:12   #1
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
[C] Leggere un file attraverso system calls

Come da titolo dovrei leggere un file txt di questo tipo:
3
2 5 + 1
1 2 - 10
2 4 * 3
3 1 / 2

Come posso fare utilizzando solamente read o comunque altre system calls?
Altra cosa, se volessi saltare la prima riga posso tranquillamente usare lseek?
Grazie, purtroppo sono da sempre abituato con fgets e fscanf ed è tutta la mattina che ci sbatto la testa.
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2018, 17:19   #2
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
system calls, ma di quale sistema operativo?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2018, 17:33   #3
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da pabloski Guarda i messaggi
system calls, ma di quale sistema operativo?
Linux, sono su Ubuntu.
La mia idea era un ciclo che contasse gli '/n' per conteggiare il numero di righe presenti nel file e poi usare la read...
Con lseek mi sposto all'inizio della seconda riga e comincio da lì, il problema sta nel mettere giù il tutto in modo efficente
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2018, 17:54   #4
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Patriche Guarda i messaggi
Linux, sono su Ubuntu.
La mia idea era un ciclo che contasse gli '/n' per conteggiare il numero di righe presenti nel file e poi usare la read...
Con lseek mi sposto all'inizio della seconda riga e comincio da lì, il problema sta nel mettere giù il tutto in modo efficente
Questo dipende da quale approccio vuoi usare. Per com'è gestito l'I/O dei sistemi operativi moderni, conviene sempre leggere pezzi di file in memoria e poi eventualmente andare a guardare ( in memoria ) dove stanno i ritorni a capo ( e ci sarebbe da gestire eventualmente sia quelli Unix che Windows, cioè \n e \r\n ).

Il problema è che read vuole sapere quanti byte leggere. Ma senza conoscere la posizione dei ritorni a capo come fai? Dovresti scorrere, carattere per carattere, il file??

A quel punto andresti a leggere due volte ogni riga.

Ultima modifica di pabloski : 28-05-2018 alle 17:57.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2018, 17:57   #5
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Patriche Guarda i messaggi
Linux, sono su Ubuntu.
La mia idea era un ciclo che contasse gli '/n' per conteggiare il numero di righe presenti nel file e poi usare la read...
Con lseek mi sposto all'inizio della seconda riga e comincio da lì, il problema sta nel mettere giù il tutto in modo efficente
Questo dipende da quale approccio vuoi usare. Per com'è gestito l'I/O dei sistemi operativi moderni, conviene sempre leggere pezzi di file in memoria e poi eventualmente andare a guardare ( in memoria ) dove stanno i ritorni a capo ( e ci sarebbe da gestire eventualmente sia quelli Unix che Windows, cioè \n e \r\n ).

Il problema è che read vuole sapere quanti byte leggere. Ma senza conoscere la posizione dei ritorni a capo come fai? Dovresti scorrere, carattere per carattere, il file??

A quel punto andresti a leggere due volte ogni riga.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2018, 18:04   #6
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Questo dipende da quale approccio vuoi usare. Per com'è gestito l'I/O dei sistemi operativi moderni, conviene sempre leggere pezzi di file in memoria e poi eventualmente andare a guardare ( in memoria ) dove stanno i ritorni a capo ( e ci sarebbe da gestire eventualmente sia quelli Unix che Windows, cioè \n e \r\n ).

Il problema è che read vuole sapere quanti byte leggere. Ma senza conoscere la posizione dei ritorni a capo come fai? Dovresti scorrere, carattere per carattere, il file??

A quel punto andresti a leggere due volte ogni riga.
Si purtroppo quello era l'unico modo che ero riuscito bene o male a buttare giù. So che non è per niente efficente e fa schifo da vedere ma questa è solo la prima parte di un progetto e confido che il resto venga più scorrevole (riguarderebbe processi e pipe/code di messaggi).
Come potrei evitarlo senza scorrere due volte carattere per carattere?
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 09:59   #7
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da Bellaz89 Guarda i messaggi
Domanda: ma perche' non leggi direttamente tutto il file in memoria e da li non trovi i breakline? di che grandezze di file stiamo parlando? Io cosi' a naso direi che se siamo sotto il MB e' piu' efficiente leggere tutto subito con un utilizzo minimo di metodi che vanno a chiamare syscalls.
Sicuramente saremo sotto il megabyte, il mio problema era creare un ciclo che mi permettesse la lettura tramite read di tutte le righe del file ad eccezione della prima riga. Ho messo giù un while ma continua a darmi errori.
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 10:29   #8
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Patriche Guarda i messaggi
Sicuramente saremo sotto il megabyte, il mio problema era creare un ciclo che mi permettesse la lettura tramite read di tutte le righe del file ad eccezione della prima riga. Ho messo giù un while ma continua a darmi errori.
Essendo il file piccolo e dovendo saltare solo la prima riga, comunque ti conviene leggere tutto il file. Poi vai a cercare il primo \n e quello che c'è prima semplicemente lo scarti.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 11:26   #9
fano
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2095
Per sapere direttamente da C la dimensione in byte del file usa fstat() https://linux.die.net/man/2/fstat a quel punto allochi il buffer puoi usare 3 metodi per fare questo:

1. malloc(), ma ricordati poi di fare free() tutte le volte che fai return o sei fritto
2. alloca(): alloca nello stack quindi la memoria viene liberata automaticamente quando la funzione fa return
3. dynamic allocated array: personalmente è il metodo che preferisco fai semplicemente così:

Codice:
rc = fstat(fd, &buf);
// controlla SEMPRE gli errori, mi raccomando!

char myArray[buf.st_size];

// procedi a cercare '\n' in myArray
Poi non capisco il senso di andare ad incasinare e non usare fgets() già le API sono limitatissime se ci se la va pure a cercare... poi se è un esercizio di scuola allora alzo le mani
__________________
Cosmos C# Open Source Managed Operating System
Cosmos Thread Ufficiale
Cosmos Official Site Vuoi collaborare allo sviluppo? Unisciti alla chat!
fano è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 11:30   #10
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Essendo il file piccolo e dovendo saltare solo la prima riga, comunque ti conviene leggere tutto il file. Poi vai a cercare il primo \n e quello che c'è prima semplicemente lo scarti.
E fin lì ci siamo... Il problema è proprio la lettura.
Come posso creare un ciclo che mi dica scorri il file?
Usassi una fscanf non ci sarebbero problemi, è con la read che ho difficoltà a metterlo giù. Quale potrebbe essere la mia condizione del while?
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 11:52   #11
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da fano Guarda i messaggi
Per sapere direttamente da C la dimensione in byte del file usa fstat() https://linux.die.net/man/2/fstat a quel punto allochi il buffer puoi usare 3 metodi per fare questo:

1. malloc(), ma ricordati poi di fare free() tutte le volte che fai return o sei fritto
2. alloca(): alloca nello stack quindi la memoria viene liberata automaticamente quando la funzione fa return
3. dynamic allocated array: personalmente è il metodo che preferisco fai semplicemente così:

Codice:
rc = fstat(fd, &buf);
// controlla SEMPRE gli errori, mi raccomando!

char myArray[buf.st_size];

// procedi a cercare '\n' in myArray
Poi non capisco il senso di andare ad incasinare e non usare fgets() già le API sono limitatissime se ci se la va pure a cercare... poi se è un esercizio di scuola allora alzo le mani

Scusa non avevo letto questo
Mmm... Ora provo a buttarci giù qualcosa vediamo come va.
Si è un progetto scolastico effettivamente, è quella la rottura.
Grazie per l'aiuto in ogni caso, sei stato molto gentile!
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 13:44   #12
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Patriche Guarda i messaggi
Scusa non avevo letto questo
Mmm... Ora provo a buttarci giù qualcosa vediamo come va.
Si è un progetto scolastico effettivamente, è quella la rottura.
Grazie per l'aiuto in ogni caso, sei stato molto gentile!
Mi sorge un dubbio a questo punto. Quella indicata da fano è una funzione della libc, ok un banale wrapper per la relativa syscall, ma quel codice che ha postato non sta invocando direttamente le syscall del kernel.

Nel tuo caso va bene così?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 15:33   #13
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Mi sorge un dubbio a questo punto. Quella indicata da fano è una funzione della libc, ok un banale wrapper per la relativa syscall, ma quel codice che ha postato non sta invocando direttamente le syscall del kernel.

Nel tuo caso va bene così?
A sto punto l'importante é leggere sto maledetto file... Non ho ancora potuto provare il discorso dell'array dinamico ma ho già elaborato un'idea... Vediamo se riesco a metterci nel mezzo qualcosa.
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 16:21   #14
fano
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2095
Io non penso il prof intendesse davvero le syscall del kernel... manco sono sicuro si possa fare dal C (forse in assembler)... poi la read() internamente fa comunque la syscall.
__________________
Cosmos C# Open Source Managed Operating System
Cosmos Thread Ufficiale
Cosmos Official Site Vuoi collaborare allo sviluppo? Unisciti alla chat!
fano è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 17:39   #15
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da fano Guarda i messaggi
Io non penso il prof intendesse davvero le syscall del kernel... manco sono sicuro si possa fare dal C (forse in assembler)... poi la read() internamente fa comunque la syscall.
Ma infatti è questo il dubbio. Se ha usato il termine syscall, beh, che intendeva? Parecchia gente confonde le funzioni della libc con le syscall e impropriamente le chiama syscall.

Ma questo mistero può svelarlo solo il professore.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2018, 20:04   #16
Patriche
Junior Member
 
Iscritto dal: May 2018
Messaggi: 8
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Ma infatti è questo il dubbio. Se ha usato il termine syscall, beh, che intendeva? Parecchia gente confonde le funzioni della libc con le syscall e impropriamente le chiama syscall.

Ma questo mistero può svelarlo solo il professore.
Conta che è per un progetto di SO, in parole povere al posto di fopen e fclose dovevo usare open e close...poi comunque l'esercizio mirava a creare vari processi figlio e implementare pipe/code di messaggi...quindi utilizzare fork e qualsivoglia...
Diciamo che quella parte è stata spiegata bene mentre l'altra è stata data più per scontato.
Anche perché dai, essendoci le librerie perché farsi del male?
Comunque grazie per i consigli e scusate la rottura! Siete stati veramente molto disponibili.
Patriche è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2018, 10:09   #17
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Patriche Guarda i messaggi
Conta che è per un progetto di SO, in parole povere al posto di fopen e fclose dovevo usare open e close...poi comunque l'esercizio mirava a creare vari processi figlio e implementare pipe/code di messaggi...quindi utilizzare fork e qualsivoglia...
Diciamo che quella parte è stata spiegata bene mentre l'altra è stata data più per scontato.
Anche perché dai, essendoci le librerie perché farsi del male?
Quindi è il classico esercizio di sistemi operativi. In quel caso si usa ovviamente la libc.

Però è importante ricordare che per "usare le syscall" s'intende richiamare direttamente le funzioni esposte dal kernel, cosa che si fa ( in Linux ) tramite l'interrupt 80h.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2018, 14:26   #18
fano
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2095
Certo che chiamare le classiche funzioni C open(), read(), write() è proprio sbagliato del resto si sa che i Professori in Italia raramente capiscono cosa insegnano

Sinceramente in quasi 20 anni di programmazione su Linux non ho mai avuto bisogno di usare interrupt 80h per aprire un file
__________________
Cosmos C# Open Source Managed Operating System
Cosmos Thread Ufficiale
Cosmos Official Site Vuoi collaborare allo sviluppo? Unisciti alla chat!
fano è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2018, 15:46   #19
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da fano Guarda i messaggi
Certo che chiamare le classiche funzioni C open(), read(), write() è proprio sbagliato del resto si sa che i Professori in Italia raramente capiscono cosa insegnano
Non sto dicendo questo. Ma se il professore, ad esempio, insegna come interfacciarsi in Assembly col kernel, allora la libc è fuori dall'equazione.

C'è un bellissimo libro al riguardo "Programming from the Ground Up".

Non avendo l'OP specificato il contesto e avendo usato il termine syscall, mi era venuto il dubbio.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2018, 22:20   #20
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12847
Quote:
Originariamente inviato da fano Guarda i messaggi
Certo che chiamare le classiche funzioni C open(), read(), write() è proprio sbagliato del resto si sa che i Professori in Italia raramente capiscono cosa insegnano

Sinceramente in quasi 20 anni di programmazione su Linux non ho mai avuto bisogno di usare interrupt 80h per aprire un file
Potresti argomentare?

Alla fine della fiera per aprire un file da user space devi per forza arrivare a fare una syscall, c'è poco da fare. Infatti alla fine se vai a vedere fopen() sotto linux chiama open...

Dopodiché oggi ci sono istruzioni dedicate e più efficienti (ad es. su x86 sysenter/sysexit, syscall) di un software interrupt.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Start Cup Puglia 2025: il 16 ottobre la ...
Incentivi auto elettriche, falsa partenz...
Silence crea anche in Francia una rete d...
La realtà mista al servizio degli...
Nothing ha un altro smartphone in progra...
Decisione storica ad Amburgo: i cittadin...
Questo è il nuovo motore elettric...
HUAWEI WATCH GT 6: lo smartwatch 'infini...
Fotografia con AI: ecco Caira, la macchi...
PlayStation 6 vs Xbox Magnus: il rumor s...
DJI Osmo Action 4 a soli 208€ su Amazon:...
Irion, la data governance diventa strate...
EHang VT35: debutta in Cina il nuovo aer...
Cooler Master MasterLiquid Atmos II 360:...
Trapela in rete la roadmap dei nuovi gio...
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: 18:47.


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