Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
be647eb3
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
be647eb3
编写于
11月 19, 2014
作者:
R
rriggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8064932: java/lang/ProcessBuilder/Basic.java: waitFor didn't take long enough
Reviewed-by: dholmes, martin
上级
b4e6ed16
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
25 addition
and
12 deletion
+25
-12
src/solaris/classes/java/lang/UNIXProcess.java
src/solaris/classes/java/lang/UNIXProcess.java
+11
-8
src/windows/classes/java/lang/ProcessImpl.java
src/windows/classes/java/lang/ProcessImpl.java
+14
-4
未找到文件。
src/solaris/classes/java/lang/UNIXProcess.java
浏览文件 @
be647eb3
...
...
@@ -405,14 +405,17 @@ final class UNIXProcess extends Process {
if
(
hasExited
)
return
true
;
if
(
timeout
<=
0
)
return
false
;
long
timeoutAsNanos
=
unit
.
toNanos
(
timeout
);
long
startTime
=
System
.
nanoTime
();
long
rem
=
timeoutAsNanos
;
while
(!
hasExited
&&
(
rem
>
0
))
{
wait
(
Math
.
max
(
TimeUnit
.
NANOSECONDS
.
toMillis
(
rem
),
1
));
rem
=
timeoutAsNanos
-
(
System
.
nanoTime
()
-
startTime
);
}
long
remainingNanos
=
unit
.
toNanos
(
timeout
);
long
deadline
=
System
.
nanoTime
()
+
remainingNanos
;
do
{
// Round up to next millisecond
wait
(
TimeUnit
.
NANOSECONDS
.
toMillis
(
remainingNanos
+
999_999L
));
if
(
hasExited
)
{
return
true
;
}
remainingNanos
=
deadline
-
System
.
nanoTime
();
}
while
(
remainingNanos
>
0
);
return
hasExited
;
}
...
...
src/windows/classes/java/lang/ProcessImpl.java
浏览文件 @
be647eb3
...
...
@@ -461,11 +461,21 @@ final class ProcessImpl extends Process {
if
(
getExitCodeProcess
(
handle
)
!=
STILL_ACTIVE
)
return
true
;
if
(
timeout
<=
0
)
return
false
;
long
msTimeout
=
unit
.
toMillis
(
timeout
);
long
remainingNanos
=
unit
.
toNanos
(
timeout
);
long
deadline
=
System
.
nanoTime
()
+
remainingNanos
;
do
{
// Round up to next millisecond
long
msTimeout
=
TimeUnit
.
NANOSECONDS
.
toMillis
(
remainingNanos
+
999_999L
);
waitForTimeoutInterruptibly
(
handle
,
msTimeout
);
if
(
Thread
.
interrupted
())
throw
new
InterruptedException
();
if
(
getExitCodeProcess
(
handle
)
!=
STILL_ACTIVE
)
{
return
true
;
}
remainingNanos
=
deadline
-
System
.
nanoTime
();
}
while
(
remainingNanos
>
0
);
waitForTimeoutInterruptibly
(
handle
,
msTimeout
);
if
(
Thread
.
interrupted
())
throw
new
InterruptedException
();
return
(
getExitCodeProcess
(
handle
)
!=
STILL_ACTIVE
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录