Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
d8e4fcf3
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看板
提交
d8e4fcf3
编写于
4月 12, 2013
作者:
H
henryjen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8010279: java.util.Stream.min/max((Comparator)null) is not consistent in throwing (unspecified) NPE
Reviewed-by: alanb, mduigou
上级
090bbd05
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
68 addition
and
7 deletion
+68
-7
src/share/classes/java/util/Comparators.java
src/share/classes/java/util/Comparators.java
+2
-0
test/java/util/Comparators/BasicTest.java
test/java/util/Comparators/BasicTest.java
+66
-7
未找到文件。
src/share/classes/java/util/Comparators.java
浏览文件 @
d8e4fcf3
...
...
@@ -261,6 +261,7 @@ public class Comparators {
* according to the supplied {@code Comparator}
*/
public
static
<
T
>
BinaryOperator
<
T
>
lesserOf
(
Comparator
<?
super
T
>
comparator
)
{
Objects
.
requireNonNull
(
comparator
);
return
(
a
,
b
)
->
comparator
.
compare
(
a
,
b
)
<=
0
?
a
:
b
;
}
...
...
@@ -274,6 +275,7 @@ public class Comparators {
* according to the supplied {@code Comparator}
*/
public
static
<
T
>
BinaryOperator
<
T
>
greaterOf
(
Comparator
<?
super
T
>
comparator
)
{
Objects
.
requireNonNull
(
comparator
);
return
(
a
,
b
)
->
comparator
.
compare
(
a
,
b
)
>=
0
?
a
:
b
;
}
}
test/java/util/ComparatorsTest.java
→
test/java/util/Comparators
/Basic
Test.java
浏览文件 @
d8e4fcf3
...
...
@@ -23,8 +23,8 @@
/*
* @test
* @bug 8001667
* @run testng
Comparators
Test
* @bug 8001667
8010279
* @run testng
Basic
Test
*/
import
java.util.Comparator
;
...
...
@@ -33,6 +33,7 @@ import java.util.AbstractMap;
import
java.util.Map
;
import
org.testng.annotations.Test
;
import
java.util.function.BinaryOperator
;
import
java.util.function.Function
;
import
java.util.function.ToIntFunction
;
import
java.util.function.ToLongFunction
;
...
...
@@ -41,12 +42,13 @@ import java.util.function.ToDoubleFunction;
import
static
org
.
testng
.
Assert
.
assertEquals
;
import
static
org
.
testng
.
Assert
.
assertTrue
;
import
static
org
.
testng
.
Assert
.
assertSame
;
import
static
org
.
testng
.
Assert
.
fail
;
/**
* Unit tests for helper methods in Comparators
*/
@Test
(
groups
=
"unit"
)
public
class
Comparators
Test
{
public
class
Basic
Test
{
private
static
class
Thing
{
public
final
int
intField
;
public
final
long
longField
;
...
...
@@ -95,7 +97,7 @@ public class ComparatorsTest {
Thing
[]
things
=
new
Thing
[
intValues
.
length
];
for
(
int
i
=
0
;
i
<
intValues
.
length
;
i
++)
things
[
i
]
=
new
Thing
(
intValues
[
i
],
0L
,
0.0
,
null
);
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToIntFunction
<
Comparators
Test
.
Thing
>()
{
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToIntFunction
<
Basic
Test
.
Thing
>()
{
@Override
public
int
applyAsInt
(
Thing
thing
)
{
return
thing
.
getIntField
();
...
...
@@ -109,7 +111,7 @@ public class ComparatorsTest {
Thing
[]
things
=
new
Thing
[
longValues
.
length
];
for
(
int
i
=
0
;
i
<
longValues
.
length
;
i
++)
things
[
i
]
=
new
Thing
(
0
,
longValues
[
i
],
0.0
,
null
);
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToLongFunction
<
Comparators
Test
.
Thing
>()
{
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToLongFunction
<
Basic
Test
.
Thing
>()
{
@Override
public
long
applyAsLong
(
Thing
thing
)
{
return
thing
.
getLongField
();
...
...
@@ -123,7 +125,7 @@ public class ComparatorsTest {
Thing
[]
things
=
new
Thing
[
doubleValues
.
length
];
for
(
int
i
=
0
;
i
<
doubleValues
.
length
;
i
++)
things
[
i
]
=
new
Thing
(
0
,
0L
,
doubleValues
[
i
],
null
);
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToDoubleFunction
<
Comparators
Test
.
Thing
>()
{
Comparator
<
Thing
>
comp
=
Comparators
.
comparing
(
new
ToDoubleFunction
<
Basic
Test
.
Thing
>()
{
@Override
public
double
applyAsDouble
(
Thing
thing
)
{
return
thing
.
getDoubleField
();
...
...
@@ -350,4 +352,61 @@ public class ComparatorsTest {
.
apply
(
people
[
0
],
people
[
1
]),
people
[
1
]);
}
}
\ No newline at end of file
public
void
testNulls
()
{
try
{
Comparators
.<
String
>
naturalOrder
().
compare
(
"abc"
,
(
String
)
null
);
fail
(
"expected NPE with naturalOrder"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparators
.<
String
>
naturalOrder
().
compare
((
String
)
null
,
"abc"
);
fail
(
"expected NPE with naturalOrder"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparators
.<
String
>
reverseOrder
().
compare
(
"abc"
,
(
String
)
null
);
fail
(
"expected NPE with naturalOrder"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparators
.<
String
>
reverseOrder
().
compare
((
String
)
null
,
"abc"
);
fail
(
"expected NPE with naturalOrder"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
Map
.
Entry
<
String
,
String
>>
cmp
=
Comparators
.
byKey
(
null
);
fail
(
"byKey(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
Map
.
Entry
<
String
,
String
>>
cmp
=
Comparators
.
byValue
(
null
);
fail
(
"byValue(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
People
>
cmp
=
Comparators
.
comparing
((
Function
<
People
,
String
>)
null
);
fail
(
"comparing(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
People
>
cmp
=
Comparators
.
comparing
((
ToIntFunction
<
People
>)
null
);
fail
(
"comparing(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
People
>
cmp
=
Comparators
.
comparing
((
ToLongFunction
<
People
>)
null
);
fail
(
"comparing(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
Comparator
<
People
>
cmp
=
Comparators
.
comparing
((
ToDoubleFunction
<
People
>)
null
);
fail
(
"comparing(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
BinaryOperator
<
String
>
op
=
Comparators
.
lesserOf
(
null
);
fail
(
"lesserOf(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
try
{
BinaryOperator
<
String
>
op
=
Comparators
.
greaterOf
(
null
);
fail
(
"lesserOf(null) should throw NPE"
);
}
catch
(
NullPointerException
npe
)
{}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录