Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-06-2012, 12:37   #1
legolas93
Senior Member
 
Iscritto dal: Dec 2007
Messaggi: 659
[JAVA] Perdo 256

Codice:
	byte z1 = (byte) (4500>>8);
		println(Integer.toBinaryString(z1));
		byte z2 =  (byte)(4500);
		println(Integer.toBinaryString(z2));
		
		int z3 = ((z1<<8)+ z2);
		println(z3);
Mi stampa

10001
11111111111111111111111110010100
4244

Perchè ho perso 256?

Perchè il secondo Byte ha così tante cifre?
legolas93 è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2012, 13:51   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Il valore letterale intero 4500 in binario è:"1000110010100".
Poi tu forzi il cast a byte. Il tipo Byte è formato di 8 bit, cioè 8 cifre binarie.
Se tronchi "1000110010100" a 8 cifre resta la parte: "xxxxx10010100" e il resto è perso nella conversione.

In Java i tipi primitivi sono tutti trattati come signed, non esiste il concetto di unsigned type.
Quindi qua:
Codice:
Integer.toBinaryString(z2)
z2 viene convertito a int, prima di essere passato come argomento al metodo toBinaryString (che accetta un parametro di tipo int).

"z2" "unsigned" dovrebbe essere convertito come un int di valore "00000000 00000000 00000000 10010100" (148 in decimale), invece viene trattato come tipo signed e viene convertito in un int di valore "11111111 11111111 11111111 10010100" (-108 in decimale)

Prova a fare così:
Codice:
byte z1 = (byte) (4500>>8);
		println(Integer.toBinaryString(z1));
		byte z2 =  (byte)(4500);

                int z2Cast = unsignedByteToInt(z2);
		println(Integer.toBinaryString(z2Cast));
		
                int z1Cast = unsignedByteToInt(z1);
		int z3 = (z1Cast << 8) + z2Cast;
		println(z3);

// da qualche parte, qualcosa tipo:
public static int unsignedByteToInt(byte b) {
    return ((int) b) & 0xFF;
}
Non ho provato il codice e sono di fretta, ma dovrebbe essere corretto.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 12-06-2012 alle 14:35.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2012, 14:20   #3
legolas93
Senior Member
 
Iscritto dal: Dec 2007
Messaggi: 659
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Il valore letterale intero 4500 in binario è:"1000110010100".
Poi tu forzi il cast a byte. Il tipo Byte è formato di 8 bit, cioè 8 cifre binarie.
Se tronchi "1000110010100" a 8 cifre resta la parte: "xxxxx10010100" e il resto è perso nella conversione.

In Java i tipi primitivi sono tutti trattati come signed, non esiste il concetto di unsigned type.
Quindi qua:
Codice:
Integer.toBinaryString(z2)
z2 viene convertito a int, prima di essere passato come argomento al metodo toBinaryString (che accetta un parametro di tipo int).

"z2" "unsigned" dovrebbe essere convertito come un int di valore "00000000 00000000 00000000 10010100" (148 in decimale), invece viene trattato come tipo signed e viene convertito in un int di valore "11111111 11111111 11111111 10010100" (-108 in decimale)

Prova a fare così:
Codice:
byte z1 = (byte) (4500>>8);
		println(Integer.toBinaryString(z1));
		byte z2 =  (byte)(4500);
		println(Byte.valueOf(z2));
		
                int z2Cast = unsignedByteToInt(z2);
                int z1Cast = unsignedByteToInt(z1);
		int z3 = (z1Cast << 8) + z2Cast;
		println(z3);

// da qualche parte, qualcosa tipo:
public static int unsignedByteToInt(byte b) {
    return ((int) b) & 0xFF;
}
Non ho provato il codice e sono di fretta, ma dovrebbe essere corretto.
Grazie mille davvero! Tutto funziona e ho capito anche perchè. Non potevo chiedere di meglio.
legolas93 è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2012, 14:30   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
4500 in binario è:
0001 0001 1001 0100
Mettendolo in un byte hai una perdita, esso viene troncato e diventa:
1001 0100
il cui valore è -108 (il primo bit è il bit di segno)
Integer.toBinaryString si aspetta un int, quando lo invochi quindi il byte viene automaticamente castato a int e in questo caso la conversione è senza perdita, ma su 4 byte -108 viene rappresentato come
1111 1111 1111 1111 1111 1111 1001 0100
Riguardo a questo invece:
Codice:
int z3 = ((z1<<8)+ z2);
z1 vale 0001 0001, applicando l'operatore di shift viene implicitamente castato a int, poi avvenendo lo shift diventa
0001 0001 0000 0000
cioè 4352
anche z2, per via dell'operatore + viene castato implicitamente a int (ma non è particolarmente rilevante sottolinearlo). In ogni caso z2 vale -108 come detto più su. Quindi l'operazione diventa
4352 - 108
cioè appunto 4244

Reference:
http://docs.oracle.com/javase/specs/...tml/jls-5.html

EDIT: avevo scritto la prima parte e dopo pranzo ho finito, non ho visto che nel frattempo ti avevano già risposto...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2012, 16:16   #5
legolas93
Senior Member
 
Iscritto dal: Dec 2007
Messaggi: 659
Grazie Mille ad Entrambi davvero molto chiari
legolas93 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
PlayStation Portal con display OLED: Son...
POCO X8 Pro e Pro Max sono quasi pronti:...
OpenAI ha bisogno di nuovi fondi: NVIDIA...
Mese nuovo, rinnovo delle offerte Amazon...
Accessori auto imperdibili su Amazon: pu...
Gli utenti iPhone possono ridurre la pr...
Come fare affari con l'usato garantito d...
Il miglior tablet di tutta Amazon, DOOGE...
Gli smartphone in super offerta su Amazo...
Produttori di memoria più severi ...
WhatsApp Business, Meta introduce costi ...
SpaceX vuole portare nello Spazio 1 mili...
Realme 16: il nuovo mid-range che si isp...
DAZN lancia il piano Full Mobile a 19,99...
Samsung Galaxy S26, ormai è tutto...
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: 13:49.


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