Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
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 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2010, 11:43   #1
grana
Senior Member
 
Iscritto dal: Jan 2003
Messaggi: 848
[C++] string, utf-8, accenti, lunghezze..

Ciao,

sto sbattendo la testa contro un muro In particolare, leggo che il tipo std::string può lavorare in UTF-8 (è così?), mentre il wstring è per formati ancora più "larghi" (UTF-16 e UTF-32).

Ma allora perchè:
Codice:
std::string test="qualità";
cout << test.length() << endl;
dà come risultato
Codice:
8
Lo stesso codice, utilizzando wstring, funziona correttamente (7) ma preferirei, se posso, usare il tipo string per poter mantenere la compatibilità con le altre classi e per ottimizzazione.

Sapete aiutarmi?

Grana
grana è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 12:16   #2
il-pollo
Senior Member
 
Iscritto dal: Aug 2008
Messaggi: 382
usando Visual Studio 2008 ottengo il risultato corretto nella versione con std::string
strano sto problema
il-pollo è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 12:58   #3
grana
Senior Member
 
Iscritto dal: Jan 2003
Messaggi: 848
Quote:
Originariamente inviato da il-pollo Guarda i messaggi
usando Visual Studio 2008 ottengo il risultato corretto nella versione con std::string
strano sto problema
Sono sotto linux, e sospetto che abbia a che fare con i locale, ma anche con
std::locale::global(std::locale("it_IT.utf8"));
non cambia niente
grana è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 13:44   #4
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da grana Guarda i messaggi
Ciao,

sto sbattendo la testa contro un muro In particolare, leggo che il tipo std::string può lavorare in UTF-8 (è così?), mentre il wstring è per formati ancora più "larghi" (UTF-16 e UTF-32).

Ma allora perchè:
Codice:
std::string test="qualità";
cout << test.length() << endl;
dà come risultato
Codice:
8
Lo stesso codice, utilizzando wstring, funziona correttamente (7) ma preferirei, se posso, usare il tipo string per poter mantenere la compatibilità con le altre classi e per ottimizzazione.

Sapete aiutarmi?

Grana
Puoi utilizzare std::string per contenere una stringa codificata in UTF-8, bisto che quest'ultima non e' altro che una sequenza di singoli byte,ma il risultato non e' quello che ti aspetti. Una volta che si va oltre i caratteri ASCII infatti i caratteri cominciano ad usare piu' di un byte e non c'e' piu' corrispondenza tra la tabella caratteri usata per la lettura delle stringhe (dipendente tipicamente dal locale utilizzato) e la tabella UTF-8.
Devi cercarti delle funzioni accessorie che facciano l'opportuna conversione delle stringhe in formato UTF-8 e viceversa.
In particolare, se non ricordo male, le stringhe letterali nel sorgente vengono interpretate secondo il set di caratteri utilizzato dal compilatore.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2010, 08:41   #5
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da grana Guarda i messaggi
Ma allora perchè:
Codice:
std::string test="qualità";
cout << test.length() << endl;
dà come risultato
Codice:
8
Come puoi vedere qui:
http://www.utf8-chartable.de/unicode...ble.pl?start=0
La codifica UTF-8 della à occupa due byte, il che potrebbe spiegare la lunghezza maggiorata.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2010, 08:50   #6
grana
Senior Member
 
Iscritto dal: Jan 2003
Messaggi: 848
mi sembra assurdo (intendo l'implementazione, non la tua risposta che sicuramente è corretta), ma grazie (anche se non mi spiego perchè in visual studio il risultato sia corretto).

Possibile che non ci sia un metodo "charlen", o qualcosa del genere?
grana è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Intel riacquista la Fab 34 in Irlanda, u...
SpaceX ha lanciato la missione Transport...
Occhiali smart in affitto: la nuova stra...
L'aeroplano supersonico ''silenzioso'' N...
Il primo chip a 2 nm di MediaTek sarà a...
Blue Origin lancerà il satellite ...
Roscosmos torna a lanciare capsule verso...
La connettività satellitare anche sui di...
Astronauta italiano sul suolo lunare gra...
Senza formazione ai dipendenti l'IA non ...
Google rende disponibile l'opzione per i...
Oracle licenzia migliaia di persone con ...
Il semaforo bianco sta arrivando: cos'è,...
FRITZ!Repeater 2700 disponibile su Amazo...
Xiaomi TV A Pro: QLED 4K da 65'' con Goo...
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: 22:19.


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