Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/vmTestbase/gc/gctests/JumbleGC/JumbleGC.java
41159 views
1
/*
2
* Copyright (c) 2002, 2020, Oracle and/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
/*
25
* @test
26
* @key stress randomness
27
*
28
* @summary converted from VM Testbase gc/gctests/JumbleGC.
29
* VM Testbase keywords: [gc, stress, stressopt, nonconcurrent]
30
* VM Testbase readme:
31
* A vector of 10 elements is filled up with references to
32
* CicrcularLinkedList and Binary Trees of 0.1 Meg. Once this
33
* entire structure has been built, all elements in the Vecor are set to null
34
* creating 1Meg of garbage. The Vector is repopulated once again.
35
* With ineffective garbage collection, the heap will soon fill up.
36
* If an OutofMemoryError is thrown, the test fails.
37
*
38
* @library /vmTestbase
39
* /test/lib
40
* @run main/othervm -XX:-UseGCOverheadLimit gc.gctests.JumbleGC.JumbleGC
41
*/
42
43
package gc.gctests.JumbleGC;
44
45
import nsk.share.test.*;
46
import nsk.share.gc.*;
47
import java.util.Vector;
48
49
public class JumbleGC extends TestBase {
50
public void run() {
51
int TreeSize = 1000;
52
int gc_count;
53
int randNum;
54
int num = 0;
55
56
Vector v = new Vector(10);
57
58
// Build a tree containing 100 treeNodes occupying about
59
// 1Meg of heap space.
60
61
gc_count = 0;
62
try {
63
for(int i = 0; i < 10 ; i++) {
64
if ( i % 2 == 0 )
65
v.addElement(buildCircularLinkedList());
66
else
67
v.addElement(buildTree());
68
}
69
70
while (gc_count < 10) {
71
72
for (int i = 0; i < 10 ; i++)
73
v.setElementAt(null, i);
74
75
for (int i = 0; i < 10 ; i++) {
76
if ( i % 2 == 0 )
77
v.setElementAt(buildCircularLinkedList(),i);
78
else
79
v.setElementAt(buildTree(),i);
80
}
81
gc_count ++;
82
log.info("Finished iteration # " + gc_count);
83
}
84
85
} catch (OutOfMemoryError e) {
86
log.error("Test Failed.");
87
setFailed(true);
88
}
89
log.info("Test Passed.");
90
}
91
92
public static void main(String args[]){
93
GC.runTest(new JumbleGC(), args);
94
}
95
96
// build a binary tree of 0.1 Meg.(100 treeNodes in the three, each of 100 bytes
97
98
private Tree buildTree() {
99
int i, randNum;
100
101
i = 0;
102
Tree newTree = new Tree(100);
103
while (i < 100) {
104
randNum = LocalRandom.nextInt(0, 1000000);
105
newTree.addElement(randNum);
106
i++;
107
}
108
return newTree;
109
}
110
111
// build a circular linked list of 0.1 Meg
112
private CircularLinkedList buildCircularLinkedList() {
113
CircularLinkedList cl;
114
cl = new CircularLinkedList(100);
115
for(int i = 0; i < 1000; i++)
116
cl.grow();
117
return cl;
118
}
119
}
120
121