I know this is blasphemy in the Java world, but I'd probably use a preprocessor to transform some clean syntax into the normal Java code. I'd rather have the slight increase in build complexity over the potential issues with the extra classes and the breaking of assumption about how things compare and such.
I have always been extremely tempted to just throw together a quick and dirty preprocessor in maybe Awk for the few personal projects that I've used Java for. It would just make everything so much nicer.
> I'd probably use a preprocessor to transform some clean syntax into the normal Java code.
If I were in your place, I'd just learn enough Java to be proficient. Java is a very powerful language and certainly better suited for mundane tasks than your preprocessor.
I am no Java expert but they write that this syntax automatically creates a anonymous inner class - every time you create a collection instance in this way. Or am I wrong about this?
Most of the examples given are creating static objects but the last example a non-static object is created in the same way. Imagine you are doing this a couple of times then you end up with a lot of anonymous classes. Isn't there a limit on the number of classes you can have? At least it makes debugging problematic.
But I might be wrong about this since I am not a Java expert...
In Java, you have a gazzilion of classes. You have seriolusly many classes. And if you use Clojure or Scala or JRuby, you number of classes multiplies.
You just stuff a hundred of jars full of classes into your classpath and never look back.
JVM hums happily and does not care about however much classes you have. No problems with debugging either because why would it be? Anonymous classes are as introspective as non-anonymous.
In the majority of cases where you are deploying your java code on a server you own, having a few dozen or hundred extra classes is not a big deal. Each adds maybe a few kb to the size the jar, and as for loading costs, a class is only loaded into a running JVM once.
The cases in which to worry about stuff like this is if you need to load the code on someone else's machine, like with an applet or Android.
I consider this to be an antipattern, in part for some of the reasons listed in the article. The syntactic convenience being attempted here is more appropriately encapsulated as a utility method.
It can also make UI code much more readable, but it also comes with the cost of making the bytecode much larger (each use of the double-brace initialization creates a new class).
I had known of this before, and I'm fairly certain I've used it before. However, one thing I didn't consider is the equals issue commented on the site. As attractive as it may be to use, I think from now on I will refrain from using the double braces.
> I had known of this before, and I'm fairly certain I've used it before.
I consider myself pretty liberal when it comes to coding standards and being clever, but this is something that will badly piss me off. I can't quite put my finger on why I feel so, considering I am perfectly fine with most of the perl tricks. For example, https://gist.github.com/3392206 looks good to me(you are using Perl, you should know about list and scalar contexts).
[+] [-] tzs|13 years ago|reply
[+] [-] guard-of-terra|13 years ago|reply
[+] [-] syjer|13 years ago|reply
[+] [-] jlgreco|13 years ago|reply
[+] [-] ExpiredLink|13 years ago|reply
If I were in your place, I'd just learn enough Java to be proficient. Java is a very powerful language and certainly better suited for mundane tasks than your preprocessor.
[+] [-] philthom|13 years ago|reply
[+] [-] jrockway|13 years ago|reply
[+] [-] jfb|13 years ago|reply
[+] [-] irahul|13 years ago|reply
You don't have to do it even if you are writing Java. This is a perfect example of clever for the sake of being clever.
[+] [-] J446|13 years ago|reply
http://jcp.org/en/jsr/detail?id=337
Today Java lets you do the following:
List<String> myList = Arrays.asList("one", "two", "three");
Scala and Groovy which target the JVM let you do things like:
Scala: val myList = List("one", "two", "three")
Groovy: def myList = ["one", "two", "three"]
Then there's JRuby, Jython etc.
[+] [-] manojlds|13 years ago|reply
[+] [-] LinaLauneBaer|13 years ago|reply
Most of the examples given are creating static objects but the last example a non-static object is created in the same way. Imagine you are doing this a couple of times then you end up with a lot of anonymous classes. Isn't there a limit on the number of classes you can have? At least it makes debugging problematic.
But I might be wrong about this since I am not a Java expert...
[+] [-] guard-of-terra|13 years ago|reply
You just stuff a hundred of jars full of classes into your classpath and never look back.
JVM hums happily and does not care about however much classes you have. No problems with debugging either because why would it be? Anonymous classes are as introspective as non-anonymous.
[+] [-] brown9-2|13 years ago|reply
The cases in which to worry about stuff like this is if you need to load the code on someone else's machine, like with an applet or Android.
[+] [-] mindslight|13 years ago|reply
[+] [-] ansciath|13 years ago|reply
[+] [-] muyyatin|13 years ago|reply
[+] [-] chamakits|13 years ago|reply
[+] [-] irahul|13 years ago|reply
I consider myself pretty liberal when it comes to coding standards and being clever, but this is something that will badly piss me off. I can't quite put my finger on why I feel so, considering I am perfectly fine with most of the perl tricks. For example, https://gist.github.com/3392206 looks good to me(you are using Perl, you should know about list and scalar contexts).
[+] [-] J446|13 years ago|reply
http://jcp.org/en/jsr/detail?id=337