Thursday, March 5, 2015

Compilers, Errors, Classes, Objects, and Methods--Oh My!

Welcome back to basic programming in Java! Today we will be learning a TON of fundamental concepts vital to programming. If you don't want to read and learn...you might as well turn back now. That being said, let's hop in and get to it!

If you recall from the last post where we wrote HelloWorld, you might remember that all we had to do is click the "run" button in IDEA to run our code. However, there's a lot more going on behind the scenes that needs to be looked at to fully understand programming (I feel bad for neglecting this yesterday). When you click that run button, two things are happening: compiling and executing.

Compiling:
As you might have guessed, Java can't understand the lines of code you write. If you copied HelloWorld into the command prompt, nothing would happen. It doesn't 'mean' anything to the computer. So what does? In fact, there's some Java software called the Java Virtual Machine, JVM, that takes what you code and converts it into language the computer can understand. This important process is called compiling.

Code we write is stored in a file with the extension .java, which means we can edit it. However, as soon as you compile it, a new file is generated, a file ending in .class. If you try to read it, it looks like literal gibberish--but the computer understands it. So, why do we care?

Well, in fact, when you compile your program, it gets completely checked for any mistakes you made, these are called syntax errors. Think of them as spelling or grammatical mistakes in English writing. The Java compiler will make sure your program is 100% A-OK for running.

Once your program gets the thumbs up from the compiler, it gets turned into a .class file, which we'll just call a class file. It's important to note that since your .java file and your .class file are two separate files, you have to re-compile your code every time you want to run it. Lucky for you, though, IDEA compiles and executes in a single click. No worries!

Executing:

Once you have a class file, you can run it to your heart's content. Your class file won't change utnil you re-compile, which means your program will execute the exact same way every time until you change something. Moreover, since the compiler checked it, nothing *should* go wrong...however, things *do* go wrong, which brings us to:

Errors:

Oh no! Something has gone terribly awry! It sometimes happens that you, a fallible human, make a mistake. But fear not, the Java compiler is on your side! Any time an error happens, Java will (usually) tell you why, which means you know what to fix! Errors are easy to spot because they are big and annoying. Example:
Isn't the compiler nice? It tells us 1) that this is an error, 2) The line number and column number, and 3) what went wrong! In this case, I forgot to put a semicolon at the end of a statement:
So, easy fix, we just add our semicolon back, and we're good to go. The program compiles now. What we just did is called debugging or bugfixing, a vital step in software development. 

Tidbit: The phrase "debugging" comes from the era when computers were made using vacuum tubes. Occasionally a bug would fly into the tubes, and workers would literally have to de-bug the computer. 

It's worth noting that there are two main types of errors/bugs: compile-time errors, which happen during (you guessed it) compile time, and run-time errors, which happen when you execute the program. Doesn't make sense? Don't worry, we have a bit more to digest yet.

Classes:
When you compile a .java file, you get a class file, if you remember. Why is it called that? Well, and this is important, every file in Java is called a class. Every single line of code you write will be written in a class. Every single line, no exaggeration. Classes are important because, as we're about to discuss, you can make objects out of them!

Objects:
Look around your locale. What's the first thing you see? Ask yourself, "is that an object"? The answer is probably yes. Table = object. Floor = object. Air = object. It's the same way in Java. Every class you make has the capability to become an object, which means that you can have specific values that only that object has. Think about people. If Person was a Java class, that's great, but what if we have more than one person? We can't edit the code every time we have a new person. So we will make an object out of the person class. Now, we can have a Person object that refers to me, one that refers to you, and so on. Now each person can have their own describing values and traits. Don't worry if you can't wrap your head around this concept, it will make sense the more we discuss it. How exactly we make an object is for a post in the near future!

Methods (this is the last section, I promise):
So how exactly do we tell our program what to do? If you look back at our HelloWorld program, we basically have three lines of code that are interesting:
The first line is the start of our program. Every Java program starts with "public class AnyName", followed by curly braces to write your code in. So that leaves us with
So what are those? As it turns out, those are both what we call methods. Methods are how we tell Java what to do. Think of a method as an action that can be performed. You can turn on your computer repeatedly with a button--that's a method. You can eat food. That's a method. Any task you want to do in Java is a method. So how do we tell Java we have a method? Simple. You'll notice that the first line has four words in the first part: public, static, void, and main. Three out of these four are required in every method.

Public: This is the "scope" of the method. public methods can be 'used' (or in Javaspeak, called) from any other class, while private methods can only be called from within the class they're written in.

Static: The static keyword is optional at the start of a method. Static means that no matter how many objects we make out of this class, there will only be one instance of this method. For example, in our Person analogy, no matter how many People we have created, there will only be one main method. No more. Uno. No mas. Don't worry about static though, it's a bit more of an advanced topic.

Void: This is the return type of a method. This will make more sense when we learn about fundamental data types, but this basically tells the Java compiler what kind of output or return we can expect from this method. Is it going to give me a number? A word? That's what the return type tells you. In this case, void means that the method won't give the JVM anything in return.

main: This is just the name of your method. It can literally be anything, with a few exceptions. You can't use special characters like % or @, and you can't use certain reserved words like main, public, void, etc. Don't try to be a smartalec about it, and you'll be fine.

Finally, what's in those parentheses? In fact, those parentheses come after the name of your method, and they are vital--they tell Java what kind of information your method needs to run. If my method is "computeAverageGrade", I'll need what? I'll need several scores to average, right? Or, maybe if my method is called "watchPaintDry", I don't need any information--I just do it. Those parentheses contain what we call the parameters of the method. 

So let's put it all together! If you want to name a method, you write the scope, followed by static or not, (if not, just skip it), then the return type, (void for now), and then the name and parameters (nothing, for now). Let's make a sample method called eatPizza!


See how simple it is? We chose public by default, we skipped static because that's the default choice we should pick, we chose void again because it's default, and then we chose the name eatPizza, followed by empty parentheses because we don't want any information. 

That method at the start of HelloWorld is your main method, which needs to be in every program you write. It tells the compiler where your program starts. The main method is where your program begins, every time. 

Phew that was a lot! Sorry it took so long, but you've gotta understand these concepts before we can program. Hope you enjoyed even a little bit! Please feel free to comment or email me with any inaccuracies or questions. Thanks for reading!

~Nathan

Advanced, Completely Unnecessary Tidbit: You might have noticed that in our discussion of public static void main(String[] args), we left out the topic of String[] args. Those are actually just a parameter, like we discussed. Since the main method is the start of our program, there's no way for us to "call"  it within our program. Actually, the main method is called by the Java Virtual Machine, and that parameter means that the main method needs "an array of arguments" to run. Just like how eatFood would need a parameter of what food we're eating, the main method requires a list of "arguments" which are specific ways to execute our program. We can't control them, but it's interesting to know what that means.




No comments:

Post a Comment