-
Notifications
You must be signed in to change notification settings - Fork 289
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
DoubleToStringConverter::EcmaScriptConverter() not thread safe on Windows #3
Comments
how about making the variable const and the constructor constexpr(c++11 or above), it's straight-forward.
For old C++ standard, we can take advantage of POD struct initialization, but for doing so we'll have to break some of the existing code using this library or do some hackish work. in header file
in cc file Now we have 2 ways:
So no perfect solution on below c++11. But at least, we can use macros to give users have c++11 enabled a faster & better implementation. (no static initialization issue, no multi-thread issue, also we can mark EcmaScriptConverter() as inline to return the extern obj) |
We should try not to change the minimum supported C++ standard as it will reduce the compatibility for compiling this library on various platforms. For instance, compilers for N3DS or WiiU are stuck with old versions and they are not going to upgrade any time soon.
I totally agree with this.
For that particular solution you also need a converting constructor and it could work... but it's rather complex I have to admit. For this particular case, another solution would just remove If we're concerned about breaking public API then we can provide a singleton implementation. What do you guys think ? |
That's why I said
generally the c++11 solution seems perfect (needs some special handling of the ASSERT inside the constructor), and we can fall back to singleton/static implementation for old c++. |
👍 |
What, if we just added the flag, when the compiler supports it? I just added a conditional flag for CMake ( The following link has similar code for adding the c++0x flag: http://stackoverflow.com/questions/25451254/getting-cmake-check-cxx-compiler-flag-to-work I could try to find a similar pattern for scons, and we should hopefully be able to get something similar for bazel. @tfarina what do you think? |
@floitsch I would prefer to avoid introducing any hack in the C++ code if possible. If we can, then I can help to look at doing the changes for the Bazel build. |
From http://code.google.com/p/double-conversion/issues/detail?id=30 :
-- sean.parent
Code inspection at: double-conversion.cc:44
Function level statics are not initialized in a thread safe manner with Visual Studio 2012 or prior. With gcc and clang thread safe initialization is optional (though required by C++11).
Could be fixed with any number of once init mechanisms, or aggregate initialization.
-- floitsch
I don't see any easy way of solving this without pulling in thread-specific headers.
I would rather just require -std=c++0x which, afaik, guarantees correct initialization.
I will discuss this with my colleagues next week and see if somebody comes up with a better solution.
-- stephen.mercer
If you simply move the function static out of the function and make it static to the file then it will be thread safe initialized. Reference this answer:
http://stackoverflow.com/questions/1962880/is-c-static-member-variable-initialization-thread-safe
So to make it thread safe, simply replace this code (and similar if you have other function-level statics):
with this code:
-- rafaelefernandez
You definitely do not want to move it out of the function because then you will run into the static initialization order problem.
The text was updated successfully, but these errors were encountered: