Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
d309677c
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看板
提交
d309677c
编写于
12月 01, 2010
作者:
M
mchung
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6402006: FileInputStream.available() returns negative values when reading a large file
Reviewed-by: alanb
上级
3459dfdc
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
113 addition
and
17 deletion
+113
-17
src/windows/native/java/io/io_util_md.c
src/windows/native/java/io/io_util_md.c
+12
-17
test/java/io/FileInputStream/LargeFileAvailable.java
test/java/io/FileInputStream/LargeFileAvailable.java
+101
-0
未找到文件。
src/windows/native/java/io/io_util_md.c
浏览文件 @
d309677c
...
...
@@ -300,7 +300,6 @@ handleStdinAvailable(jlong, long *);
int
handleAvailable
(
jlong
fd
,
jlong
*
pbytes
)
{
jlong
current
,
end
;
HANDLE
h
=
(
HANDLE
)
fd
;
DWORD
type
=
0
;
...
...
@@ -320,18 +319,17 @@ handleAvailable(jlong fd, jlong *pbytes) {
}
/* Handle is for regular file */
if
(
type
==
FILE_TYPE_DISK
)
{
long
highPos
=
0
;
DWORD
sizeLow
=
0
;
DWORD
sizeHigh
=
0
;
DWORD
lowPos
=
SetFilePointer
(
h
,
0
,
&
highPos
,
FILE_CURRENT
);
if
(
lowPos
==
((
DWORD
)
-
1
)
)
{
jlong
current
,
end
;
LARGE_INTEGER
filesize
;
current
=
handleLseek
(
fd
,
0
,
SEEK_CUR
);
if
(
current
<
0
)
{
return
FALSE
;
}
current
=
(((
jlong
)
highPos
)
<<
32
)
|
lowPos
;
end
=
GetFileSize
(
h
,
&
sizeHigh
);
if
(
sizeLow
==
((
DWORD
)
-
1
))
{
if
(
GetFileSizeEx
(
h
,
&
filesize
)
==
0
)
{
return
FALSE
;
}
end
=
long_to_jlong
(
filesize
.
QuadPart
);
*
pbytes
=
end
-
current
;
return
TRUE
;
}
...
...
@@ -569,6 +567,7 @@ handleClose(JNIEnv *env, jobject this, jfieldID fid)
jlong
handleLseek
(
jlong
fd
,
jlong
offset
,
jint
whence
)
{
LARGE_INTEGER
pos
,
distance
;
DWORD
lowPos
=
0
;
long
highPos
=
0
;
DWORD
op
=
FILE_CURRENT
;
...
...
@@ -584,13 +583,9 @@ handleLseek(jlong fd, jlong offset, jint whence)
op
=
FILE_BEGIN
;
}
lowPos
=
(
DWORD
)
offset
;
highPos
=
(
long
)(
offset
>>
32
);
lowPos
=
SetFilePointer
(
h
,
lowPos
,
&
highPos
,
op
);
if
(
lowPos
==
((
DWORD
)
-
1
))
{
if
(
GetLastError
()
!=
ERROR_SUCCESS
)
{
distance
.
QuadPart
=
offset
;
if
(
SetFilePointerEx
(
h
,
distance
,
&
pos
,
op
)
==
0
)
{
return
-
1
;
}
}
return
(((
jlong
)
highPos
)
<<
32
)
|
lowPos
;
return
long_to_jlong
(
pos
.
QuadPart
);
}
test/java/io/FileInputStream/LargeFileAvailable.java
0 → 100644
浏览文件 @
d309677c
/*
* Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 6402006
* @summary Test if available returns correct value when reading
* a large file.
*/
import
java.io.*
;
import
java.nio.ByteBuffer
;
import
java.nio.channels.*
;
import
static
java
.
nio
.
file
.
StandardOpenOption
.*;
public
class
LargeFileAvailable
{
private
static
final
long
FILESIZE
=
7405576182L
;
public
static
void
main
(
String
args
[])
throws
Exception
{
File
file
=
createLargeFile
(
FILESIZE
);
try
(
FileInputStream
fis
=
new
FileInputStream
(
file
))
{
if
(
file
.
length
()
!=
FILESIZE
)
{
throw
new
RuntimeException
(
"unexpected file size = "
+
file
.
length
());
}
long
bigSkip
=
3110608882L
;
long
remaining
=
FILESIZE
;
remaining
-=
skipBytes
(
fis
,
bigSkip
,
remaining
);
remaining
-=
skipBytes
(
fis
,
10L
,
remaining
);
remaining
-=
skipBytes
(
fis
,
bigSkip
,
remaining
);
if
(
fis
.
available
()
!=
(
int
)
remaining
)
{
throw
new
RuntimeException
(
"available() returns "
+
fis
.
available
()
+
" but expected "
+
remaining
);
}
}
finally
{
file
.
delete
();
}
}
// Skip toSkip number of bytes and expect that the available() method
// returns avail number of bytes.
private
static
long
skipBytes
(
InputStream
is
,
long
toSkip
,
long
avail
)
throws
IOException
{
long
skip
=
is
.
skip
(
toSkip
);
if
(
skip
!=
toSkip
)
{
throw
new
RuntimeException
(
"skip() returns "
+
skip
+
" but expected "
+
toSkip
);
}
long
remaining
=
avail
-
skip
;
int
expected
=
remaining
>=
Integer
.
MAX_VALUE
?
Integer
.
MAX_VALUE
:
(
int
)
remaining
;
System
.
out
.
println
(
"Skipped "
+
skip
+
" bytes "
+
" available() returns "
+
expected
+
" remaining="
+
remaining
);
if
(
is
.
available
()
!=
expected
)
{
throw
new
RuntimeException
(
"available() returns "
+
is
.
available
()
+
" but expected "
+
expected
);
}
return
skip
;
}
private
static
File
createLargeFile
(
long
filesize
)
throws
Exception
{
// Create a large file as a sparse file if possible
File
largefile
=
File
.
createTempFile
(
"largefile"
,
null
);
// re-create as a sparse file
largefile
.
toPath
().
delete
();
try
(
FileChannel
fc
=
FileChannel
.
open
(
largefile
.
toPath
(),
CREATE_NEW
,
WRITE
,
SPARSE
))
{
ByteBuffer
bb
=
ByteBuffer
.
allocate
(
1
).
put
((
byte
)
1
);
bb
.
rewind
();
int
rc
=
fc
.
write
(
bb
,
filesize
-
1
);
if
(
rc
!=
1
)
{
throw
new
RuntimeException
(
"Failed to write 1 byte to the large file"
);
}
}
return
largefile
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录