Lesson 1.0

Why the name Java?

Java was initially called Oak after an oak tree that stood outside James Gosling’s office; it went by the name Green later, and was later renamed Java, from Java coffee, said to be consumed in large quantities by the language’s creators. This also tells the story behind the logo of java. [https://www.quora.com /Why-is-Java-called-so]

First Steps

  1. Install Java JDK - It’s the full featured Software Development Kit for Java, including JRE, and the compilers and tools (like JavaDoc, and Java Debugger) to create and compile program .

  2. Visit https://docs.oracle.com/javase/8/docs/technotes/guides/install/install_overview.html to read about installation on your platform. Smasll examples may also be executed online on https://www.ideone.com

  3. Install Eclipse (Check how many of them have experience with eclipse) from: https://www.eclipse.org/downloads/eclipse-packages/

Eclipse is not necessary! It is a good IDE for JAVA. Other options are Netbeans https://netbeans.org/downloads/ or IntelliJIDEA https://www.jetbrains.com/idea/

Hello World

  1. Both javac and java must be available in the system.
java -version

should shows something like the following:

java version "1.8.0_05"
Java(TM) SE Runtime Environment (build 1.8.0_05-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.5-b02, mixed mode)


HelloWorld.java

public class HelloWorldApp
{

  public static char bar(int a, int b){
   return (char)(a+b);
  }
  // arguments are passed using the text field below this editor
  public static void main(String[] args)
  {
    String s="Hello Worl";

    System.out.println(s+bar(50,50));

  }
}

Hello World 2

Importance of commenting the code Especially when working in a team. Documentation will be evaluated.

Use java.util.Scanner to read input from stdin.

import java.io.Console;
import java.util.Scanner;

public class HelloWorld {

    //input reader
    final Scanner s = new Scanner(System.in);

    //read from stdin
    public void fancyCalculator(){
        System.out.println("JAVA first calulator");
        while(true){
            //operands
            int l,r;
            System.out.println("Type the 1 operand");
            l=s.nextInt();
            System.out.println("Type the 2 operand");
            r=s.nextInt();
            //output the sum of the two number
            final int ans = l+r;
            System.out.print("-> ");
            System.out.println(ans);
        }

    }

    public static void main(String[] args) {
        HelloWorld calculator = new HelloWorld();
        calculator.fancyCalculator();
    }
}

Bytecode - What’s under the hood?



alt text

CA FE BA BE 00 00 00 34 00 1D 0A 00 06 00 0F 09 00 10 00 11 08
00 12 0A 00 13 00 14 07 00 15 07 00 16 01 00 06 3C 69 6E 69 74
3E 01 00 03 28 29 56 01 00 04 43 6F 64 65 01 00 0F 4C 69 6E 65
4E 75 6D 62 65 72 54 61 62 6C 65 01 00 04 6D 61 69 6E 01 00 16
28 5B 4C 6A 61 76 61 2F 6C 61 6E 67 2F 53 74 72 69 6E 67 3B 29
56 01 00 0A 53 6F 75 72 63 65 46 69 6C 65 01 00 12 48 65 6C 6C
6F 57 6F 72 6C 64 41 70 70 2E 6A 61 76 61 0C 00 07 00 08 07 00
17 0C 00 18 00 19 01 00 0C 48 65 6C 6C 6F 20 57 6F 72 6C 64 21
07 00 1A 0C 00 1B 00 1C 01 00 0D 48 65 6C 6C 6F 57 6F 72 6C 64
41 70 70 01 00 10 6A 61 76 61 2F 6C 61 6E 67 2F 4F 62 6A 65 63
74 01 00 10 6A 61 76 61 2F 6C 61 6E 67 2F 53 79 73 74 65 6D 01
00 03 6F 75 74 01 00 15 4C 6A 61 76 61 2F 69 6F 2F 50 72 69 6E 
Compiled from "HelloWorldApp.java"
public class HelloWorldApp {
  public HelloWorldApp();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":()V
       4: return

  public static char bar(int, int);
    Code:
       0: iload_0
       1: iload_1
       2: iadd
       3: i2c
       4: ireturn

  public static void main(java.lang.String[]);
    Code:
       0: ldc           #2                  // String Hello Worl
       2: astore_1
       3: getstatic     #3                  // Field java/lang/System.out:Ljava/io/PrintStream;
       6: new           #4                  // class java/lang/StringBuilder
       9: dup
      10: invokespecial #5                  // Method java/lang/StringBuilder."<init>":()V
      13: aload_1
      14: invokevirtual #6                  // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
      17: bipush        50
      19: bipush        50
      21: invokestatic  #7                  // Method bar:(II)C
      24: invokevirtual #8                  // Method java/lang/StringBuilder.append:(C)Ljava/lang/StringBuilder;
      27: invokevirtual #9                  // Method java/lang/StringBuilder.toString:()Ljava/lang/String;
      30: invokevirtual #10                 // Method java/io/PrintStream.println:(Ljava/lang/String;)V
      33: return
}


Java Frame


Examples

Example - 1 - Basic Sorting

Allocate a vector of int of size N (read from stdin). Populate it using Random positive numbers in the interval [1..N].
Write two method for sorting arrays.

Bubble sort

import java.util.Random;

public class Example1{


    public static void initArrayRandomly(int[] array){
        Random r = new Random(System.currentTimeMillis());
        for (int i = 0; i < array.length; i++) 
            array[i] = r.nextInt(array.length*10);
    }

    public static void example1(){
        final int N = 100000;
        int[] array = new int[N];
        initArrayRandomly(array);
        //System.out.println(Arrays.toString(array));
        bubbleSort(array);
        //System.out.println(Arrays.toString(array));
    }
    public static  void bubbleSort(int[] numbers){
        boolean go = true;
        while(go){
            go=false;
            for(int i=0 ; i< numbers.length-1; i++){
                if(numbers[i] > numbers[i+1])
                {
                    int t=numbers[i];
                    numbers[i]=numbers[i+1];
                    numbers[i+1]=t;
                    go=true;
                }
            }
        }
    }


    public static void main(String[] args) {
        Example1.example1();
    }

}

It is important to get familiar with testing the code. Testing is important because it is a good way (not the only possible!) to ensure that code is correct (as soon as the tests are smart, i.e. test the invariants!)
Java does not provide standarts for test but there is a library which is now a standard called JUnit . Read how to use it in eclipse from here ( https://dzone.com/articles/junit-tutorial-beginners )

The following is an example of JUnit tests for the bubble sort method:

import static org.junit.Assert.*;

import org.junit.Test;


public class Example1_Tests {

    static final int SIZE = 10000; 
    @Test
    public void testBubbleSort(){
        int[] array = new int[SIZE];
        Example1.initArrayRandomly(array);
        Example1.bubbleSort(array);
        for(int i=0; i < array.length -1; i++){
             assertTrue(array[i] <= array[i+1]); //(<=) is the invariant enforced by sorting
        }
    }


}