Кажется, проблема в том, что на экран выводится не точное до одной миллисекунды время, постоянно 1000 миллсекунд. С чем это связано и как это исправить?
package com.javarush.task.task16.task1605;
import java.util.Date;
/*
Поговорим о музыке
*/
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();
}
@Override
public void run() {
Date d1 = startPlaying();
sleepNSeconds(1);
Date d2 = stopPlaying();
System.out.println("Playing " + (d2.getSeconds() - d1.getSeconds()) * 1000 + " ms");
}
}
}