To keep it simple:
1. It’s not a series of 1 and 0 but a single value represented with 1 and 0. Look up counting in binary it’s too complicated to dig into and keep it ELI5.
2. Assign a number for each letter in the alphabet.
3. Use binary representation of the number assigned for the characters to make words.
Think of it as a number system, which is great. But it can be so much more.
To make it simple. Let’s say you want to write out text using only numbers. Let’s say 65 = a, 66=B, 67=C, 97=a, etc. I can write Wizywig as 87, 105, 122, 121, 119, 105, 103
That’s cool, but how can you convert 87105122121119105103 into something usable…? That’s where character encoding comes in. Let’s say every 3 numbers will be interpreted together. So all you gotta do is look at 3 numbers, and boom character. If the character is less than 3 numbers, hey lets add a 0 in front. So 087105122121119105103 boom easy peasy, you don’t need any commas.
Well… Decimal kinda sucks, but hey what if we only had a 1 and a 0 as the only numbers available. So like 0 = 0, 1 = 1, but how do we go above 1? Well just like you would go above 9, you move it to the next “place”. So 10 = 2 (1 in the “2”s place, and 0 in the “1”s place). ETC.
So it turns out the maximum number you can represent with a BIT is 1 (0 or 1), 2 bits = 3 (11), 3 bits = 7 (111), etc. So with 8 bits you can represent a total of 255 numbers. And that’s what we call ASCII. Eventually we went with more interesting formats, but that’s more complex. Buuuuuuut now I can encode Wizywig as binary, just gotta convert those numbers into binary:
W = 87 = 01010111
i = 105 = 01101001
etc.
So 0101011101101001 will be “Wi”
Yay we have a way to encode characters we type. We can add more things in here like numbers, letters, punctuation, even invisible characters like “new line” or even a space.
Wait, you may say… How does a computer actually use binary to run its programs? Same kind of idea. What if we read binary a bit differently… We start reading binary for an _instruction_ then the instruction dictates what is needed and will read more until it is satisfied, and then we figure out what to do next. And that’s how a processor reads info. Let’s say every 8 numbers is an instruction on the CPU, then following that would be whatever is appropriate for that instruction, then the next 8 is yet another one. So we keep consuming bits until we have what we need.
Well that seems pretty darn fragile. One bit off and the entire program becomes meaningless. YES EXACTLY!!!!!!!! That’s what we use compilers and validators for. And back in the days of punch cards, that’s exactly what happened. And in current days, a “buffer overflow attack” is exactly using this vulnerability to take over computers by writing our own instructions.
But assuming you made a _perfect_ set of instructions… well fantastic, the CPU can read one, and that can do things like saying “check register A against 0, if it is 0 jump to the instruction numbered <next 8 bits> otherwise continue to the next instruction that is starting 8 bits later. And there are a few hundred commands the cpu can do to move numbers around through its logical operators and through billions of these motions per second you get to read reddit.
The easiest way to visualize a computer program is… imagine you had 8 switches and a piece of paper. On each line it said a combination of switches to flip, which in turn caused other switches to flip in other parts of the machine that you don’t actually get to control, but eventually there’s a spot where you read the switches which tell you the next line in the paper to read. You read that line and it tells you what switches to flip, etc, etc, etc, etc. Now just imagine someone is sitting on the other side of your giant board. And on that side those switches are actually colored, so as you’re flipping switches colors are moving across the board on the other side. And that’s how you get “output” or images using a computer.
Computers are binary because it’s easier to design one this way. 0 represents ON (5 volts of electricity running through a wire) and 1 represents OFF (low-voltage or no voltage running through the wire). It’s more reliable than other possible ways of dealing with information.
We can create little “switches” that can do NOT operations, AND operations, OR (inclusive or) operations, XOR (exclusive or) operations, and some combinations of the previous ones:
NOT 1 = 0, NOT 0 = 1
1 AND 0 = 0, 1 AND 1 = 1
1 OR 0 = 0, 0 OR 0 = 0
1 XOR 0 = 1, 0 XOR 1 = 1, 1 XOR 1 = 0, 0 XOR 0 = 0
etc.
and thereby perform operations on data, primarily “ordinary” arithmetic, but theoretically, any set of instructions that can physically be carried out can be done using some combination of such simple operations. And a program is just a set of instructions.
I could go into more detail about how computers, but this stuff was two entire college courses (one on Boolean algebra, one on the architecture of a CPU)
A lot of answers here are missing the basics. Binary is base-2. We use base-10 when writing numbers. (0-9)
When you count past nine, you count up in the tens place and start over in the ones place. (09 goes to 10) this is the exact same as binary, except instead of going from 0 up to 9 in a place, you can only go from 0 up to 1.
Example:
00
01
10
Same as regular base ten just way less numbers before you need to carry to the left.
You can do all math exactly the same in binary as base10. Addition,subtraction,mult,div.
In base 10, adding a zero is the same as multiplying by 10. In base 3, adding a zero is the same as multiplying by 2.
Instead of tens, hundreds, thousands places, you have twos, fours, and eights places.
Why do we do this? Because it’s really easy to do digitally. Signal off is 0, signal on is 1.
You can use any value for a base-x system. You probably know how to count in base 5 and just didn’t realize it. Ever counted by drawing 4 lines down and the fifth diagonally across, then starting that pattern over? Some places in the world count on the finger segments (4 fingers, 3 segments each) which is base12.
Base 10: 0,1,2,3,4,5,6,7,8,9,10
Base 9: 0,1,2,3,4,5,6,7,8,10
Base 8: 0,1,2,3,4,5,6,7,10
Base 5: 0,1,2,3,4,10
Base 3: 0,1,2,10
Base 2: 0,1,10 (aka binary)
Base 1: 0,00,000 (chicken scratches)
Base 12: 0,1,2,3,4,5,6,7,8,9,A,B,10
Base 16: 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,10
Latest Answers