Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-05-2007, 14:15   #1
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
[JAVA] availability di un ObjectInpuStream

Mi succede una cosa veramente strana con un ObjectInputStream, ho un file contenente degli oggetti scritti con un writeObject() da un ObjectOutputStream e che cerco di rileggere con un ObjectInputStream, apro un FileInputStream sul File e lo inscatolo dentro l'ObjectInputStream, solo che l'availability di quest'ultimo è zero mentre quello del FileInputStream no!!!!
Questo è il codice
Codice:
FileInputStream fis=new FileInputStream(this.theFile);
            ObjectInputStream ois=new ObjectInputStream(fis);
            System.out.println("Starting the cycle, availability (ois):"+String.valueOf(ois.available())+", availability (fis):"+String.valueOf(fis.available()));
            while (ois.available()>0){
                System.out.println("I'm in, trying to read");
                ris.add((IEsame)ois.readObject());
                System.out.println("I'm in, read");
            }
            ois.close();
            fis.close();
            return ris;
e questo è l'output quando chiamo questo metodo
Codice:
Starting the cycle, availability (ois):0, availability (fis):5617
A questo punto non so cme mai il fis ha disponibilità di byte e uando (nella riga dopo) lo inscatolo in un ObjectInputStream sembra che perda il suo contenuto!!!! (Naturalmente nel ciclo non ci entra mai)
Qualcuno ha qualche idea????
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 14:53   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Non usare available(). E' un metodo che ha una documentazione sibillina. In particolare non si capisce se possa restituire zero, anche senza aver raggiunto la fine del file, quando non sia possibile leggere ulteriori byte senza bloccare il flusso di controllo. Probabilmente restituisce zero in entrambi i casi, cioè se ha raggiunto la fine del flusso oppure è possibile leggere zero byte prima di un blocco.

Usa FileChannel, position() e size() e vai sul sicuro.

Codice:
FileChannel channel = new FileInputStream(file).getChannel();
ObjectInputStream ois = new ObjectInputStream(Channels.newInputStream(channel));
while(channel.position() < channel.size()) {
     Object o = ois.readObject();
}
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!

Ultima modifica di PGI-Bis : 08-05-2007 alle 14:54. Motivo: Un po' di grammatica, via!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 15:17   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da morskott Guarda i messaggi
Mi succede una cosa veramente strana con un ObjectInputStream, ho un file contenente degli oggetti scritti con un writeObject() da un ObjectOutputStream e che cerco di rileggere con un ObjectInputStream, apro un FileInputStream sul File e lo inscatolo dentro l'ObjectInputStream, solo che l'availability di quest'ultimo è zero mentre quello del FileInputStream no!!!!
Se devi deserializzare diversi oggetti senza sapere quanti sono a priori, una possibile idea potrebbe essere quella di fare la lettura in un ciclo infinito e di catturare all'esterno del ciclo l'eccezione EOFException, in modo che quando viene lanciata, il ciclo di lettura termina.

Può sembrare un po' "rozzo" ma funziona. (PGI-Bis, sei d'accordo con me?).
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 15:21   #4
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Adesso ho una exception veramente esotica
Codice:
java.io.StreamCorruptedException: invalid type code: AC
	at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1356)
	at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
	at esami2.dao.EsameDAO.findAll(EsameDAO.java:79)
	at esami2.dao.EsameDAOTest.testFindAll(EsameDAOTest.java:105)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at junit.framework.TestCase.runTest(TestCase.java:154)
	at junit.framework.TestCase.runBare(TestCase.java:127)
at junit.framework.TestResult$1.protect(TestResult.java:106)
	at junit.framework.TestResult.runProtected(TestResult.java:124)
	at junit.framework.TestResult.run(TestResult.java:109)
	at junit.framework.TestCase.run(TestCase.java:118)
	at junit.framework.TestSuite.runTest(TestSuite.java:208)
	at junit.framework.TestSuite.run(TestSuite.java:203)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.run(JUnitTestRunner.java:297)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.launch(JUnitTestRunner.java:672)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.main(JUnitTestRunner.java:567)
esattamente alla readObject(). Nel file ho fatto lo store di 3 oggetti con questo codice
Codice:
FileOutputStream fos=new FileOutputStream(this.theFile,true);
            ObjectOutputStream oos=new ObjectOutputStream(fos);
            oos.writeObject(esame);
            oos.close();
            fos.close();
Qualcuno sa spiegarmela????

Ultima modifica di morskott : 08-05-2007 alle 15:23.
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 17:07   #5
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Io sono restio ad usare le eccezioni come condizioni di controllo, anche quando si tratta di EOFException che, se non ricordo male, sarebbe fatta apposta. Preferisco il canale che, con il suo bel cursore, è lì pronto a dirci quando non c'è più trippa per gatti.

morskott, devi mantenere una specularità tra il modo in cui scrivi ed il modo in cui leggi.

Se la serializzazione di più oggetti avviene aprendo e chiudendo l'ObjectOutputStream per ogni scrittura allora la lettura di più oggetti deve essere fatta aprendo un nuovo ObjectInputStream per ogni oggetto.

Se la serializzazione di più oggetti avviene "riciclando" uno stesso ObjectOutputStream (cioè lo apri una volta, ci scrivi 10 oggetti e poi lo chiudi) allora la deserializzazione va fatta riciclando uno stesso ObjectInputStream (lo apri una volta, leggi finchè puoi e poi lo chiudi).

Il tuo codice rientra nel primo caso.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 18:52   #6
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
risolto!!!!!!
grazie PGI!!!
morskott è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Panasonic LUMIX TZ300: la nuova compatta...
La società aerospaziale italiana ...
Il Politecnico di Milano guiderà ...
Amazon Leo punta ad aumentare la cadenza...
Pro Type Ergo: Razer si lancia a gamba t...
Artemis II: dal guasto risolto alla toil...
Le immagini e i video più spettac...
Previsioni drastiche di TrendForce: la D...
La PS6 portatile sarà più potente della ...
Toshiba annuncia i primi dischi FC-MAMR ...
Amazon Leo offrirà l'accesso a Internet ...
Alienware presenta i nuovi desktop Area-...
Fiat 600 benzina senza ibrido: 101 CV, c...
DJI Mini 4K Combo a 269€ o DJI Neo da 14...
Addio agli sprechi nel riciclo: il Fraun...
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: 23:37.


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