-
Notifications
You must be signed in to change notification settings - Fork 76
/
Test.java
119 lines (98 loc) · 3.27 KB
/
Test.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
* To compile this program run [ javac Test.java ]on terminal (Please follow instruction in link to setup java for cli)
* Link : https://introcs.cs.princeton.edu/java/15inout/windows-cmd.html
* To run this program run [ java Test ]
*/
import java.util.*;
/**
* This program demonstrates object construction along with static methods.
* @version 1.01 12-08-2018
* @author Abhey Rana
*/
public class Test
{
public static void main(String[] args)
{
// Fill the staff array with three Employee objects
Employee[] staff = new Employee[3];
staff[0] = new Employee("Abhey Rana", 40000);
staff[1] = new Employee(60000);
staff[2] = new Employee();
// Print out information about all Employee objects
for (Employee e : staff)
System.out.println("name=" + e.getName() + ",id=" + e.getId() + ",salary="
+ e.getSalary());
// If above loop doesn't seem familar then google it. You will learn a new thing.
int n = Employee.getNextId(); // calls static method
System.out.println("Next available id=" + n);
}
}
/*
* Please note that in one Java file there can be only one public class.
* Also the name of class that is made public must match with the name of file.
* Here in our case Test is the public class used for testing purposes (Note name of file is Test.java)
* Also Employee is the class that is encaspulating the functionality of a Employee
*/
class Employee
{
private static int nextId = 0;
// Always remember make Instance variables (Object Variables) private and provide Accessor and Mutator Methods.
private int id;
private String name = ""; // Instance field initialization
private double salary;
// Three overloaded constructors
public Employee(String name, double salary)
{
this.name = name;
this.salary = salary;
this.id = nextId;
Employee.nextId ++;
}
public Employee(double salary)
{
// Calls the Employee(String, double) constructor
// Remember call to another constructor via this keyword should be made in the very first line.
this("Employee #" + nextId, salary);
}
// The default constructor
public Employee()
{
// name initialized to "" --see above
// salary not explicitly set--initialized to 0
this.id = nextId;
Employee.nextId ++;
}
// Accessor Methods (Or Getter Methods)
public String getName()
{
return this.name;
}
public double getSalary()
{
return this.salary;
}
public int getId()
{
return this.id;
}
// Mutator Methods (Or Setter Methods)
public void setName(String name){
this.name = name;
}
public void setSalary(double salary){
// Check to see if someone is not setting negative salary
if(salary > 0)
this.salary = salary;
}
// See not all insatnce members require Mutator Method, here we don't want to change ID so we don't have a mutator for it.
public static int getNextId()
{
return nextId; // returns static field
}
// Look each class can have it's own main method. (Here this one is for testing purposes)
public static void main(String[] args)
{
Employee e = new Employee("Harry", 50000);
System.out.println(e.getName() + " " + e.getSalary());
}
}