Hi,
My output is 1001 ms and 1002ms is the output from the example. I get this could be due to HW but it is correct :)
Funny though.
package com.codegym.task.task16.task1605;
import java.util.Date;
/*
Let's talk music
*/
public class Solution {
public static int delay = 1000;
public static void main(String[] args) {
Thread violin = new Thread(new Violin("Player"));
violin.start();
}
public static void sleepNSeconds(int n) {
try {
Thread.sleep(n * delay);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public interface MusicalInstrument extends Runnable {
Date startPlaying();
Date stopPlaying();
}
public static class Violin implements MusicalInstrument {
private String owner;
public Violin(String owner) {
this.owner = owner;
}
public Date startPlaying() {
//System.out.println(this.owner + " is starting to play");
return new Date();
}
public Date stopPlaying() {
//System.out.println(this.owner + " is stopping playing");
return new Date();
}
public void run(){
startPlaying();
long startOfPlayingTime = System.currentTimeMillis();
sleepNSeconds(1);
stopPlaying();
long endOfPlayingTime = System.currentTimeMillis();
long playedTime = endOfPlayingTime - startOfPlayingTime;
System.out.println("Played for " + playedTime + " ms");
}
}
}