Re: Holy boop: goto for Java
 
On 04.06.2012 19:45, Lew wrote:
public void processResources(String ... resourceNames)
{
....
I'd rather
public void processResources(String ... resourceNames)
{
   for (String name : resourceNames)
   {
     try
     {
       final BufferedReader br =
         new BufferedReader(new FileReader(name));
       try
       {
         doSomething(br);
         reportComplete(name);
       }
       catch(IOException exc)
       {
         logger.error("Issue while processing "+ name, exc);
       }
       finally
       {
         close(br);
       }
     }
     catch(FileNotFoundException exc)
     {
       logger.error("Cannot find "+ name, exc);
     }
   }
}
close() is a static helper method which catches IOException and reports it.
In other words, I try to place the catch block at the end of a logical 
section and use try catch to only execute some commands in absence of 
error.  The exception will make the continue superfluous.  The advantage 
in my eyes is that you can easily follow the regular flow and have error 
handling concentrated in one place.  I sometimes even refactor out 
methods so I can have this catch at the end idiom.
In a more realistic example I'd probably extract parts of this into a 
method (likely the inner try catch finally).
Kind regards
    robert
-- 
remember.guy do |as, often| as.you_can - without end
http://blog.rubybestpractices.com/