Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-03-2004, 13:42   #1
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
[JAVA]utilizzo classe BufferReader

devo leggere un file di testo che contiene tot righe di testo; per leggere ogni riga uso il metodo .readline della classe bufferreader: il problema sorge quando voglio leggere *tutte" le righe di testo contenute nel file .......che ciclo devo utilizzare e sopratutto qualche condizione?

nei metodi della classe BufferReader non ho trovato nulla che mi potesse indicare l'EOF!

Codice:
File aFile = new File("C:\\file.bin");  <--- file da leggere


try { in = new FileInputStream (aFile); } catch(Exception e) { } <--- ottengo lo Stream (non quello della valve! lol)


BufferedReader d = new BufferedReader(new InputStreamReader(in)); <--- il buffer per leggere il testo


string = d.readLine(); <--- metodo per leggere una singola riga
ciao e grazie



ps: secondo voi questo tipo di lettura di un file di testo è efficente o c'è qualcosa di meglio?
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2004, 14:30   #2
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19148
tu continua a leggere il file finché non arriva l'eccezione IOException
a quel punto sai che il file è finito
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2004, 14:35   #3
RaNd0m
Member
 
Iscritto dal: Sep 2003
Città: Garlasco (PV)
Messaggi: 71
string = d.readLine();
while (string!=null) {leggi il file }

.......io ho usavo questo ( mi sembra )

cmq dovresti mettere tutto in un array di string
RaNd0m è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2004, 15:40   #4
gabriele81
Senior Member
 
L'Avatar di gabriele81
 
Iscritto dal: Dec 2001
Città: Roma
Messaggi: 542
Quote:
Originariamente inviato da RaNd0m
string = d.readLine();
while (string!=null) {leggi il file }

.......io ho usavo questo ( mi sembra )

cmq dovresti mettere tutto in un array di string
Esatto, se il file è finito il metodo readLine() ritorna NULL.
__________________
Il 90% dei problemi di un computer si trova tra la tastiera e la sedia.
XP2500+@3200+|A7N8X Deluxe|1,25 GB DDR400|Radeon 9550|HD 160+320 GB SATA|WinXP Pro|Fastweb 6 Mb/s
gabriele81 è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2004, 15:58   #5
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19148
Quote:
Originariamente inviato da gabriele81
Esatto, se il file è finito il metodo readLine() ritorna NULL.
è vero, non so perché non mi è venuto in mente subito
del resto ho usato la bufferedreader praticamente solo per le socket quindi c'era l'abitudine a usare le eccezioni
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2004, 20:25   #6
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Re: [JAVA]utilizzo classe BufferReader

Quote:
Originariamente inviato da Frank1962
ps: secondo voi questo tipo di lettura di un file di testo è efficente o c'è qualcosa di meglio?
I FileChannel sono dichiarati "più meglio del meglio", però se il file è piccolo la differenza non penso si veda.

Codice:
import java.io.*;
import java.nio.*;
import java.nio.channels.*;
import java.nio.charset.*;

public class NIOReader { 	
	public static void main(String[] args) {
		try {
			StringBuffer text = new StringBuffer();
			FileChannel inChannel = new FileInputStream("z:/prova.txt").getChannel();
			ByteBuffer buffer = ByteBuffer.allocate(1024);
			Charset charset = Charset.forName("ISO-8859-1");
			CharsetDecoder charsetDecoder = charset.newDecoder();
			while( inChannel.read(buffer) != -1 ) {
				buffer.flip();
				text.append(charsetDecoder.decode(buffer).toString());
				buffer.clear();
			}
			inChannel.close();
			System.out.println(text);
		} catch(IOException e) {
			e.printStackTrace(System.err);
			System.out.println("End of stack trace");
		}
		System.exit(0);
	}
}
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2004, 10:23   #7
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
grazie PGI!! ...in effetti quel codice riuslta essere moolto + efficente nella lettura di file! ....però quando tento di andare a caricare file abbastanza grossi (30-40mb) mi da un errore "java.lang.OutOfMemoryError" <--- come faccio quindi a impostare la jvm per fargli utilizzare + ram ?

ciao e grazie!
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2004, 11:40   #8
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
I parametri sono da impostare al momento del lancio della jvm:

http://java.sun.com/j2se/1.4.2/docs/...dows/java.html

In special modo

Quote:
-Xmsn
Specify the initial size, in bytes, of the memory allocation pool. This value must be a multiple of 1024 greater than 1MB. Append the letter k or K to indicate kilobytes, or m or M to indicate megabytes. The default value is 2MB. Examples:
-Xms6291456
-Xms6144k
-Xms6m
Devi comunque tenere conto dei limiti fisici della memoria, per cui è conveniente(anzi d'obbligo) implementare un algoritmo che divida in n blocchi il file da leggere.
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2004, 11:41   #9
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
da linea di comando puoi usare l'opzione -XmxN, dove N indica la quantità di memoria massima di allocazione che la jvm può usare (default 64megabyte). N può essere espresso in kilobyte o megabyte, di solito si usano i megabyte.

es.

java -Xmx256m Programma.java -> la jvm "arriva" fino a 256megabyte

Puoi anche stabilire la dimensione iniziale della memoria di allocazione (default 2megabyte)

java -Xms16m -Xmx256m Programma.java -> la jvm parte con 16megabyte e arriva fino a 256.

Questa seconda opzione si può usare nel caso in cui il programma richieda già all'avvio un quantitiativo di memoria più ampio del normale e dovrebbe garantire una partenza un po' più rapida.

Se stai impacchettando l'applicazione in un Jar eseguibile, puoi definire direttamente le opzioni che verranno usate dalla macchina virtuale quando eseguirà l'applicazione usando le opzioni -J-

es.

jar -J-Xmx256m -mcf blablabla...

crea un jar che sarà eseguito passando alla macchina virtuale l'opzione -Xmx256m.

Tutte le opzioni -X sono opzioni della macchina virtuale HotSpot di Sun.

Ciao.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2004, 11:43   #10
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
cn73, m'hai fregato per un minuto!
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2004, 12:22   #11
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Quote:
Originariamente inviato da PGI
cn73, m'hai fregato per un minuto!

cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2004, 03:40   #12
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
grazie raga .....adesso ho risolo anche questo problema! però ho notato che utilizzando il codice di PGI mi trovo a essere limitato dalla grandezza del buffer; mi spiego meglio, essendo le righe di testo nel file di lunghezza differente mi ritrovo con "oggetti" String di testo che all'ultima riga di solito viene spezzato per poi essere salvato nell'oggetto successivo ...........c'è la possibilità di aggirare questo problema e avere le righe complete!?

ciao e grazie
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2004, 12:19   #13
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Per leggere una linea per volta personalmente ti consiglio di restare sul buon vecchio BufferedReader, forse è meno efficiente però il codice che salta fuori è 1000 volte più "rapido da leggere" (e non è una cosa da buttar via).

Con un CharsetDecoder il carattere "new line" è trattato come un carattere qualsiasi, per risolvere dovresti aggiungere un ciclo di "parsing" del testo letto, o tutto quanto, e quindi dopo aver creato una stringa che può anche essere piuttosto grossa, oppure all'interno del ciclo di lettura: togli l' "append", riversi il contenuto del buffer in una stringa intermedia e la parzializzi cercando i caratteri "\n".

Così fancendo sarebbe ancora più efficiente di un bufferedreader? Non lo so, bisognerebbe provare. Sicuramente il codice è un po' più incasinato.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 07-03-2004, 02:25   #14
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
Quote:
Originariamente inviato da PGI
....bisognerebbe provare. Sicuramente il codice è un po' più incasinato.
dici? .....guarda un pò questo codice che ho buttato giù, come ti sembra?

Codice:
import java.io.*;
import java.nio.*;
import java.nio.channels.*;
import java.nio.charset.*;



public class ReadFile {


  static String text = new String("");
  
  static Charset charset = Charset.forName("ISO-8859-1");
  static CharsetDecoder charsetDecoder = charset.newDecoder();

  static File aFile = new File("C:\\file.bin");
  static FileChannel inChannel;
  static ByteBuffer buffer;

  static {
       try { 
         inChannel = new FileInputStream(aFile).getChannel(); 
      } catch(Exception e) { }
  }


  public ReadFile() {
    
    buffer = ByteBuffer.allocate((int)aFile.length());
    
    try {
      
      while( inChannel.read(buffer) != -1 ) {
                              buffer.flip();
                              text = (charsetDecoder.decode(buffer)).toString();
                              buffer.clear();
                      } 
                      inChannel.close();
                      
                    } catch(IOException e) {
                      e.printStackTrace(System.err);
                      System.out.println("End of stack trace"); }

    splitting();
  }
  
  
  public void splitting() {
    String[] array = text.split("\n");
    System.out.println("^_^");
  }
  

}
è valida come soluzione secondo te?

ciao



edit ps: ho separato in un metodo a se stante le righe di codice per splittare così da poter eventualmente modificare lo String text completo in altri modi.
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------

Ultima modifica di Frank1962 : 07-03-2004 alle 02:29.
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 07-03-2004, 19:20   #15
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Per funzionare dovrebbe funzionare, bisogna vedere se funziona "meglio".

Prima carichi la stringa in un buffer, poi carichi il contenuto in un array, alla fine potresti ritrovarti con un po' di duplicati.

Ma la cosa è tutta da vedere, perchè il motore di gestione delle stringhe in Java potrebbe anche offrire la possibilità di rimuovere i duplicati usando il metodo "intern()" della classe String, che rimpiazza la stringa generata con un riferimento ad una delle stringhe nel pool in memoria. Forse si potrebbe parzializzare tutto il testo in tanti "token" quante sono le singole parole e richiamare "intern()" su ciascuno di essi. Ma è un'idea un po' così. E poi dipende dalla lunghezza del testo, per 100kb non andrei ad arrovellarmi troppo sulla questione, per 40megabyte però...

Ciao.
PGI è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
iPhone Fold: scorte limitate al lancio m...
OpenAI porterà la pubblicità in ChatGPT ...
TSMC aumenterà ancora i prezzi: nel 2026...
Marvel pubblica anche il secondo teaser ...
Nuovo accordo tra xAI e il Pentagono: l'...
La famiglia Xiaomi 17 sta per registrare...
Nuove auto elettriche che vedremo sul me...
E-bike illegali, a Verona il più ...
Quali sono i giochi più venduti su Steam...
HONOR sta per lanciare un nuovo smartpho...
Jared Isaacman sarà alla guida de...
Il Tesla Cybertruck non arriverà ...
Xiaomi Watch 5 è ufficiale: architettura...
CD Projekt vende GOG: il co-fondatore Mi...
Il meglio di Amazon in 26 prodotti, aggi...
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: 04:27.


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