this post was submitted on 06 Sep 2024
1375 points (99.6% liked)

Programmer Humor

32039 readers
1019 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 74 points 1 week ago (3 children)

Why is it that whenever something is spitting out junk data, those specific characters are involved?

[–] [email protected] 101 points 1 week ago

� is used to represent an invalid character, so it makes sense that it'd appear often when bad data is being rendered (or good data is being rendered improperly).

[–] [email protected] 68 points 1 week ago (1 children)

Everything is 0s and 1s to a computer. What a pattern of 0s and 1s encodes is decided by people--often arbitrarily. Over the years there have been attempts to standardize encodings but, for legacy reasons, older encodings are still valid.

The 0s and 1s that encode ' in UTF-8 (a standardized encoding) are the same 0s and 1s that encode ’ in CP-1252 (a legacy encoding).

The � symbol is shown when the 0s and 1s don't encode anything of meaning.

[–] [email protected] 55 points 1 week ago* (last edited 1 week ago) (1 children)

= e2 80 99 (3 bytes)
’ = e2 80 99 (3 separate bytes)

[–] [email protected] 14 points 1 week ago

Good to see it "spelt out" like that

[–] [email protected] 5 points 1 week ago

Right single quote (’) in UTF-8 (https://www.compart.com/en/unicode/U+2019) has the same bytes as ’ in cp1252 (which is more or less "ASCII" if we're doing ELI5). https://en.wikipedia.org/wiki/Windows-1252

Sometimes your keyboard or program's settings will use right single quote for apostrophes instead of a normal apostrophe. ' you might notice how this one is straight and not bent a certain way. This setting is often called smart quotes.