Skip to content

Commit 8b70c43

Browse files
committedJan 18, 2023
8299772: The ColorModel.getRGBdefault() method is not thread-safe
Reviewed-by: prr
1 parent ba899b4 commit 8b70c43

File tree

2 files changed

+77
-10
lines changed

2 files changed

+77
-10
lines changed
 

‎src/java.desktop/share/classes/java/awt/image/ColorModel.java

+7-10
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 1995, 2022, Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 1995, 2023, Oracle and/or its affiliates. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* This code is free software; you can redistribute it and/or modify it
@@ -221,7 +221,6 @@ public Void run() {
221221
loadLibraries();
222222
initIDs();
223223
}
224-
private static ColorModel RGBdefault;
225224

226225
/**
227226
* Returns a {@code DirectColorModel} that describes the default
@@ -240,15 +239,13 @@ public Void run() {
240239
* RGB values.
241240
*/
242241
public static ColorModel getRGBdefault() {
243-
if (RGBdefault == null) {
244-
RGBdefault = new DirectColorModel(32,
245-
0x00ff0000, // Red
246-
0x0000ff00, // Green
247-
0x000000ff, // Blue
248-
0xff000000 // Alpha
249-
);
242+
interface RGBdefault {
243+
ColorModel INSTANCE = new DirectColorModel(32, 0x00ff0000, // Red
244+
0x0000ff00, // Green
245+
0x000000ff, // Blue
246+
0xff000000); // Alpha
250247
}
251-
return RGBdefault;
248+
return RGBdefault.INSTANCE;
252249
}
253250

254251
/**
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
/*
2+
* Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation.
8+
*
9+
* This code is distributed in the hope that it will be useful, but WITHOUT
10+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12+
* version 2 for more details (a copy is included in the LICENSE file that
13+
* accompanied this code).
14+
*
15+
* You should have received a copy of the GNU General Public License version
16+
* 2 along with this work; if not, write to the Free Software Foundation,
17+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18+
*
19+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20+
* or visit www.oracle.com if you need additional information or have any
21+
* questions.
22+
*/
23+
24+
import java.awt.image.ColorModel;
25+
import java.util.Collections;
26+
import java.util.IdentityHashMap;
27+
import java.util.Map;
28+
import java.util.concurrent.CountDownLatch;
29+
30+
/**
31+
* @test
32+
* @bug 8299772
33+
* @summary "ColorModel.getRGBdefault()" should always return the same object
34+
*/
35+
public final class RGBdefaultSingleton {
36+
37+
private static volatile boolean failed;
38+
private static final Map<ColorModel, ?> map =
39+
Collections.synchronizedMap(new IdentityHashMap<>(1));
40+
41+
public static void main(String[] args) throws Exception {
42+
Thread[] ts = new Thread[10];
43+
CountDownLatch latch = new CountDownLatch(ts.length);
44+
for (int i = 0; i < ts.length; i++) {
45+
ts[i] = new Thread(() -> {
46+
latch.countDown();
47+
try {
48+
ColorModel cm;
49+
latch.await();
50+
cm = ColorModel.getRGBdefault();
51+
map.put(cm, null);
52+
} catch (Throwable t) {
53+
t.printStackTrace();
54+
failed = true;
55+
}
56+
});
57+
}
58+
for (Thread t : ts) {
59+
t.start();
60+
}
61+
for (Thread t : ts) {
62+
t.join();
63+
}
64+
if (failed) {
65+
throw new RuntimeException("Unexpected exception");
66+
} else if (map.size() != 1) {
67+
throw new RuntimeException("The size of the map != 1");
68+
}
69+
}
70+
}

0 commit comments

Comments
 (0)
Please sign in to comment.