screenshot of a terminal displaying the numbers 64 (100 in hex) and 256 (0x100 in decimal) repeatedly
https://cdn.pony.social/media_attachments/files/114/134/073/333/013/689/original/c00df8fd94028327.png
Consider this code. One thread repeatedly prints the number 100 in decimal to std::cout. Another thread repeatedly prints the number 0x100 in hex (which will output as '100') to std::cout.
You might reasonably expect that the output will simply be '100' over and over and over.
Unfortunately, the calls to operator<< can get interleaved so you end up with crosstalk of the format specifiers:
GNU social JP is a social network, courtesy of GNU social JP管理人. It runs on GNU social, version 2.0.2-dev, available under the GNU Affero General Public License.
All GNU social JP content and data are available under the Creative Commons Attribution 3.0 license.