Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-10-2010, 21:28   #1
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
[C] raggruppare esadecimale a gruppi di due

Ho un numero esadecimale, tipo 2D000801F166AF10 e voglio raggrupparlo a gruppi di due cifre partendo da destra:
10 AF 66 etc inserendole come numeri 0x10 , 0xAF in un array.

Se fosse stato un decimale avrei usato la divisione per 100 e il modulo,ma essendo esadecimale come devo fare?
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 21-10-2010, 21:48   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
potresti usare un shift verso destra combinato con una operazione logica AND per mettere a zero ciò che non ti interessa e copiare i valori in un array, poi questo lo giri sottosopra.
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 21-10-2010, 23:10   #3
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Grazie. Ho provato così:

Codice:
	
long temp = 0x2D000801;//F166AF10;
long gruppo;			

	for (j = 3; j >= 0; j--)
	{
		
		gruppo = (temp >>  j*8) & 0xFF ; 
		printf("%x %x\n",temp, gruppo );
	}
con 8 cifre funziona.
Ma se metto le 16 cifre devo passare al double e allora mi dà errore nell'operazione bitwise: "error: invalid operands to binary >>"

Come si fa un bitwise col double?


Magari potrebbe essere più semplice trattare le cifre come una stringa e prendere la stringa a gruppi di due e fare poi un cast per trasformare la coppia di caratteri numerici in int?

Però non so come scriverla quest'operazione con le stringhe.
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 00:12   #4
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
ehm già non avevo pensato se fosse più lungo ..... ... usare il float è una cappellata perchè il float il s.o. lo memorizza in modo diverso, anche con un int normale avresti problemi perchè il primo bit a sinistra è quello di segno quindi ti cambia tutta l'interpretazione da fare.... il bello è quando è negativo perchè sarà un roba del tipo 0xfffffff1..... .. usa unsigned, guadagni un bit.

cmq non so, credo anche io che sia il caso di utilizzare un semplice array, anche se poi hai un problema di dover fare la conversione da array a valore numerico, ma forse non ne hai bisogno....

non puoi fare un cast con l'int, pensa a come memorizza il numero F3 il sistema..... per lui saranno char quindi F => 46h e 3 => 33h... se usi atoi() forse ci sono più possibilità, ma essendo l'array scomposto forse diventa complicato perchè devi tenere conto della posizione delle cifre che hanno nel numero finale...

il problema sono i numeri grandi, hai veramente bisogno di numeri così grandi?
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 09:16   #5
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Bè in realtà è un codice esadecimale inciso su un chip per riconoscere un sensore.
Quindi devo memorizzare questo codice in un array per poi fare una ricerca per sensore.

Ho provato a fare l'assegnamento a mano con:

short ROM[9];

ROM[0]=0x10 ;
ROM[1]=0x57 ;
...
ROM[7]=0x20;

e funziona.

In effetti la funzione che legge il codice mi popola direttamente l'array a gruppi di due.

Ma io ho una lista di codici che voglio inserire in variabili (double o char)
double temp = 0x2D000801F166AF10;
o
char temp[] = 2D000801F166AF10;

e volevo che automaticamente mi creasse l'array con i gruppi di due cifre esadecimali del sensore che voglio.
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 11:03   #6
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 21919
lavorare su un array di binari?
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 16:34   #7
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Ok, prima di passare a provare coi binari, avevo iniziato questo approccio con le stringhe e forse può essere la strada giusta. Ma c'è da fare qualche ritocco:

Intanto per passare da stringa a int in hex:

Codice:
  char *str = "3a";
  int num;
  sscanf(str, "%x", &num); 
  printf("%x", num);
e questo ci risolve la trasformazione in intero della coppia di lettere hex.

Allora facendo un ciclo con una stringa più lunga e memorizzando in un array di interi:

Codice:
	
char *str = "2D1b3c1f";     //000801F166AF10";
	long num[16];
	int iN =0;
	
	while(*str) 
	{
		sscanf(str, "%X", &num[iN]); 
		printf("%X\n", num[iN]);
		str += 2;
		iN++;
	}
C'è il problema che si passa dalla coppia 1F al 3C1F invece che 3C solo.
Bisognerebbe dirgli di andare avanti nel leggere la stringa a due a due, ma anche di non andare fino alla fine, ma di fermarsi dopo due caratteri.

Poi c'è un altro problema, che se metto una stringa tipo "2D1b001f" con la coppia di 00, mi sballa dandomi:

2D1b001f
1b001f
1f
1f
mi salta la coppia 00 e mi scrive due volte 1F...

Qualche suggerimento?
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 16:37   #8
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 21919
0 in binario corrisponde al carattere \0 che è il terminatore di stringa
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 16:40   #9
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Quindi non si può mai trasformare una stringa 00 in intero hex ??
Acc...

Allora non rimane altro che l'array di binari?
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 17:05   #10
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da frank10 Guarda i messaggi
...
Se fosse stato un decimale avrei usato la divisione per 100 e il modulo,ma essendo esadecimale come devo fare?
Scusate, magari sparo la cazzata, ma non basta cambiare la base con cui si fanno queste operazioni?
Cioè se ho una sequenza di cifre in base 10 e voglio prenderle a due a due divido e/o uso il modulo con i numero 100 perchè è il risultato del calcolo: Base^NumCifre (10^2).

Ora tu hai Base=16 e NumCifre=2... (16^2=256 ovvero "100" in esadecimale).
"2D000801F166AF10" mod "100" = "10".
"2D000801F166AF10" / "100" = "2D000801F166AF".
Semplice no?

EDIT:
Mi sa che sono rimasto indietro, avevo considerato solo il primo post, ignoratemi
__________________

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 : 22-10-2010 alle 17:11.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 17:22   #11
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Sì, hai ragione per il long, ma il problema è che ho quella cifra hex molto lunga per cui mi toccherebbe usare il double e lì non mi permette di usare il mod:
"invalid operands to binary %"

Bisognerebbe spezzare in due l'hex del double di 16 cifre in due long da 8.

EDIT: ok grazie comunque.
frank10 è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2010, 19:05   #12
frank10
Senior Member
 
Iscritto dal: Feb 2005
Messaggi: 579
Ho risolto sempre lavorando un po' con le stringhe!

Codice:
int ROM[8];
int k = 7;		
int i;
char *str1 = "2D000801F166AF10";

for (i=0;i<15;i=i+2)	
{
     printf("%c%c\n",str1[i],str1[i+1]);
	
     ROM[k]= (str1[i]>'9'?(str1[i]&0xDF)-'A'+10:str1[i]-'0')*8*2   +  (str1[i+1]>'9'?(str1[i+1]&0xDF)-'A'+10:str1[i+1]-'0') ;
	
	
     printf("---->dec=%d \n",ROM[k]);
     k--;
}
Prendo il mio codice hex e lo metto in una stringa.
Leggo i valori dall'array a gruppi di due.
Converto i valori di quei singoli caratteri in decimali convertendo le eventuali lettere hex, li moltiplico a seconda della loro posizione hex e li sommo, ottenendo il numero decimale.
Lo memorizzo in un array int.
Ho visto che riconosce il codice del sensore anche in formato dec, non solo hex.


Ho trasformato in dec perché non riuscivo ad applicare l'altro metodo che ho postato prima col sscanf, ai singoli due caratteri prelevati con str1[i]...


Comunque non ho capito bene cosa intendevi !fazz con array di binari. Puoi spiegarmi meglio il metodo? Magari è un'ovvietà, ma non mi viene dopo che ho risolto così
frank10 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
La capsula SpaceX Dragon CRS-33 ha acces...
La NASA è sempre più vicin...
Crisi delle memorie: ASUS torna al passa...
Le console next-generation potrebbero es...
Gemini cresce ancora: la quota di mercat...
Samsung sfida TSMC: la capacità produtti...
Iliad alza il prezzo della fibra ottica ...
Il prossimo low cost di POCO sarà il più...
The Elder Scrolls VI: ecco le ultime sul...
Ecco i saldi di fine anno Amazon, 34 off...
iPhone Fold: scorte limitate al lancio m...
OpenAI porterà la pubblicità in ChatGPT ...
TSMC aumenterà ancora i prezzi: nel 2026...
Marvel pubblica anche il secondo teaser ...
Nuovo accordo tra xAI e il Pentagono: l'...
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: 16:07.


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