Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2007, 23:07   #1
dnarod
Senior Member
 
L'Avatar di dnarod
 
Iscritto dal: Nov 2002
Messaggi: 4329
[java]struttura di puntatori a sequenze di bit di lunghezza variabile...

spiego meglio: mi trovo a dover lavorare coi bit in java, e cascasse il mondo ci devo riuscire...in pratica devo generare il codice di huffman per ogni carattere di una determinata sequenza...inizio col dire cio che faccio: leggo un file e metto le rispettive frequenze dei caratteri i un array di interi (dimensione-> caratteri ascii per esempio)...poi sbatto tutto dentro una coda con priorita che realizzo con un heap binario...dopodiche, visito in preordine l heap e quello che mi manca è l ultimo passo! devo infilare, per ogni carattere, una sequenza di bit che lo caratterizzino...

l algoritmo di per se è una baggianata, l ho fatto in 5 minuti, ma poi mi sono reso conto che invece dei bit stavo pushando dei caratteri '0' o '1' in degli stringbuffer per ogni elemento del mio alfabeto...e questo puo non essere male per fini didattici, ma lo è se si pensa che sta roba ha la pretesa di comprimere (per esempio un testo) quando in realta aumenta lo spazio...

la soluzione? usare i bit, ok....ma ho dato un occhiata alle api e ho trovato solo una scialbissima bitset e non so come e se sia possibile servirmene...il numero di bit che caratterizza ogni singolo elemento del mio alfabeto è varibile, quindi vorrei una struttura che mi dia la possibilita di esprimere sto fatto...

avendo letto da qualche parte che i boolean pigliano 1 bit, ho pensato a una cosa lercia e credo bruttissima: un array di arrayList (mamma mia mi faccio cagare da solo) con dentro un po di booleani quando servono...


e finalmente la domanda: tolto che voglio farlo cosi (e non con altri linguaggi o con altri metodi) perche sono il solito testardo, è possibile avere in grazia i bit in java con qualche classetta magica? ovvero, c e una soluzione piu indolore e meno sporca, se non quasi pulita?

grazie in anticipo per il mal di testa
__________________
|18k+|slk800|a7n8x|1Gb/ddr400|Gf4mx440|Pio108|WD 160Gb|Case|Uni|Album|AnimeClick|OneManga|
|ClassicThrash!|BNR Metal|TrueMetal|Dime|Chuck|
dnarod è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2007, 23:36   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Secondo le specifiche del linguaggio di programmazione Java un boolean potrebbe benissimo occupare 40 gigabyte.

BitSet ingrassa a piacere. Il metodo set imposta a true un bit. Anche il centomillesimo. Credo funzioni a multipli di 32, forse 64. Basta guardare il sorgente per sincerarsene.

Non puoi creare un array di ArrayList a meno di usare una versione anteguerra di Java (pre 5). Puoi creare un ArrayList di ArrayList.

Ma anche la soluzione dei char non va male. Forse è poco rappresentativa del concetto di Bit. Comunque quando vai a scrivere o inviare i dati compressi prendi la tua rapprentazione in memoria e la traduci in un flusso di bit, in pacchetti da 8, non ti metti certo ad inviare un long per un vero o falso. In più se lo scrivi su disco hai un minimo sindacale occupabile che è la dimensione del cluster. Se lo tieni in memoria, hai il metro della parola (word). Che io sappia nessuno di questi è grande esattamente 1 bit.

Insomma, usare due bit anzichè uno non significa meritare il titolo di sprecone honoris causa. Non essere avaro! .
__________________
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 17-03-2007, 13:44   #3
dnarod
Senior Member
 
L'Avatar di dnarod
 
Iscritto dal: Nov 2002
Messaggi: 4329
grazie, alla fine l ho spuntata...credevo che bitset non facesse al caso, invece è perfetto!


inoltre utilizzandolo comprimo un testo ascii minimo minimo del 20-30% ma di solito è di piu


ora mi rimangono cose miscellanee come una gui decente e mi riterro piu o meno soddisfatto

per salvare il file compresso, serializzo un oggettino che contiene l albero di huffman e il bitset di dati....mi piacerebbe poter eliminare il file di testo ogirinale una volta finito di serializzare il pacco compresso...ora guardo un attimo come si fa...


cmq finalmente in uni mi danno un esercizietto degno di nota...non che sia qualcosa di complesso (per i fatti miei ho sbattuto su cose enormemente piu pesanti), ma almeno sta roba ha una qualche pseudo-utilita meta didattica (non che sia utile un compressore ascii ma almeno incista di piu che non stampare un output di un algoritmo inutile)
__________________
|18k+|slk800|a7n8x|1Gb/ddr400|Gf4mx440|Pio108|WD 160Gb|Case|Uni|Album|AnimeClick|OneManga|
|ClassicThrash!|BNR Metal|TrueMetal|Dime|Chuck|
dnarod è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2007, 15:58   #4
dnarod
Senior Member
 
L'Avatar di dnarod
 
Iscritto dal: Nov 2002
Messaggi: 4329
bom...gui essenziale, comprimi, decomprimi, guadagno il 50%, triccheballacche...

ora pero mi sono intrippato di quest argomento e vorrei fare qualcosa che comprima non solo file...dove trovo il sapere necessario?
__________________
|18k+|slk800|a7n8x|1Gb/ddr400|Gf4mx440|Pio108|WD 160Gb|Case|Uni|Album|AnimeClick|OneManga|
|ClassicThrash!|BNR Metal|TrueMetal|Dime|Chuck|
dnarod è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2007, 16:21   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Studiati LZ77 e LZ78
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2007, 17:53   #6
dnarod
Senior Member
 
L'Avatar di dnarod
 
Iscritto dal: Nov 2002
Messaggi: 4329
wow, ecco intendevo proprio cose simili...azzo se solo avessi un po piu di tempo potrei giocare di piu con ste cose...
__________________
|18k+|slk800|a7n8x|1Gb/ddr400|Gf4mx440|Pio108|WD 160Gb|Case|Uni|Album|AnimeClick|OneManga|
|ClassicThrash!|BNR Metal|TrueMetal|Dime|Chuck|
dnarod è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Google lancia l'allarme: un miliardo di ...
Secondo NVIDIA, i 660 miliardi di dollar...
Qualcomm punta sulla flessibilità...
Amazon sconta schede video, CPU e access...
Halo: Campaign Evolved, l'uscita del rem...
La rete elettrica europea sta limitando ...
Apple Magic Keyboard per iPad Pro 11'' i...
BYD punta a nuove tecnologie: batterie a...
Windows 11 porta il Bluetooth multi-disp...
iPhone 17e e non solo: Gurman svela le c...
Arrestato per omicidio, in lacrime ai po...
Vexilar, scopa elettrica da 65000Pa, 4,9...
Linux 7.0 sarà la prossima versio...
Windows 11: Copilot AI entra anche nella...
Apple apre CarPlay ai chatbot di terze p...
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: 14:14.


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