原文:http://stevex.blog.51cto.com/4300375/1285767
1
2
3
4
5
6
7
|
public
void
sleep(
long
timeout)
throws
InterruptedException {
if
(timeout >
0
) {
long
ms = toMillis(timeout);
int
ns = excessNanos(timeout, ms);
Thread.sleep(ms, ns);
}
}
|
1
|
private
final
int
SLEEP_TIME =
3
*
1000
;
//3 seconds
|
1
2
3
4
5
6
|
TimeUnit.MILLISECONDS.sleep(
10
);
TimeUnit.SECONDS.sleep(
10
);
TimeUnit.MINUTES.sleep(
10
);
Thread.sleep(
10
);
Thread.sleep(
10
*
1000
);
Thread.sleep(
10
*
60
*
1000
);
|
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
|
import
java.util.concurrent.TimeUnit;
public
class
TestSleep {
public
static
void
main(String[] args)
throws
InterruptedException {
sleepByTimeunit(
10000
);
sleepByThread(
10000
);
}
private
static
void
sleepByTimeunit(
int
sleepTimes)
throws
InterruptedException {
long
start = System.currentTimeMillis();
for
(
int
i=
0
; i<sleepTimes; i++){
TimeUnit.MILLISECONDS.sleep(
10
);
}
long
end = System.currentTimeMillis();
System.out.println(
"Total time consumed by TimeUnit.MILLISECONDS.sleep : "
+ (end - start));
}
private
static
void
sleepByThread(
int
sleepTimes)
throws
InterruptedException {
long
start = System.currentTimeMillis();
for
(
int
i=
0
; i<sleepTimes; i++){
Thread.sleep(
10
);
}
long
end = System.currentTimeMillis();
System.out.println(
"Total time consumed by Thread.sleep : "
+ (end - start));
}
}
|
1
2
3
4
5
6
|
Total time consumed by TimeUnit.MILLISECONDS.sleep :
100068
Total time consumed by Thread.sleep :
100134
Difference : -- -
66
Total time consumed by TimeUnit.MILLISECONDS.sleep :
100222
Total time consumed by Thread.sleep :
100077
Difference : -- +
145
|