Questo codice sembrava funzionare bene nelle versioni (ubuntu trusty) di gcc e clang, e in Win 7 su una VM tramite mingw ... Recentemente ho aggiornato a Wily e le build fatte con clang si sono verificate costantemente qui.È corretto questo semplice programma C++ utilizzando <locale>?
#include <iostream>
#include <locale>
#include <string>
int main() {
std::cout << "The locale is '" << std::locale("").name() << "'" << std::endl;
}
A volte è una stringa senza senso seguita da Aborted: Core dumped
e, talvolta, la sua invalid free
.
$ ./a.out
The locale is 'en_US.UTF-8QX�у�X�у����0�����P�����\�(��\�(��\�(��h��t�������������y���������ț�ԛ�������en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_UP����`�������������������������p�����������@��������������`�������������p��������������������@��@��@��`��������p������������0��P��p���qp��!en_US.UTF-8QЈ[�����\�(��\�(��\�(�����������@�� �����P�����0�����P�����\�(��\�(��\�(��Ȣ�Ԣ����������������(��4��@��L��en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8!�v[��������������@�� �����P�����0�����P�����\�(��\�(���(��h��t��������������������Ȥ�Ԥ�������en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8!��[�� ����[�������7����7��.,!!x�[��!��[��!�[��@�����������@�� �����P�����0�����P�����\�(��\�(��\�(��(��4��@��L��X��d��p��|������������n_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8ѻAborted (core dumped)
$ ./a.out
The locale is 'en_US.UTF-8QX\%�QX\%�Q�G�0H��H�PI��I�\:|�Q\D|�Q\>|�QhK�tK��K��K��K��K��Q�K��K��K��K��K��K�en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8en_US.UTF-8ѻ
*** Error in `./a.out': free(): invalid pointer: 0x0000000000b04a98 ***
Aborted (core dumped)
(Entrambe le uscite di programma sopra sono stati abbreviato notevolmente altrimenti non si adatterebbe in questa domanda.)
Ho anche avuto un invalid free on Coliru con esso pure.
Ma questo è molto simile al codice di esempio su cppreference:
#include <iostream>
#include <locale>
#include <string>
int main()
{
std::wcout << "User-preferred locale setting is " << std::locale("").name().c_str() << '\n';
// on startup, the global locale is the "C" locale
std::wcout << 1000.01 << '\n';
// replace the C++ global locale as well as the C locale with the user-preferred locale
std::locale::global(std::locale(""));
// use the new global locale for future wide character output
std::wcout.imbue(std::locale());
// output the same number again
std::wcout << 1000.01 << '\n';
}
In realtà quel codice crashes Coliru anche ...: facepalm:
Morecrashes di codice simile da Coliru.
Si tratta di un bug nella libreria C++ utilizzato da clang, oppure questo codice è difettoso?
Nota anche: questi incidenti sembrano essere limitato alle API C++, se si utilizza <clocale>
invece le cose sembrano funzionare bene, quindi potrebbe essere solo qualche problema banale nei binding C++ oltre questo?
Variazioni utilizzando setlocale
: 123
Sembra ovviamente un bug per me. Hai preso in considerazione la possibilità di chiedere la mailing list clang e/o segnalarla come un bug? Sembra un posto più appropriato da chiedere ... –
Se clang, il compilatore, si blocca compilando questo codice, allora questo è un bug clang e dovrebbe essere segnalato. –
@LightnessRacesinOrbit: Sì, immagino che questo sia il passo successivo –