Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-06-2012, 11: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, 12: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 13:35.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2012, 13: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, 13:30   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2788
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, 15: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


Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
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...
Roscosmos aggiorna le tempistiche per la...
Confermato il ritardo delle missioni rob...
L'Intelligenza Artificiale ora può...
Il data center del futuro secondo Huawei...
Spesa a domicilio senza conducente: robo...
Satoshi Nakamoto ha finalmente un volto?...
La Corea del Sud taglia fuori i bus elet...
GoPro taglia ancora: licenziato il 23% d...
Muse S Athena: la fascia che ti legge ne...
PS5 Pro e PSSR 2.0: tutti i giochi compa...
Dimensity 9600 Pro promette prestazioni ...
BMW i7 2026 adotta celle cilindriche Gen...
Cyberpunk 2077 si aggiorna su PS5 Pro co...
Valve porta Steam Link su Vision Pro per...
Google Maps: ufficiali 3 novità c...
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: 21:12.


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