Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-01-2004, 23:03   #1
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
[java]da Byte a bit

come faccio a codificare un ByteBuffer in codice binario !!?

è possibile?
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 00:06   #2
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
"codificare un bytebuffer in codice binario" non è l'apice della chiarezza, ci vuole qualche informazione in più per sapere quali strumenti usare.

In via generale, il metodo Integer.toBinaryDigits(int) restituisce un letterale String che rappresenta la sequenza di bit che corrisponde al valore intero in notazione binaria (es. 2 -> 10), ma è una stringa e non un numero, per cui l'uso ha scopi estranei al calcolo.

La notazione binaria è estranea all'armamentario dei letterali numerici di Java (ci sono interi esadecimali, ottali, decimali a 32 e 64 bit, numeri in virgola mobile a precisione singola e doppia ma niente notazione binaria), il che significa che non puoi fare operazioni usando direttamente la notazione binaria.

Altro paio di maniche è la possibilità di operare sui singoli bit che compongono un intero: qui c'è tutta la famiglia degli operatori & | ^ e chi più ne ha più ne metta.

A titolo d'esempio, volendo conoscere il valore del terzo bit che compone il byte 53 è sufficiente una riga di codice e l'operatore bitwise "&" :

int bit = (53 & 4) == 4 ? 1 : 0;


In tutta sincerità non oso immaginare quale masochistica ragione ti porti a dover considerare una sequela di byte per i bit che compongono ciascun elemento (ma sono pronto ad essere stupefatto ).

&Ciao.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 00:36   #3
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
io non vorrei esattamente "operare" con i bit .....a me basta aver la possibilità di leggere un file e conoscere esattamente la sua struttura binaria invece dei bytes; ho fatto qualche prova usando anche il metodo che citi, Integer.toBinaryDigits(int), ma purtroppo non funziona, o meglio, l'Hex editor che uso per comparare i risultati mi segna qualcosa di completamente diverso ..........quindi evidentemente sbaglio in qualcosa, forse i bit di complemento non vengono calcolati con quel metodo


edit:

ho provato il codice che hai postato con gli operatori bit

Codice:
array = (Reader.Leggi()).array();  <--- array ricavato dal ByteBuffer
    for(int i=0; i<array.length; i++) {
       for(int e=0; e<8; e++) {
         int bit = (array[i] & e) == e ? 1 : 0;
         System.out.print(bit);
       }
    }
...credo però che il problema sia questo:

Codice:
try { inputFile = new FileInputStream(unFile); } catch(Exception e) { }
    FileChannel inChannel = inputFile.getChannel();
    try { inChannel.read(naltro); } catch(Exception e) { }
    int dimFile = Integer.parseInt(ok.valueOf(unFile.length()));

    try {
      while(inChannel.read(bite) == -1) {
        bite.clear();
      }
      inputFile.close();
    } catch(Exception e) { System.out.println(e); }
....ovvero come vado a "creare" il ByteBuffer .....ho provato a stamparmi il contenuto del buffer appena gli "alloco" la grandezza e l'otput è stato: "100000001000000010000000...ecc" per ogni byte in + ........in pratica su un ByteBuffer di 20byte mi trovavo una ventina di byte inizializzati a "10000000" e non a "00000000" ....forse il problema può essere questo ?


edit2:

le prove le ho fatte su un file txt dove ho scritto la parola "ciao" .......salvato su hd, credo in formato unicode, con il notepad; se leggo con l'hexeditor il risultato è questo:

01100011 01101001 01100001 01101111

mentre con il programma java:

11110000 11000000 11000000 11111111


un pò "diverso" come risultato
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------

Ultima modifica di Frank1962 : 12-01-2004 alle 03:29.
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 13:03   #4
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Codice:
import java.io.*;
import java.nio.*;
import java.nio.channels.*;

public class BitProva {
  public static void main(String[] a) {
    try {
      FileChannel channel = new FileInputStream("c:\\ciao.txt").getChannel();
      
      int numBytes = (int)channel.size();
      
      ByteBuffer buffer = ByteBuffer.allocate(numBytes);
      
      channel.read(buffer);
      
      buffer.flip();
      
      for(int i = 0; i < numBytes; i++) {
        String binDigits = Integer.toBinaryString(buffer.get(i));
        System.out.println(binDigits);
      }
      
      channel.close();
      
    } catch(IOException e) {
      e.printStackTrace();
    }

  }
}
1100011
1101001
1100001
1101111
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 14:05   #5
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
Quote:
Originariamente inviato da PGI
1100011
1101001
1100001
1101111
edit:

ma perchè non vengono aggiunti gli 0 iniziali ?

1100011 1101001 1100001 1101111

01100011 01101001 01100001 01101111
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------

Ultima modifica di Frank1962 : 12-01-2004 alle 14:17.
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 15:18   #6
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Probabilmente hanno scelto di "tradurre" solo i bit significativi, tra 0010 e 10 non c'è alcuna differenza, sempre 2 è.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 15:25   #7
Frank1962
Senior Member
 
L'Avatar di Frank1962
 
Iscritto dal: Sep 2001
Città: de_legato
Messaggi: 792
Quote:
Originariamente inviato da PGI
Probabilmente hanno scelto di "tradurre" solo i bit significativi, tra 0010 e 10 non c'è alcuna differenza, sempre 2 è.
Codice:
String binDigits = 0+Integer.toBinaryString(buffer.get(i));
cmq per avere il codice corretto basta aggiungere uno 0

ps: ma se volessi avere un array di valori short che mi contenga gli 0/1 come dovrei fare ..........mi occuperebbe + spazio in memoria l'array di short oppure la stringa completa?
__________________
----------------------------------------------
File reality.sys corrupted, Reboot Universe? Y/N
----------------------------------------------
Frank1962 è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 19:32   #8
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Quote:
Originariamente inviato da Frank1962
Codice:
String binDigits = 0+Integer.toBinaryString(buffer.get(i));
cmq per avere il codice corretto basta aggiungere uno 0
Beh, no. Per avere la notazione corretta dovresti generalizzare un pelo la faccenda. In realtà devi aggiungere un numero di cifre 0 compreso tra 8 e 0 a seconda di dove si trovi la prima cifra 1 a partire da sinistra.

10 -> 2 -> 0000 0010 (8 bit x 1 byte)

Quote:
Originariamente inviato da Frank1962
ps: ma se volessi avere un array di valori short che mi contenga gli 0/1 come dovrei fare ..........mi occuperebbe + spazio in memoria l'array di short oppure la stringa completa?
Fai un "benchmark" sull'occupazione di memoria di un oggetto String e poi su un array di short e scopri subito. In teoria la stringa dovrebbe essere più piccola (perchè si "basa" su un array di char, ma bisogna poi vedere quanto pesa il resto del contenuto dell'oggetto String).

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


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...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
NVIDIA mostra una comunità di rob...
Sony annuncia LYTIA L910, arriva il sens...
Ericsson, il 5G è l’infrastruttur...
Marvell punta tutto su TSMC A14: sar&agr...
Hyundai a un passo dal controllo totale ...
Questo SSD vecchio 16 anni ha resistito ...
Monopattino elettrico Xiaomi in offerta:...
Microsoft usa le capre di Age of Empires...
Microsoft conferma bug nel Cestino in tu...
Accenture crolla del 20% in borsa, il pe...
ASUS Pro WS W890E-SAGE SE: sette PCIe 5....
Attenzione al prezzo di questa TV Hisens...
Chrome sbeffeggiato da Ballmer nel 2009:...
Un gioco Mac compatibile con Apple Silic...
La batteria allo stato solido di Honda 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: 00:04.


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