Fatten or strip - the great Java debate

Sugary syntactical goodies

Java

QCon Fundamental divisions over whether Java should be fattened up or have bits ripped out to suit changing requirements have emerged at an industry show.

A panel of industry experts at Qcon in San Francisco agreed Java should be left to enter its middle years without major changes and the industry should look for a "new language, soon".

As we all know, though, the devil is in the details. In this case, making Java easier to learn and to use was everyone's favorite topic.

While some wanted to add more APIs, others took a "less is more" approach, while others still supported the idea of a modular "core" framework" or a "consumer" friendly edition of Java.

After nods of agreement that Java should be allowed to mature gracefully and not make a fool of itself in mid-life, Spring father and Interface 21 chief executive Rod Johnson lit the touchpaper by calling for "negative growth" in the number of Java APIs in the JDK - especially old or leased used APIs - that he said are "hurting the platform".

Johnson singled out AWT which, a straw poll of QCon audience members revealed, is being used by precisely no one.

"We really need to take some hard decision because the size of the JDK is getting problematic.... It's naive to think there isn't pain at present. To think successive versions of Java get bigger and bigger - people take pot shots at Java, but we are giving them a bigger target," Johnson said.

Google's chief Java architect Joshua Bloch rode in and found surprising common ground with the only Java outsider - Erik Meijer, creator of Microsoft's LINQ, who cautioned the Java community against removing things from a platform or language once they are "out there".

"There are whole packages I'd like to drop," Bloch agreed. "But there are banks and insurance companies that have invested tens of millions of dollars in this, and if you don't support this you will ensure they don't progress forward."

Sponsored: Network DDoS protection