Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Develop #2155

Open
wants to merge 19 commits into
base: master
Choose a base branch
from
Open

Develop #2155

Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions src/main/java/core/basesyntax/Bulldozer.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package core.basesyntax;

public class Bulldozer extends Machine {
public Bulldozer() {
}

@Override
public void doWork() {
System.out.println("Bulldozer is moving earth");
}

@Override
public void stopWork() {
System.out.println("Bulldozer has finished moving earth");
}
}
18 changes: 18 additions & 0 deletions src/main/java/core/basesyntax/Excavator.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package core.basesyntax;

public class Excavator extends Machine {
public Excavator() {
}

@Override
public void doWork() {
System.out.println("Excavator started its work.");
}

@Override
public void stopWork() {
System.out.println("Excavator stopped working.");

}

}
7 changes: 7 additions & 0 deletions src/main/java/core/basesyntax/Machine.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package core.basesyntax;

public abstract class Machine {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is how this class should look like:

public abstract class Machine {
    public abstract void doWork();

    public abstract void stopWork();
}

public abstract void doWork();

public abstract void stopWork();
}
14 changes: 14 additions & 0 deletions src/main/java/core/basesyntax/MainApp.java
Original file line number Diff line number Diff line change
@@ -1,5 +1,19 @@
package core.basesyntax;

public class MainApp {
public static void main(String[] args) {
Machine truck = new Truck();
Machine bulldozer = new Bulldozer();
Machine excavator = new Excavator();

Machine[] machines = {truck, bulldozer, excavator};
printTotal(machines);
}

private static void printTotal(Machine[] machines) {
for (Machine machine : machines) {
machine.doWork();
machine.stopWork();
}
}
}
17 changes: 17 additions & 0 deletions src/main/java/core/basesyntax/Truck.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package core.basesyntax;

public class Truck extends Machine {
public Truck() {
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove constructor and "name" field to be able to create instances without providing a name


@Override
public void doWork() {
System.out.println("Truck started its work.");
}

@Override
public void stopWork() {
System.out.println("Truck stopped working. ");

}
}
Loading