Skip to content

Commit 610174b

Browse files
BAEL-4494 | .toArray(new MyClass[0]) or .toArray(new MyClass[myList.size()])? (eugenp#10903)
* BAEL-4220 | A Guide to IllegalAccessError and when it happens * BAEL-4220 | A Guide to IllegalAccessError and when it happens | fix tests * BAEL-4220 | A Guide to IllegalAccessError and when it happens | fix tests * BAEL-4220 | A Guide to IllegalAccessError and when it happens | BDD test names * BAEL-4494 | .toArray(new MyClass[0]) or .toArray(new MyClass[myList.size()])? * BAEL-4494 | .toArray(new MyClass[0]) or .toArray(new MyClass[myList.size()])? Co-authored-by: root <[email protected]>
1 parent e5f0e89 commit 610174b

2 files changed

Lines changed: 97 additions & 25 deletions

File tree

Lines changed: 25 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -1,31 +1,31 @@
11
<?xml version="1.0" encoding="UTF-8"?>
22
<project xmlns="http://maven.apache.org/POM/4.0.0"
3-
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4-
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5-
<modelVersion>4.0.0</modelVersion>
6-
<artifactId>core-java-collections-4</artifactId>
7-
<version>0.1.0-SNAPSHOT</version>
8-
<name>core-java-collections-4</name>
9-
<packaging>jar</packaging>
10-
11-
<parent>
12-
<groupId>com.baeldung.core-java-modules</groupId>
13-
<artifactId>core-java-modules</artifactId>
14-
<version>0.0.1-SNAPSHOT</version>
15-
<relativePath>../pom.xml</relativePath>
16-
</parent>
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<modelVersion>4.0.0</modelVersion>
6+
<artifactId>core-java-collections-4</artifactId>
7+
<version>0.1.0-SNAPSHOT</version>
8+
<name>core-java-collections-4</name>
9+
<packaging>jar</packaging>
1710

18-
<dependencies>
19-
<dependency>
20-
<groupId>org.assertj</groupId>
21-
<artifactId>assertj-core</artifactId>
22-
<version>${assertj.version}</version>
23-
<scope>test</scope>
24-
</dependency>
25-
</dependencies>
11+
<parent>
12+
<groupId>com.baeldung.core-java-modules</groupId>
13+
<artifactId>core-java-modules</artifactId>
14+
<version>0.0.1-SNAPSHOT</version>
15+
<relativePath>../pom.xml</relativePath>
16+
</parent>
2617

27-
<properties>
28-
<assertj.version>3.19.0</assertj.version>
29-
</properties>
18+
<dependencies>
19+
<dependency>
20+
<groupId>org.assertj</groupId>
21+
<artifactId>assertj-core</artifactId>
22+
<version>${assertj.version}</version>
23+
<scope>test</scope>
24+
</dependency>
25+
</dependencies>
26+
27+
<properties>
28+
<assertj.version>3.19.0</assertj.version>
29+
</properties>
3030

3131
</project>
Lines changed: 72 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,72 @@
1+
package com.baeldung.collections.toarraycomparison;
2+
3+
import java.io.IOException;
4+
import java.util.ArrayList;
5+
import java.util.Collection;
6+
import java.util.TreeSet;
7+
import java.util.concurrent.TimeUnit;
8+
9+
import org.openjdk.jmh.annotations.Benchmark;
10+
import org.openjdk.jmh.annotations.BenchmarkMode;
11+
import org.openjdk.jmh.annotations.Fork;
12+
import org.openjdk.jmh.annotations.Measurement;
13+
import org.openjdk.jmh.annotations.Mode;
14+
import org.openjdk.jmh.annotations.OutputTimeUnit;
15+
import org.openjdk.jmh.annotations.Param;
16+
import org.openjdk.jmh.annotations.Scope;
17+
import org.openjdk.jmh.annotations.Setup;
18+
import org.openjdk.jmh.annotations.State;
19+
import org.openjdk.jmh.annotations.Warmup;
20+
21+
@Warmup(iterations = 5, time = 1, timeUnit = TimeUnit.SECONDS)
22+
@Measurement(iterations = 5, time = 1, timeUnit = TimeUnit.SECONDS)
23+
@Fork(value = 3, jvmArgsAppend = { "-XX:+UseParallelGC", "-Xms4g", "-Xmx4g" })
24+
@BenchmarkMode(Mode.AverageTime)
25+
@OutputTimeUnit(TimeUnit.NANOSECONDS)
26+
@State(Scope.Benchmark)
27+
public class ToArrayBenchmark {
28+
29+
@Param({ "10", "10000", "10000000" })
30+
private int size;
31+
32+
@Param({ "array-list", "tree-set" })
33+
private String type;
34+
35+
private Collection<String> collection;
36+
37+
@Setup
38+
public void setup() {
39+
switch (type) {
40+
case "array-list":
41+
collection = new ArrayList<String>();
42+
break;
43+
case "tree-set":
44+
collection = new TreeSet<String>();
45+
break;
46+
default:
47+
throw new UnsupportedOperationException();
48+
}
49+
for (int i = 0; i < size; i++) {
50+
collection.add(String.valueOf(i));
51+
}
52+
}
53+
54+
@Benchmark
55+
public String[] zero_sized() {
56+
return collection.toArray(new String[0]);
57+
}
58+
59+
@Benchmark
60+
public String[] pre_sized() {
61+
return collection.toArray(new String[collection.size()]);
62+
}
63+
64+
65+
public static void main(String[] args) {
66+
try {
67+
org.openjdk.jmh.Main.main(args);
68+
} catch (IOException e) {
69+
e.printStackTrace();
70+
}
71+
}
72+
}

0 commit comments

Comments
 (0)