Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
1548b7f0
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看板
提交
1548b7f0
编写于
2月 27, 2013
作者:
M
mduigou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8008785: IdentityHashMap.values().toArray(V[]) broken by JDK-8008167
Reviewed-by: alanb
上级
776b8511
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
189 addition
and
2 deletion
+189
-2
src/share/classes/java/util/IdentityHashMap.java
src/share/classes/java/util/IdentityHashMap.java
+2
-2
test/java/util/Map/ToArray.java
test/java/util/Map/ToArray.java
+187
-0
未找到文件。
src/share/classes/java/util/IdentityHashMap.java
浏览文件 @
1548b7f0
...
...
@@ -1106,12 +1106,12 @@ public class IdentityHashMap<K,V>
Object
[]
tab
=
table
;
int
ti
=
0
;
for
(
int
si
=
0
;
si
<
tab
.
length
;
si
+=
2
)
{
if
(
tab
[
si
++
]
!=
null
)
{
// key present ?
if
(
tab
[
si
]
!=
null
)
{
// key present ?
// more elements than expected -> concurrent modification from other thread
if
(
ti
>=
size
)
{
throw
new
ConcurrentModificationException
();
}
a
[
ti
++]
=
(
T
)
tab
[
si
];
// copy value
a
[
ti
++]
=
(
T
)
tab
[
si
+
1
];
// copy value
}
}
// fewer elements than expected or concurrent modification from other thread detected
...
...
test/java/util/Map/ToArray.java
0 → 100644
浏览文件 @
1548b7f0
/*
* Copyright (c) 2013, 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 8008785
* @summary Ensure toArray() implementations return correct results.
* @author Mike Duigou
*/
import
java.util.*
;
import
java.util.concurrent.ConcurrentHashMap
;
import
java.util.concurrent.ConcurrentSkipListMap
;
public
class
ToArray
{
/**
* Number of elements per map.
*/
private
static
final
int
TEST_SIZE
=
5000
;
private
static
void
realMain
(
String
[]
args
)
throws
Throwable
{
Map
<
Integer
,
Long
>[]
maps
=
(
Map
<
Integer
,
Long
>[])
new
Map
[]{
new
HashMap
<>(),
new
Hashtable
<>(),
new
IdentityHashMap
<>(),
new
LinkedHashMap
<>(),
new
TreeMap
<>(),
new
WeakHashMap
<>(),
new
ConcurrentHashMap
<>(),
new
ConcurrentSkipListMap
<>()
};
// for each map type.
for
(
Map
<
Integer
,
Long
>
map
:
maps
)
{
try
{
testMap
(
map
);
}
catch
(
Exception
all
)
{
unexpected
(
"Failed for "
+
map
.
getClass
().
getName
(),
all
);
}
}
}
private
static
final
Integer
[]
KEYS
=
new
Integer
[
TEST_SIZE
];
private
static
final
Long
[]
VALUES
=
new
Long
[
TEST_SIZE
];
static
{
for
(
int
each
=
0
;
each
<
TEST_SIZE
;
each
++)
{
KEYS
[
each
]
=
Integer
.
valueOf
(
each
);
VALUES
[
each
]
=
Long
.
valueOf
(
each
+
TEST_SIZE
);
}
}
private
static
void
testMap
(
Map
<
Integer
,
Long
>
map
)
{
System
.
out
.
println
(
"Testing "
+
map
.
getClass
());
System
.
out
.
flush
();
// Fill the map
for
(
int
each
=
0
;
each
<
TEST_SIZE
;
each
++)
{
map
.
put
(
KEYS
[
each
],
VALUES
[
each
]);
}
// check the keys
Object
[]
keys
=
map
.
keySet
().
toArray
();
Arrays
.
sort
(
keys
);
for
(
int
each
=
0
;
each
<
TEST_SIZE
;
each
++)
{
check
(
"unexpected key"
,
keys
[
each
]
==
KEYS
[
each
]);
}
// check the values
Object
[]
values
=
map
.
values
().
toArray
();
Arrays
.
sort
(
values
);
for
(
int
each
=
0
;
each
<
TEST_SIZE
;
each
++)
{
check
(
"unexpected value"
,
values
[
each
]
==
VALUES
[
each
]);
}
// check the entries
Map
.
Entry
<
Integer
,
Long
>[]
entries
=
map
.
entrySet
().
toArray
(
new
Map
.
Entry
[
TEST_SIZE
]);
Arrays
.
sort
(
entries
,
new
Comparator
<
Map
.
Entry
<
Integer
,
Long
>>()
{
public
int
compare
(
Map
.
Entry
<
Integer
,
Long
>
o1
,
Map
.
Entry
<
Integer
,
Long
>
o2
)
{
return
o1
.
getKey
().
compareTo
(
o2
.
getKey
());
}});
for
(
int
each
=
0
;
each
<
TEST_SIZE
;
each
++)
{
check
(
"unexpected entry"
,
entries
[
each
].
getKey
()
==
KEYS
[
each
]
&&
entries
[
each
].
getValue
()
==
VALUES
[
each
]);
}
}
//--------------------- Infrastructure ---------------------------
static
volatile
int
passed
=
0
,
failed
=
0
;
static
void
pass
()
{
passed
++;
}
static
void
fail
()
{
failed
++;
(
new
Error
(
"Failure"
)).
printStackTrace
(
System
.
err
);
}
static
void
fail
(
String
msg
)
{
failed
++;
(
new
Error
(
"Failure: "
+
msg
)).
printStackTrace
(
System
.
err
);
}
static
void
abort
()
{
fail
();
System
.
exit
(
1
);
}
static
void
abort
(
String
msg
)
{
fail
(
msg
);
System
.
exit
(
1
);
}
static
void
unexpected
(
String
msg
,
Throwable
t
)
{
System
.
err
.
println
(
"Unexpected: "
+
msg
);
unexpected
(
t
);
}
static
void
unexpected
(
Throwable
t
)
{
failed
++;
t
.
printStackTrace
(
System
.
err
);
}
static
void
check
(
boolean
cond
)
{
if
(
cond
)
{
pass
();
}
else
{
fail
();
}
}
static
void
check
(
String
desc
,
boolean
cond
)
{
if
(
cond
)
{
pass
();
}
else
{
fail
(
desc
);
}
}
static
void
equal
(
Object
x
,
Object
y
)
{
if
(
Objects
.
equals
(
x
,
y
))
{
pass
();
}
else
{
fail
(
x
+
" not equal to "
+
y
);
}
}
public
static
void
main
(
String
[]
args
)
throws
Throwable
{
Thread
.
currentThread
().
setName
(
ToArray
.
class
.
getName
());
// Thread.currentThread().setPriority(Thread.MAX_PRIORITY);
try
{
realMain
(
args
);
}
catch
(
Throwable
t
)
{
unexpected
(
t
);
}
System
.
out
.
printf
(
"%nPassed = %d, failed = %d%n%n"
,
passed
,
failed
);
if
(
failed
>
0
)
{
throw
new
Error
(
"Some tests failed"
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录