Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
d6fde63a
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看板
提交
d6fde63a
编写于
10月 11, 2013
作者:
A
alanb
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8019526: (fs) Files.lines, etc without Charset parameter
Reviewed-by: psandoz, henryjen
上级
84621ebc
变更
3
展开全部
显示空白变更内容
内联
并排
Showing
3 changed file
with
503 addition
and
260 deletion
+503
-260
src/share/classes/java/nio/file/Files.java
src/share/classes/java/nio/file/Files.java
+179
-17
test/java/nio/file/Files/BytesAndLines.java
test/java/nio/file/Files/BytesAndLines.java
+270
-214
test/java/nio/file/Files/StreamTest.java
test/java/nio/file/Files/StreamTest.java
+54
-29
未找到文件。
src/share/classes/java/nio/file/Files.java
浏览文件 @
d6fde63a
...
@@ -43,9 +43,10 @@ import java.nio.channels.SeekableByteChannel;
...
@@ -43,9 +43,10 @@ import java.nio.channels.SeekableByteChannel;
import
java.nio.charset.Charset
;
import
java.nio.charset.Charset
;
import
java.nio.charset.CharsetDecoder
;
import
java.nio.charset.CharsetDecoder
;
import
java.nio.charset.CharsetEncoder
;
import
java.nio.charset.CharsetEncoder
;
import
java.nio.charset.StandardCharsets
;
import
java.nio.file.attribute.BasicFileAttributeView
;
import
java.nio.file.attribute.BasicFileAttributeView
;
import
java.nio.file.attribute.BasicFileAttributes
;
import
java.nio.file.attribute.BasicFileAttributes
;
import
java.nio.file.attribute.DosFileAttributes
;
import
java.nio.file.attribute.DosFileAttributes
;
// javadoc
import
java.nio.file.attribute.FileAttribute
;
import
java.nio.file.attribute.FileAttribute
;
import
java.nio.file.attribute.FileAttributeView
;
import
java.nio.file.attribute.FileAttributeView
;
import
java.nio.file.attribute.FileOwnerAttributeView
;
import
java.nio.file.attribute.FileOwnerAttributeView
;
...
@@ -104,8 +105,7 @@ public final class Files {
...
@@ -104,8 +105,7 @@ public final class Files {
return
()
->
{
return
()
->
{
try
{
try
{
c
.
close
();
c
.
close
();
}
}
catch
(
IOException
e
)
{
catch
(
IOException
e
)
{
throw
new
UncheckedIOException
(
e
);
throw
new
UncheckedIOException
(
e
);
}
}
};
};
...
@@ -2782,6 +2782,37 @@ public final class Files {
...
@@ -2782,6 +2782,37 @@ public final class Files {
return
new
BufferedReader
(
reader
);
return
new
BufferedReader
(
reader
);
}
}
/**
* Opens a file for reading, returning a {@code BufferedReader} to read text
* from the file in an efficient manner. Bytes from the file are decoded into
* characters using the {@link StandardCharsets#UTF_8 UTF-8} {@link Charset
* charset}.
*
* <p> This method works as if invoking it were equivalent to evaluating the
* expression:
* <pre>{@code
* Files.newBufferedReader(path, StandardCharsets.UTF_8)
* }</pre>
*
* @param path
* the path to the file
*
* @return a new buffered reader, with default buffer size, to read text
* from the file
*
* @throws IOException
* if an I/O error occurs opening the file
* @throws SecurityException
* In the case of the default provider, and a security manager is
* installed, the {@link SecurityManager#checkRead(String) checkRead}
* method is invoked to check read access to the file.
*
* @since 1.8
*/
public
static
BufferedReader
newBufferedReader
(
Path
path
)
throws
IOException
{
return
newBufferedReader
(
path
,
StandardCharsets
.
UTF_8
);
}
/**
/**
* Opens or creates a file for writing, returning a {@code BufferedWriter}
* Opens or creates a file for writing, returning a {@code BufferedWriter}
* that may be used to write text to the file in an efficient manner.
* that may be used to write text to the file in an efficient manner.
...
@@ -2827,6 +2858,41 @@ public final class Files {
...
@@ -2827,6 +2858,41 @@ public final class Files {
return
new
BufferedWriter
(
writer
);
return
new
BufferedWriter
(
writer
);
}
}
/**
* Opens or creates a file for writing, returning a {@code BufferedWriter}
* to write text to the file in an efficient manner. The text is encoded
* into bytes for writing using the {@link StandardCharsets#UTF_8 UTF-8}
* {@link Charset charset}.
*
* <p> This method works as if invoking it were equivalent to evaluating the
* expression:
* <pre>{@code
* Files.newBufferedWriter(path, StandardCharsets.UTF_8, options)
* }</pre>
*
* @param path
* the path to the file
* @param options
* options specifying how the file is opened
*
* @return a new buffered writer, with default buffer size, to write text
* to the file
*
* @throws IOException
* if an I/O error occurs opening or creating the file
* @throws UnsupportedOperationException
* if an unsupported option is specified
* @throws SecurityException
* In the case of the default provider, and a security manager is
* installed, the {@link SecurityManager#checkWrite(String) checkWrite}
* method is invoked to check write access to the file.
*
* @since 1.8
*/
public
static
BufferedWriter
newBufferedWriter
(
Path
path
,
OpenOption
...
options
)
throws
IOException
{
return
newBufferedWriter
(
path
,
StandardCharsets
.
UTF_8
,
options
);
}
/**
/**
* Reads all bytes from an input stream and writes them to an output stream.
* Reads all bytes from an input stream and writes them to an output stream.
*/
*/
...
@@ -3025,9 +3091,7 @@ public final class Files {
...
@@ -3025,9 +3091,7 @@ public final class Files {
* @throws OutOfMemoryError
* @throws OutOfMemoryError
* if an array of the required size cannot be allocated
* if an array of the required size cannot be allocated
*/
*/
private
static
byte
[]
read
(
InputStream
source
,
int
initialSize
)
private
static
byte
[]
read
(
InputStream
source
,
int
initialSize
)
throws
IOException
{
throws
IOException
{
int
capacity
=
initialSize
;
int
capacity
=
initialSize
;
byte
[]
buf
=
new
byte
[
capacity
];
byte
[]
buf
=
new
byte
[
capacity
];
int
nread
=
0
;
int
nread
=
0
;
...
@@ -3131,9 +3195,7 @@ public final class Files {
...
@@ -3131,9 +3195,7 @@ public final class Files {
*
*
* @see #newBufferedReader
* @see #newBufferedReader
*/
*/
public
static
List
<
String
>
readAllLines
(
Path
path
,
Charset
cs
)
public
static
List
<
String
>
readAllLines
(
Path
path
,
Charset
cs
)
throws
IOException
{
throws
IOException
{
try
(
BufferedReader
reader
=
newBufferedReader
(
path
,
cs
))
{
try
(
BufferedReader
reader
=
newBufferedReader
(
path
,
cs
))
{
List
<
String
>
result
=
new
ArrayList
<>();
List
<
String
>
result
=
new
ArrayList
<>();
for
(;;)
{
for
(;;)
{
...
@@ -3146,6 +3208,37 @@ public final class Files {
...
@@ -3146,6 +3208,37 @@ public final class Files {
}
}
}
}
/**
* Read all lines from a file. Bytes from the file are decoded into characters
* using the {@link StandardCharsets#UTF_8 UTF-8} {@link Charset charset}.
*
* <p> This method works as if invoking it were equivalent to evaluating the
* expression:
* <pre>{@code
* Files.readAllLines(path, StandardCharsets.UTF_8)
* }</pre>
*
* @param path
* the path to the file
*
* @return the lines from the file as a {@code List}; whether the {@code
* List} is modifiable or not is implementation dependent and
* therefore not specified
*
* @throws IOException
* if an I/O error occurs reading from the file or a malformed or
* unmappable byte sequence is read
* @throws SecurityException
* In the case of the default provider, and a security manager is
* installed, the {@link SecurityManager#checkRead(String) checkRead}
* method is invoked to check read access to the file.
*
* @since 1.8
*/
public
static
List
<
String
>
readAllLines
(
Path
path
)
throws
IOException
{
return
readAllLines
(
path
,
StandardCharsets
.
UTF_8
);
}
/**
/**
* Writes bytes to a file. The {@code options} parameter specifies how the
* Writes bytes to a file. The {@code options} parameter specifies how the
* the file is created or opened. If no options are present then this method
* the file is created or opened. If no options are present then this method
...
@@ -3262,6 +3355,45 @@ public final class Files {
...
@@ -3262,6 +3355,45 @@ public final class Files {
return
path
;
return
path
;
}
}
/**
* Write lines of text to a file. Characters are encoded into bytes using
* the {@link StandardCharsets#UTF_8 UTF-8} {@link Charset charset}.
*
* <p> This method works as if invoking it were equivalent to evaluating the
* expression:
* <pre>{@code
* Files.write(path, lines, StandardCharsets.UTF_8, options);
* }</pre>
*
* @param path
* the path to the file
* @param lines
* an object to iterate over the char sequences
* @param options
* options specifying how the file is opened
*
* @return the path
*
* @throws IOException
* if an I/O error occurs writing to or creating the file, or the
* text cannot be encoded as {@code UTF-8}
* @throws UnsupportedOperationException
* if an unsupported option is specified
* @throws SecurityException
* In the case of the default provider, and a security manager is
* installed, the {@link SecurityManager#checkWrite(String) checkWrite}
* method is invoked to check write access to the file.
*
* @since 1.8
*/
public
static
Path
write
(
Path
path
,
Iterable
<?
extends
CharSequence
>
lines
,
OpenOption
...
options
)
throws
IOException
{
return
write
(
path
,
lines
,
StandardCharsets
.
UTF_8
,
options
);
}
// -- Stream APIs --
// -- Stream APIs --
/**
/**
...
@@ -3431,9 +3563,11 @@ public final class Files {
...
@@ -3431,9 +3563,11 @@ public final class Files {
* if an I/O error is thrown when accessing the starting file.
* if an I/O error is thrown when accessing the starting file.
* @since 1.8
* @since 1.8
*/
*/
public
static
Stream
<
Path
>
walk
(
Path
start
,
int
maxDepth
,
public
static
Stream
<
Path
>
walk
(
Path
start
,
int
maxDepth
,
FileVisitOption
...
options
)
FileVisitOption
...
options
)
throws
IOException
{
throws
IOException
{
FileTreeIterator
iterator
=
new
FileTreeIterator
(
start
,
maxDepth
,
options
);
FileTreeIterator
iterator
=
new
FileTreeIterator
(
start
,
maxDepth
,
options
);
try
{
try
{
return
StreamSupport
.
stream
(
Spliterators
.
spliteratorUnknownSize
(
iterator
,
Spliterator
.
DISTINCT
),
false
)
return
StreamSupport
.
stream
(
Spliterators
.
spliteratorUnknownSize
(
iterator
,
Spliterator
.
DISTINCT
),
false
)
...
@@ -3484,9 +3618,7 @@ public final class Files {
...
@@ -3484,9 +3618,7 @@ public final class Files {
* @see #walk(Path, int, FileVisitOption...)
* @see #walk(Path, int, FileVisitOption...)
* @since 1.8
* @since 1.8
*/
*/
public
static
Stream
<
Path
>
walk
(
Path
start
,
public
static
Stream
<
Path
>
walk
(
Path
start
,
FileVisitOption
...
options
)
throws
IOException
{
FileVisitOption
...
options
)
throws
IOException
{
return
walk
(
start
,
Integer
.
MAX_VALUE
,
options
);
return
walk
(
start
,
Integer
.
MAX_VALUE
,
options
);
}
}
...
@@ -3547,7 +3679,8 @@ public final class Files {
...
@@ -3547,7 +3679,8 @@ public final class Files {
int
maxDepth
,
int
maxDepth
,
BiPredicate
<
Path
,
BasicFileAttributes
>
matcher
,
BiPredicate
<
Path
,
BasicFileAttributes
>
matcher
,
FileVisitOption
...
options
)
FileVisitOption
...
options
)
throws
IOException
{
throws
IOException
{
FileTreeIterator
iterator
=
new
FileTreeIterator
(
start
,
maxDepth
,
options
);
FileTreeIterator
iterator
=
new
FileTreeIterator
(
start
,
maxDepth
,
options
);
try
{
try
{
return
StreamSupport
.
stream
(
Spliterators
.
spliteratorUnknownSize
(
iterator
,
Spliterator
.
DISTINCT
),
false
)
return
StreamSupport
.
stream
(
Spliterators
.
spliteratorUnknownSize
(
iterator
,
Spliterator
.
DISTINCT
),
false
)
...
@@ -3619,4 +3752,33 @@ public final class Files {
...
@@ -3619,4 +3752,33 @@ public final class Files {
throw
e
;
throw
e
;
}
}
}
}
/**
* Read all lines from a file as a {@code Stream}. Bytes from the file are
* decoded into characters using the {@link StandardCharsets#UTF_8 UTF-8}
* {@link Charset charset}.
*
* <p> This method works as if invoking it were equivalent to evaluating the
* expression:
* <pre>{@code
* Files.lines(path, StandardCharsets.UTF_8)
* }</pre>
*
* @param path
* the path to the file
*
* @return the lines from the file as a {@code Stream}
*
* @throws IOException
* if an I/O error occurs opening the file
* @throws SecurityException
* In the case of the default provider, and a security manager is
* installed, the {@link SecurityManager#checkRead(String) checkRead}
* method is invoked to check read access to the file.
*
* @since 1.8
*/
public
static
Stream
<
String
>
lines
(
Path
path
)
throws
IOException
{
return
lines
(
path
,
StandardCharsets
.
UTF_8
);
}
}
}
test/java/nio/file/Files/BytesAndLines.java
浏览文件 @
d6fde63a
此差异已折叠。
点击以展开。
test/java/nio/file/Files/StreamTest.java
浏览文件 @
d6fde63a
...
@@ -22,11 +22,10 @@
...
@@ -22,11 +22,10 @@
*/
*/
/* @test
/* @test
* @bug 8006884
* @bug 8006884 8019526
* @summary Unit test for java.nio.file.Files
* @library ..
* @build PassThroughFileSystem FaultyFileSystem
* @build PassThroughFileSystem FaultyFileSystem
* @run testng StreamTest
* @run testng StreamTest
* @summary Unit test for java.nio.file.Files methods that return a Stream
*/
*/
import
java.io.IOException
;
import
java.io.IOException
;
...
@@ -43,11 +42,13 @@ import java.nio.file.Path;
...
@@ -43,11 +42,13 @@ import java.nio.file.Path;
import
java.nio.file.Paths
;
import
java.nio.file.Paths
;
import
java.nio.file.attribute.BasicFileAttributes
;
import
java.nio.file.attribute.BasicFileAttributes
;
import
java.util.Arrays
;
import
java.util.Arrays
;
import
java.util.Collections
;
import
java.util.Iterator
;
import
java.util.Iterator
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Objects
;
import
java.util.Objects
;
import
java.util.Set
;
import
java.util.Set
;
import
java.util.TreeSet
;
import
java.util.TreeSet
;
import
java.util.concurrent.Callable
;
import
java.util.function.BiPredicate
;
import
java.util.function.BiPredicate
;
import
java.util.stream.Stream
;
import
java.util.stream.Stream
;
import
java.util.stream.Collectors
;
import
java.util.stream.Collectors
;
...
@@ -316,53 +317,77 @@ public class StreamTest {
...
@@ -316,53 +317,77 @@ public class StreamTest {
try
{
try
{
// zero lines
// zero lines
assertTrue
(
Files
.
size
(
tmpfile
)
==
0
,
"File should be empty"
);
assertTrue
(
Files
.
size
(
tmpfile
)
==
0
,
"File should be empty"
);
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
))
{
checkLines
(
s
,
Collections
.
emptyList
());
}
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
assertEquals
(
s
.
mapToInt
(
l
->
1
).
reduce
(
0
,
Integer:
:
sum
),
0
,
"No line expected"
);
checkLines
(
s
,
Collections
.
emptyList
()
);
}
}
// one line
// one line
byte
[]
hi
=
{
(
byte
)
'h'
,
(
byte
)
'i'
};
List
<
String
>
oneLine
=
Arrays
.
asList
(
"hi"
);
Files
.
write
(
tmpfile
,
hi
);
Files
.
write
(
tmpfile
,
oneLine
,
US_ASCII
);
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
))
{
checkLines
(
s
,
oneLine
);
}
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
List
<
String
>
lines
=
s
.
collect
(
Collectors
.
toList
());
checkLines
(
s
,
oneLine
);
assertTrue
(
lines
.
size
()
==
1
,
"One line expected"
);
assertTrue
(
lines
.
get
(
0
).
equals
(
"hi"
),
"'Hi' expected"
);
}
}
// two lines using platform's line separator
// two lines using platform's line separator
List
<
String
>
expected
=
Arrays
.
asList
(
"hi"
,
"there"
);
List
<
String
>
twoLines
=
Arrays
.
asList
(
"hi"
,
"there"
);
Files
.
write
(
tmpfile
,
expected
,
US_ASCII
);
Files
.
write
(
tmpfile
,
twoLines
,
US_ASCII
);
assertTrue
(
Files
.
size
(
tmpfile
)
>
0
,
"File is empty"
);
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
))
{
checkLines
(
s
,
twoLines
);
}
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
List
<
String
>
lines
=
s
.
collect
(
Collectors
.
toList
());
checkLines
(
s
,
twoLines
);
assertTrue
(
lines
.
equals
(
expected
),
"Unexpected lines"
);
}
}
// MalformedInputException
// MalformedInputException
byte
[]
bad
=
{
(
byte
)
0xff
,
(
byte
)
0xff
};
byte
[]
bad
=
{
(
byte
)
0xff
,
(
byte
)
0xff
};
Files
.
write
(
tmpfile
,
bad
);
Files
.
write
(
tmpfile
,
bad
);
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
))
{
checkMalformedInputException
(
s
);
}
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
try
(
Stream
<
String
>
s
=
Files
.
lines
(
tmpfile
,
US_ASCII
))
{
checkMalformedInputException
(
s
);
}
// NullPointerException
checkNullPointerException
(()
->
Files
.
lines
(
null
));
checkNullPointerException
(()
->
Files
.
lines
(
null
,
US_ASCII
));
checkNullPointerException
(()
->
Files
.
lines
(
tmpfile
,
null
));
}
finally
{
Files
.
delete
(
tmpfile
);
}
}
private
void
checkLines
(
Stream
<
String
>
s
,
List
<
String
>
expected
)
{
List
<
String
>
lines
=
s
.
collect
(
Collectors
.
toList
());
assertTrue
(
lines
.
size
()
==
expected
.
size
(),
"Unexpected number of lines"
);
assertTrue
(
lines
.
equals
(
expected
),
"Unexpected content"
);
}
private
void
checkMalformedInputException
(
Stream
<
String
>
s
)
{
try
{
try
{
List
<
String
>
lines
=
s
.
collect
(
Collectors
.
toList
());
List
<
String
>
lines
=
s
.
collect
(
Collectors
.
toList
());
throw
new
RuntimeException
(
"UncheckedIOException expected"
);
fail
(
"UncheckedIOException expected"
);
}
catch
(
UncheckedIOException
ex
)
{
}
catch
(
UncheckedIOException
ex
)
{
assertTrue
(
ex
.
getCause
()
instanceof
MalformedInputException
,
IOException
cause
=
ex
.
getCause
();
assertTrue
(
cause
instanceof
MalformedInputException
,
"MalformedInputException expected"
);
"MalformedInputException expected"
);
}
}
}
}
// NullPointerException
private
void
checkNullPointerException
(
Callable
<?>
c
)
{
try
{
Files
.
lines
(
null
,
US_ASCII
);
throw
new
RuntimeException
(
"NullPointerException expected"
);
}
catch
(
NullPointerException
ignore
)
{
}
try
{
try
{
Files
.
lines
(
tmpfile
,
null
);
c
.
call
();
throw
new
RuntimeException
(
"NullPointerException expected"
);
fail
(
"NullPointerException expected"
);
}
catch
(
NullPointerException
ignore
)
{
}
}
catch
(
NullPointerException
ignore
)
{
}
catch
(
Exception
e
)
{
}
finally
{
fail
(
e
+
" not expected"
);
Files
.
delete
(
tmpfile
);
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录