Hi Harold,<br><br>Thanks for the perspective. I think these would all be good points to touch on during a Java talk. Brian, go for it!<br><br>As a side-note, I'm working on a couple of minor projects in Scala right now -- I'm really amazed at the expressiveness and flexibility of the language. To your list of boilerplate reducing Scala equivalents, I'd add: pattern matching, class instantiation, "for" comprehensions, infix class methods, implicits, parameterized types, type annotations, and higher level classes in the scalaz library that are mostly derived from category theory (functors, monads, the slightly less formal composable enumerators/iteratees, etc.). Incidentally, that's not a random list of features I read, but the things that have excited me the most in the projects I'm working on.<br>
<br>Best,<br>Eric<br><br><br><br><div class="gmail_quote">On Wed, Feb 22, 2012 at 11:21 AM, Harold Lee <span dir="ltr"><<a href="mailto:harold@hotelling.net">harold@hotelling.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
No language is perfect, but I thought I'd chime in with some points in<br>
Java's favor.<br>
<br>
Even at big companies, Java often isn't done in that "enterprise" way.<br>
I don't like what I've seen of EJBs, and fortunately I've never had to<br>
use them (even at IBM).<br>
<br>
As far as cheap hosting, Google App Engine is one place to look. For<br>
low traffic sites (e.g. pre-launch) it's free. And you can use your<br>
domain name or theirs. And Amazon AWS offers the 1st year free (their<br>
Free Tier: <a href="http://aws.amazon.com/ec2/pricing/" target="_blank">http://aws.amazon.com/ec2/pricing/</a>).<br>
<br>
Servlet containers can take a while to start up and deploy your app,<br>
use some memory, etc. but they're getting ready to handle a lot of<br>
concurrent traffic. And there are other web frameworks / APIs built on<br>
the Servlet API that feel more modern, like Play<br>
(<a href="http://www.playframework.org/" target="_blank">http://www.playframework.org/</a>).<br>
<br>
Scala makes Java much less verbose while compiling to Java class files<br>
/ byte code. Many variable types and return types will be inferred by<br>
the compiler providing compile-time type checking without the typing.<br>
<br>
What might be<br>
<br>
Clock clock = new Clock();<br>
System.out.println("Some text");<br>
<br>
becomes<br>
<br>
val clock = new Clock()<br>
println("Some text")<br>
<br>
and you can fit a main class (object in Scala declares a singleton) into 1 line:<br>
<br>
object App { def main(args: Array[String]) = { println("Some text") } }<br>
<br>
And there are 10 or more other features added by Scala that feel like<br>
major wins in removing boilerplate code, like lightweight closures:<br>
<br>
val closure : Int => Int = { _ + 1 }<br>
<br>
or<br>
<br>
List(1, 2, 3).map { _ + 1 }<br>
<span class="HOEnZb"><font color="#888888"><br>
Harold<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
On Wed, Feb 22, 2012 at 10:14 AM, Brian Lavender <<a href="mailto:brian@brie.com">brian@brie.com</a>> wrote:<br>
> Let me preface the Java seems to be encumbered at times with verbosity.<br>
><br>
> System.out.println("Some text");<br>
><br>
> Or, the following, has got to make one wonder.<br>
><br>
> public static void main() {<br>
> }<br>
><br>
> Yet, with its strong typing, it can at times promote better safety. Yet,<br>
> I know the Python guys have a lot of good stuff going.<br>
><br>
> On Tue, Feb 21, 2012 at 06:10:05PM -0800, Eric Rasmussen wrote:<br>
>> Let me preface this by saying that according to some web development<br>
>> communities, Java's niche seems to be enterprise web development by<br>
>> large teams. The reasons I hear (warning: possible stereotypes and<br>
>> faulty assumptions ahead!) are:<br>
>> 1) The language itself is limited and results in a lot of boilerplate<br>
>> code, requiring more development and maintenance time<br>
><br>
> I think with EJB 2.1 the whole thing to stubs and skeletons and<br>
> configuration files scared people off. EJB 3.1 is a whole lot easier. If<br>
> you are writing Plain Old Java Objects (POJOs) and not having to focus on<br>
> all this outside infrastructure, life is a lot better. Today's measurment<br>
> of success usually measures whether or not you can focus on POJOs. Yet,<br>
> Context Dependency Injection (CDI) also brings a better separation<br>
> of concern.<br>
><br>
>> 2) Deployment requires powerful servers, tons of configuration, etc.<br>
><br>
> A little more overhead. But, if you all you want is a servlet container to<br>
> serve up your pages, jetty is relatively light weight. If you want to see<br>
> something cool, try the following:<br>
><br>
> $ sudo apt-get install maven2<br>
><br>
> Using the the following will create default web application that uses<br>
> Wicket framework.<br>
><br>
> $ mvn archetype:generate -DarchetypeGroupId=org.apache.wicket \<br>
> -DarchetypeArtifactId=wicket-archetype-quickstart \<br>
> -DarchetypeVersion=1.5.4 -DgroupId=com.mycompany \<br>
> -DartifactId=myproject -DarchetypeRepository=<a href="https://repository.apache.org/" target="_blank">https://repository.apache.org/</a> \<br>
> -DinteractiveMode=false<br>
><br>
> $ cd myproject<br>
> $ mvn jetty:run<br>
><br>
> Point your browser to <a href="http://localhost:8080" target="_blank">http://localhost:8080</a> . It's pretty lightweight. Not to mention,<br>
> if you send your source code to someone, they can run it too without having to grab<br>
> a whole bunch of jar dependencies. Pack up and send your project to a friend using<br>
> the following:<br>
><br>
> $ mvn clean<br>
> $ tar zcvf myproject.tgz myproject<br>
> $ ls -l myproject.tgz<br>
> -rw-r--r-- 1 brian brian 20K 2012-02-22 10:11 myproject.tgz<br>
><br>
><br>
><br>
>> 3) The apps use a lot of memory so many web hosts don't support it<br>
>> It sounds like some of the libraries you've found might mitigate that<br>
>> and give people a reason to rethink Ruby on Rails or Django for their<br>
>> next app. In particular I'm really interested in how Java might benefit<br>
>> lone developers and small teams, either in terms of increased<br>
>> productivity or the security/stability/performance of the end product,<br>
>> and maybe a basic rundown of how to affordably launch a Java app.<br>
><br>
> Unpredictable Garbage Collection can be a hinderance, yet ehcache is supposed<br>
> to do a good job at managing memory. I believe it uses a slab allocator so there<br>
> are less system calls to alloc and free.<br>
><br>
> So, I would like to invite people to download Netbeans 7.1. Get the version that<br>
> does either Java EE or "All". It has the application server, the database. You will<br>
> also need to have the OpenJDK installed. If not do a "sudo apt-get install openjdk-6-jdk".<br>
> You can also use OpenJDK 7 if you like.<br>
><br>
> Once you have downloaded OpenJDK, run it similar to what follows:<br>
><br>
> $ sh ./<a href="http://netbeans-7.1-ml.linux.sh" target="_blank">netbeans-7.1-ml.linux.sh</a><br>
><br>
> Now that you have it installed, create a new web project.<br>
><br>
> File->New Project<br>
><br>
> Select a web project:<br>
><br>
> Java Web Web Application<br>
><br>
> Choose the defaults. Enter the name as SimpleWebApp<br>
><br>
> Once the project has been created, right click the project and select "Run".<br>
><br>
> Voila, you have a running Java Web Application. Netbeans has some great tools at facilitating the<br>
> process. Netbeans should launch your web browser with the url referencing your application. It launched<br>
> it using the included GlassFish application server.<br>
><br>
> I worked through the book titled:<br>
> Java EE 6 Development with NetBeans 7<br>
> by David R. Heffelfinger<br>
><br>
> It walks you through many of the features of creating Java EE Applications.<br>
><br>
> brian<br>
> --<br>
> Brian Lavender<br>
> <a href="http://www.brie.com/brian/" target="_blank">http://www.brie.com/brian/</a><br>
><br>
> "There are two ways of constructing a software design. One way is to<br>
> make it so simple that there are obviously no deficiencies. And the other<br>
> way is to make it so complicated that there are no obvious deficiencies."<br>
><br>
> Professor C. A. R. Hoare<br>
> The 1980 Turing award lecture<br>
> _______________________________________________<br>
> vox mailing list<br>
> <a href="mailto:vox@lists.lugod.org">vox@lists.lugod.org</a><br>
> <a href="http://lists.lugod.org/mailman/listinfo/vox" target="_blank">http://lists.lugod.org/mailman/listinfo/vox</a><br>
_______________________________________________<br>
vox mailing list<br>
<a href="mailto:vox@lists.lugod.org">vox@lists.lugod.org</a><br>
<a href="http://lists.lugod.org/mailman/listinfo/vox" target="_blank">http://lists.lugod.org/mailman/listinfo/vox</a><br>
</div></div></blockquote></div><br>