Java - What do constructor type arguments mean when placed *before* the type?How to round a number to n decimal places in JavaWhat is the difference between public, protected, package-private and private in Java?How do I call one constructor from another in Java?When to use LinkedList over ArrayList in Java?What does 'synchronized' mean?What is the Java equivalent for LINQ?What is a daemon thread in Java?Java: when to use static methodsWhat are the -Xms and -Xmx parameters when starting JVM?What does “Could not find or load main class” mean?

Multi tool use
Does having a TSA Pre-Check member in your flight reservation increase the chances that everyone gets Pre-Check?
Can the Supreme Court overturn an impeachment?
API Access HTML/Javascript
Proving a function is onto where f(x)=|x|.
Does the Mind Blank spell prevent the target from being frightened?
Could solar power be utilized and substitute coal in the 19th Century
Freedom of speech and where it applies
ArcGIS not connecting to PostgreSQL db with all upper-case name
Open a doc from terminal, but not by its name
MAXDOP Settings for SQL Server 2014
What is the grammatical term for “‑ed” words like these?
Greco-Roman egalitarianism
Find last 3 digits of this monster number
Is it improper etiquette to ask your opponent what his/her rating is before the game?
Wrapping Cryptocurrencies for interoperability sake
Longest common substring in linear time
Reply 'no position' while the job posting is still there
My friend sent me a screenshot of a transaction hash, but when I search for it I find divergent data. What happened?
THT: What is a squared annular “ring”?
Bob has never been a M before
Melting point of aspirin, contradicting sources
Is a model fitted to data or is data fitted to a model?
Confusion on Parallelogram
How should I respond when I lied about my education and the company finds out through background check?
Java - What do constructor type arguments mean when placed *before* the type?
How to round a number to n decimal places in JavaWhat is the difference between public, protected, package-private and private in Java?How do I call one constructor from another in Java?When to use LinkedList over ArrayList in Java?What does 'synchronized' mean?What is the Java equivalent for LINQ?What is a daemon thread in Java?Java: when to use static methodsWhat are the -Xms and -Xmx parameters when starting JVM?What does “Could not find or load main class” mean?
I've recently come across this unusual (to me) Java syntax...here's an example of it:
List list = new <String, Long>ArrayList();
Notice the positioning of the <String, Long>
type arguments...it's not after the type as normal but before. I don't mind admitting I've never seen this syntax before. Also note there are 2 type arguments when ArrayList only has 1.
Does the positioning of the type arguments have the same meaning as putting them after the type? If not, what does the different positioning mean?
Why is it legal to have 2 type arguments when ArrayList
only has 1?
I've searched the usual places, eg. Angelika Langer and on here but can't find any mention of this syntax anywhere apart from the grammar rules in the Java grammar file on the ANTLR project.
java grammar
add a comment |
I've recently come across this unusual (to me) Java syntax...here's an example of it:
List list = new <String, Long>ArrayList();
Notice the positioning of the <String, Long>
type arguments...it's not after the type as normal but before. I don't mind admitting I've never seen this syntax before. Also note there are 2 type arguments when ArrayList only has 1.
Does the positioning of the type arguments have the same meaning as putting them after the type? If not, what does the different positioning mean?
Why is it legal to have 2 type arguments when ArrayList
only has 1?
I've searched the usual places, eg. Angelika Langer and on here but can't find any mention of this syntax anywhere apart from the grammar rules in the Java grammar file on the ANTLR project.
java grammar
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
2
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so<String, Long>
is just ignored). See Generics Constructor.
– Ole V.V.
52 mins ago
1
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
1
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago
add a comment |
I've recently come across this unusual (to me) Java syntax...here's an example of it:
List list = new <String, Long>ArrayList();
Notice the positioning of the <String, Long>
type arguments...it's not after the type as normal but before. I don't mind admitting I've never seen this syntax before. Also note there are 2 type arguments when ArrayList only has 1.
Does the positioning of the type arguments have the same meaning as putting them after the type? If not, what does the different positioning mean?
Why is it legal to have 2 type arguments when ArrayList
only has 1?
I've searched the usual places, eg. Angelika Langer and on here but can't find any mention of this syntax anywhere apart from the grammar rules in the Java grammar file on the ANTLR project.
java grammar
I've recently come across this unusual (to me) Java syntax...here's an example of it:
List list = new <String, Long>ArrayList();
Notice the positioning of the <String, Long>
type arguments...it's not after the type as normal but before. I don't mind admitting I've never seen this syntax before. Also note there are 2 type arguments when ArrayList only has 1.
Does the positioning of the type arguments have the same meaning as putting them after the type? If not, what does the different positioning mean?
Why is it legal to have 2 type arguments when ArrayList
only has 1?
I've searched the usual places, eg. Angelika Langer and on here but can't find any mention of this syntax anywhere apart from the grammar rules in the Java grammar file on the ANTLR project.
java grammar
java grammar
asked 56 mins ago
Nathan AdamsNathan Adams
1638
1638
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
2
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so<String, Long>
is just ignored). See Generics Constructor.
– Ole V.V.
52 mins ago
1
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
1
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago
add a comment |
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
2
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so<String, Long>
is just ignored). See Generics Constructor.
– Ole V.V.
52 mins ago
1
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
1
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
2
2
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so
<String, Long>
is just ignored). See Generics Constructor.– Ole V.V.
52 mins ago
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so
<String, Long>
is just ignored). See Generics Constructor.– Ole V.V.
52 mins ago
1
1
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
1
1
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.
List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.
List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago
add a comment |
1 Answer
1
active
oldest
votes
This is unusual alright, but fully valid Java. A class may have a generic constructor, for example:
public class TypeWithGenericConstructor
public <T> TypeWithGenericConstructor(T arg)
// TODO Auto-generated constructor stub
I suppose that more often than not we don’t need to make the type argument explicit. For example:
new TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
Now T
is clearly LocalDate
. However there may be cases where Java cannot infer (deduce) the type argument. Then we supply it explicitly using the syntax from your question:
new <LocalDate>TypeWithGenericConstructor(null);
Of course we may also supply it even though it is not necessary if we think it helps readability or for whatever reason:
new <LocalDate>TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
In your question you seem to be calling the java.util.ArrayList
constructor. That constructor is not generic (only the ArrayList
class as a whole is, that’s something else). Why Java allows you to supply type arguments in the call when they are not used, I don’t know, but it does. My Eclipse gives me a warning:
Unused type arguments for the non generic constructor ArrayList() of
type ArrayList; it should not be parameterized with arguments
But it’s not an error, and the program runs fine (I additionally get warnings about missing type arguments for List
and ArrayList
, but that again is a different story).
Does the positioning of the type arguments have the same meaning as
putting them after the type? If not, what does the different
positioning mean?
No, it’s different. The usual type argument/s after the type (ArrayList<Integer>
) are for the generic class. The type arguments before are for the * constructor*.
The two forms may also be combined:
List<Integer> list = new <String, Long>ArrayList<Integer>();
I would consider this a bit more correct since we can now see that the list stores Integer
objects (I’d still prefer to leave out the meaningless <String, Long>
, of course).
Why is it legal to have 2 type arguments when ArrayList only has 1?
First, if you supply type arguments before the type, you should supply the correct number for the constructor, not for the class, so it hasn’t got anything to do with how many type arguments the ArrayList
class has got. That really means that in this case you shouldn’t supply any since the constructor doesn’t take type arguments (it’s not generic). When you supply some anyway, they are ignored, which is why it doesn’t matter how many or how few you supply (I repeat, I don’t know why Java allows you to supply them meaninglessly).
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55330697%2fjava-what-do-constructor-type-arguments-mean-when-placed-before-the-type%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
This is unusual alright, but fully valid Java. A class may have a generic constructor, for example:
public class TypeWithGenericConstructor
public <T> TypeWithGenericConstructor(T arg)
// TODO Auto-generated constructor stub
I suppose that more often than not we don’t need to make the type argument explicit. For example:
new TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
Now T
is clearly LocalDate
. However there may be cases where Java cannot infer (deduce) the type argument. Then we supply it explicitly using the syntax from your question:
new <LocalDate>TypeWithGenericConstructor(null);
Of course we may also supply it even though it is not necessary if we think it helps readability or for whatever reason:
new <LocalDate>TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
In your question you seem to be calling the java.util.ArrayList
constructor. That constructor is not generic (only the ArrayList
class as a whole is, that’s something else). Why Java allows you to supply type arguments in the call when they are not used, I don’t know, but it does. My Eclipse gives me a warning:
Unused type arguments for the non generic constructor ArrayList() of
type ArrayList; it should not be parameterized with arguments
But it’s not an error, and the program runs fine (I additionally get warnings about missing type arguments for List
and ArrayList
, but that again is a different story).
Does the positioning of the type arguments have the same meaning as
putting them after the type? If not, what does the different
positioning mean?
No, it’s different. The usual type argument/s after the type (ArrayList<Integer>
) are for the generic class. The type arguments before are for the * constructor*.
The two forms may also be combined:
List<Integer> list = new <String, Long>ArrayList<Integer>();
I would consider this a bit more correct since we can now see that the list stores Integer
objects (I’d still prefer to leave out the meaningless <String, Long>
, of course).
Why is it legal to have 2 type arguments when ArrayList only has 1?
First, if you supply type arguments before the type, you should supply the correct number for the constructor, not for the class, so it hasn’t got anything to do with how many type arguments the ArrayList
class has got. That really means that in this case you shouldn’t supply any since the constructor doesn’t take type arguments (it’s not generic). When you supply some anyway, they are ignored, which is why it doesn’t matter how many or how few you supply (I repeat, I don’t know why Java allows you to supply them meaninglessly).
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
add a comment |
This is unusual alright, but fully valid Java. A class may have a generic constructor, for example:
public class TypeWithGenericConstructor
public <T> TypeWithGenericConstructor(T arg)
// TODO Auto-generated constructor stub
I suppose that more often than not we don’t need to make the type argument explicit. For example:
new TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
Now T
is clearly LocalDate
. However there may be cases where Java cannot infer (deduce) the type argument. Then we supply it explicitly using the syntax from your question:
new <LocalDate>TypeWithGenericConstructor(null);
Of course we may also supply it even though it is not necessary if we think it helps readability or for whatever reason:
new <LocalDate>TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
In your question you seem to be calling the java.util.ArrayList
constructor. That constructor is not generic (only the ArrayList
class as a whole is, that’s something else). Why Java allows you to supply type arguments in the call when they are not used, I don’t know, but it does. My Eclipse gives me a warning:
Unused type arguments for the non generic constructor ArrayList() of
type ArrayList; it should not be parameterized with arguments
But it’s not an error, and the program runs fine (I additionally get warnings about missing type arguments for List
and ArrayList
, but that again is a different story).
Does the positioning of the type arguments have the same meaning as
putting them after the type? If not, what does the different
positioning mean?
No, it’s different. The usual type argument/s after the type (ArrayList<Integer>
) are for the generic class. The type arguments before are for the * constructor*.
The two forms may also be combined:
List<Integer> list = new <String, Long>ArrayList<Integer>();
I would consider this a bit more correct since we can now see that the list stores Integer
objects (I’d still prefer to leave out the meaningless <String, Long>
, of course).
Why is it legal to have 2 type arguments when ArrayList only has 1?
First, if you supply type arguments before the type, you should supply the correct number for the constructor, not for the class, so it hasn’t got anything to do with how many type arguments the ArrayList
class has got. That really means that in this case you shouldn’t supply any since the constructor doesn’t take type arguments (it’s not generic). When you supply some anyway, they are ignored, which is why it doesn’t matter how many or how few you supply (I repeat, I don’t know why Java allows you to supply them meaninglessly).
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
add a comment |
This is unusual alright, but fully valid Java. A class may have a generic constructor, for example:
public class TypeWithGenericConstructor
public <T> TypeWithGenericConstructor(T arg)
// TODO Auto-generated constructor stub
I suppose that more often than not we don’t need to make the type argument explicit. For example:
new TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
Now T
is clearly LocalDate
. However there may be cases where Java cannot infer (deduce) the type argument. Then we supply it explicitly using the syntax from your question:
new <LocalDate>TypeWithGenericConstructor(null);
Of course we may also supply it even though it is not necessary if we think it helps readability or for whatever reason:
new <LocalDate>TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
In your question you seem to be calling the java.util.ArrayList
constructor. That constructor is not generic (only the ArrayList
class as a whole is, that’s something else). Why Java allows you to supply type arguments in the call when they are not used, I don’t know, but it does. My Eclipse gives me a warning:
Unused type arguments for the non generic constructor ArrayList() of
type ArrayList; it should not be parameterized with arguments
But it’s not an error, and the program runs fine (I additionally get warnings about missing type arguments for List
and ArrayList
, but that again is a different story).
Does the positioning of the type arguments have the same meaning as
putting them after the type? If not, what does the different
positioning mean?
No, it’s different. The usual type argument/s after the type (ArrayList<Integer>
) are for the generic class. The type arguments before are for the * constructor*.
The two forms may also be combined:
List<Integer> list = new <String, Long>ArrayList<Integer>();
I would consider this a bit more correct since we can now see that the list stores Integer
objects (I’d still prefer to leave out the meaningless <String, Long>
, of course).
Why is it legal to have 2 type arguments when ArrayList only has 1?
First, if you supply type arguments before the type, you should supply the correct number for the constructor, not for the class, so it hasn’t got anything to do with how many type arguments the ArrayList
class has got. That really means that in this case you shouldn’t supply any since the constructor doesn’t take type arguments (it’s not generic). When you supply some anyway, they are ignored, which is why it doesn’t matter how many or how few you supply (I repeat, I don’t know why Java allows you to supply them meaninglessly).
This is unusual alright, but fully valid Java. A class may have a generic constructor, for example:
public class TypeWithGenericConstructor
public <T> TypeWithGenericConstructor(T arg)
// TODO Auto-generated constructor stub
I suppose that more often than not we don’t need to make the type argument explicit. For example:
new TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
Now T
is clearly LocalDate
. However there may be cases where Java cannot infer (deduce) the type argument. Then we supply it explicitly using the syntax from your question:
new <LocalDate>TypeWithGenericConstructor(null);
Of course we may also supply it even though it is not necessary if we think it helps readability or for whatever reason:
new <LocalDate>TypeWithGenericConstructor(LocalDate.now(ZoneId.systemDefault()));
In your question you seem to be calling the java.util.ArrayList
constructor. That constructor is not generic (only the ArrayList
class as a whole is, that’s something else). Why Java allows you to supply type arguments in the call when they are not used, I don’t know, but it does. My Eclipse gives me a warning:
Unused type arguments for the non generic constructor ArrayList() of
type ArrayList; it should not be parameterized with arguments
But it’s not an error, and the program runs fine (I additionally get warnings about missing type arguments for List
and ArrayList
, but that again is a different story).
Does the positioning of the type arguments have the same meaning as
putting them after the type? If not, what does the different
positioning mean?
No, it’s different. The usual type argument/s after the type (ArrayList<Integer>
) are for the generic class. The type arguments before are for the * constructor*.
The two forms may also be combined:
List<Integer> list = new <String, Long>ArrayList<Integer>();
I would consider this a bit more correct since we can now see that the list stores Integer
objects (I’d still prefer to leave out the meaningless <String, Long>
, of course).
Why is it legal to have 2 type arguments when ArrayList only has 1?
First, if you supply type arguments before the type, you should supply the correct number for the constructor, not for the class, so it hasn’t got anything to do with how many type arguments the ArrayList
class has got. That really means that in this case you shouldn’t supply any since the constructor doesn’t take type arguments (it’s not generic). When you supply some anyway, they are ignored, which is why it doesn’t matter how many or how few you supply (I repeat, I don’t know why Java allows you to supply them meaninglessly).
edited 13 mins ago
answered 37 mins ago


Ole V.V.Ole V.V.
31.2k63956
31.2k63956
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
add a comment |
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
But how it is allowing 2 arguments <String, Long>.The list will allow storing which type of data?
– jaspreet
21 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
Thanks for asking, @jaspreet. Please see my edit.
– Ole V.V.
10 mins ago
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55330697%2fjava-what-do-constructor-type-arguments-mean-when-placed-before-the-type%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
3RrUARq,MhS Y1bkE40Z77lUl7nII7,r5bCLFI3N6JzeGhH73wAen,2y54ohOwyij X0yP1gtm3M4OEC2 WRcTC,orrpEh bbqpGuT 7 3k
Yeah so do I, I'm not asking how to create a list lol
– Nathan Adams
52 mins ago
2
A constructor may have type arguments that are placed there (this particular constructor hasn’t, so
<String, Long>
is just ignored). See Generics Constructor.– Ole V.V.
52 mins ago
1
OK that makes sense, although it's weird that there's no compile error even though there's no type arguments on the constructor
– Nathan Adams
47 mins ago
1
No error, but you get a warning about raw types. Don't use raw types. Do use the diamond operator.
List<String> list = new ArrayList<>();
– Elliott Frisch
46 mins ago
@OleV.V. if you wanna put your comment and link as an answer I'll accept it
– Nathan Adams
45 mins ago