Java Mailing List Archive

http://www.junlu.com/

Google
Google
Mailing List
Home
Forum Home
JBoss - Java Application Server
Tomcat - JSP/Servlet container
Struts - A MVC web framework
iText - An open source PDF Java Library
JDOM - JDOM XML Parser
JSP - A mailing list about Java Server Pages specification and reference
J2EE - A mailing list for Java(tm) 2 Platform, Enterprise Edition
J2EE Pattern - An interest list for Sun Java Center J2EE Pattern Catalog
Servlet - A mailing list for discussion about Sun Microsystem's Java Servlet API Technology
Struts & Hibernate
Subjects
JSP editor plugin for eclipse ?
org apache jasper JasperException: Unable to compile class for JSP
Tomcat: Connection reset by peer: socket write error
Cannot retrieve definition for form bean null
Struts Tiles Tutorial (free Struts training)
Where do I download Tomcat 4 0 6?
Data Access Object (DAO) pattern, example DAO 's
Where to download Tomcat v 4 1 24 from?
Tomcat 5 0 16 Requested resource not available
Subject: Servlet : Session invalidate
Oracle Connection Pooling in 3 2 2
Servlet action is currently unavailable
Tomcat/Struts Unicode Encoding/Decoding problems
Subject: Running a Simple JMS Example
Tomcat and webapplication specific java library path
Mapping in workers2 properties
org apache jasper JasperException
problem with html:text bean throwing exception
Cannot find message resources under key org apache struts action
   MESSAGE
Cannot find message resources under key org apache struts action MESSAGE
invalid direct reference problem with solution
Tool for jsp debug Try Sysdeo Eclipse Plugin
Tomcat 5 Cannot load JDBC driver class 'null ' SQL state: null
weblogic ejbc
java properties file
Jboss 3 2 3 Coyote Can 't re
Tomcat 5, Apache2 and mod jk2 integration problem
JBoss example problem new to J2EE
Value attribute of <html:checkbox
url string for connecting jboss to oracle
javax servlet ServletException: BeanUtils populate
5 0 18: Windows XP Pro vs Windows 2000
HTTP Status 404 The requested resource is not available
 
Refactor something that 's not quite a Template pattern

Refactor something that 's not quite a Template pattern

2006-08-25       - By snekse

 Back
Reply:     1     2     3     4  

That misses a step.  I need to split which fetch method it's going to call
if the cached list is null.

i.e.

lCacheList = MiscCodeDao.fetchList_A(pSession);
-OR-
lCacheList = MiscCodeDao.fetchList_B(pSession);

On 8/25/06, Dan Marchant <driedtoast@(protected)> wrote:
>
> why don't you just do this:
>
>
>
> public static List fetchList(String key, Session pSession)
>     throws HibernateException
>     {
>         String lListKey = key;
>         List lCacheList = (List) getObjectValueOrNull(MISC_LISTS_CACHE
> .get(lListKey));
>
>         if(lCacheList==null)
>         {
>             lCacheList = MiscCodeDao.fetchList_A(pSession);
>             MISC_LISTS_CACHE.put(new Element(lListKey,lCacheList));
>         }
>         return lCacheList;
>     }
>
>
> public static List fetchList_A(Session pSession)
>     throws HibernateException
>     {
>         String lListKey = "LIST_A";
>         return fetchList(IListKey,pSession);
>     }
>
>     public static List fetchList_B(Session pSession)
>     throws HibernateException
>     {
>         String lListKey = "LIST_B";
>         return fetchList(IListKey,pSession);
>     }
>
> - dan
>
> On 8/25/06, snekse <snekse@(protected)> wrote:
> > Can anyone point me to a good way to refactor this?  Currently these two
> > methods do exactly the same thing, except they use a different param as
> the
> > obj key ( lListKey ) and if it's not found in the cache, they need to
> call
> > separate methods ( MiscCodeDao.fetch*(..) ) to retrieve the object so it
> can
> > put it into the cache.
> >
> >
> >     public static List fetchList_A(Session pSession)
> >     throws HibernateException
> >     {
> >         String lListKey = "LIST_A";
> >         List lCacheList = (List) getObjectValueOrNull(MISC_LISTS_CACHE
> > .get(lListKey));
> >
> >         if(lCacheList==null)
> >         {
> >             lCacheList = MiscCodeDao.fetchList_A(pSession);
> >             MISC_LISTS_CACHE.put(new Element(lListKey,lCacheList));
> >         }
> >         return lCacheList;
> >     }
> >
> >     public static List fetchList_B(Session pSession)
> >     throws HibernateException
> >     {
> >         String lListKey = "LIST_B";
> >         List lCacheList = (List)
> > getObjectValueOrNull(MISC_LISTS_CACHE.get(lListKey));
> >
> >         if(lCacheList==null)
> >         {
> >             lCacheList = MiscCodeDao.fetchList_B(pSession);
> >             MISC_LISTS_CACHE.put(new Element(lListKey,lCacheList));
> >         }
> >         return lCacheList;
> >     }
> >
> > The reason I want to refactor this is because we are going to have 10-20
> > list stored in the cache.  Here's the rub: I need to avoid hardcoding a
> > string for the method name (i.e.
> > invokeMethod("fetchList_A",MiscCodeDao.class, paramArray) ). We've found
> > issues with refactoring when the method names are hardcoded as a String
> > variable.  If possible, I'd also like to avoid a switch as well (i.e.
> > fetchList("LIST_A") )
> >
> >  Any thoughts?
> >
> > Thanks,
> > snekse
> > ====================================================================
> > Companion Site: http://www.corej2eepatterns.com J2EE BluePrints:
> > http://java.sun.com/blueprints/corej2eepatterns List
> > Archive:
> > http://archives.java.sun.com/archives/j2eepatterns-interest.html
> > Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to
> > listserv@(protected)
>
> ====================================================================
> Companion Site: http://www.corej2eepatterns.com
> J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
> List Archive:
> http://archives.java.sun.com/archives/j2eepatterns-interest.html
> Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to
> listserv@(protected)
>

====================================================================
Companion Site: http://www.corej2eepatterns.com
J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
List Archive: http://archives.java.sun.com/archives/j2eepatterns-interest.html
Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to listserv@(protected)

That misses a step.&nbsp; I need to split which fetch method it's going to call
if the cached list is null.<br><br>i.e. <br><br>lCacheList = MiscCodeDao
.fetchList_A(pSession);<br>-OR-<br>lCacheList = MiscCodeDao.fetchList_B(pSession
);
<br><br><div><span class="gmail_quote">On 8/25/06, <b class="gmail_sendername"
>Dan Marchant</b> &lt;<a href="mailto:driedtoast@(protected)">driedtoast@(protected)
</a>&gt; wrote:</span><blockquote class="gmail_quote" style="border-left: 1px
solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
why don't you just do this:<br><br><br><br>public static List fetchList(String
key, Session pSession)<br>&nbsp;&nbsp;&nbsp;&nbsp;throws HibernateException<br>
&nbsp;&nbsp;&nbsp;&nbsp;{<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp
;String lListKey = key;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;List
lCacheList = (List) getObjectValueOrNull(MISC_LISTS_CACHE
<br>.get(lListKey));<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if
(lCacheList==null)<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br>&nbsp
;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;lCacheList =
MiscCodeDao.fetchList_A(pSession);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp
;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;MISC_LISTS_CACHE.put(new Element(lListKey
,lCacheList));<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return lCacheList;
<br>&nbsp;&nbsp;&nbsp;&nbsp;}<br><br><br>public static List fetchList_A(Session
pSession)<br>&nbsp;&nbsp;&nbsp;&nbsp;throws HibernateException<br>&nbsp;&nbsp;
&nbsp;&nbsp;{<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;String lListKey
= &quot;LIST_A&quot;;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return
fetchList(IListKey,pSession);<br>&nbsp;&nbsp;&nbsp;&nbsp;}<br>
<br>&nbsp;&nbsp;&nbsp;&nbsp;public static List fetchList_B(Session pSession)<br
>&nbsp;&nbsp;&nbsp;&nbsp;throws HibernateException<br>&nbsp;&nbsp;&nbsp;&nbsp;{
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;String lListKey = &quot;LIST
_B&quot;;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return fetchList
(IListKey,pSession);<br>&nbsp;&nbsp;&nbsp;&nbsp;}<br><br>- dan<br>
<br>On 8/25/06, snekse &lt;<a href="mailto:snekse@(protected)">snekse@(protected)<
/a>&gt; wrote:<br>&gt; Can anyone point me to a good way to refactor this?&nbsp;
&nbsp;Currently these two<br>&gt; methods do exactly the same thing, except they
use a different param as the
<br>&gt; obj key ( lListKey ) and if it's not found in the cache, they need to
call<br>&gt; separate methods ( MiscCodeDao.fetch*(..) ) to retrieve the object
so it can<br>&gt; put it into the cache.<br>&gt;<br>&gt;<br>&gt;&nbsp;&nbsp;
&nbsp;&nbsp; public static List fetchList_A(Session pSession)
<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp; throws HibernateException<br>&gt;&nbsp;&nbsp;
&nbsp;&nbsp; {<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; String
lListKey = &quot;LIST_A&quot;;<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp
;&nbsp; List lCacheList = (List) getObjectValueOrNull(MISC_LISTS_CACHE<br>&gt;
.get(lListKey));<br>&gt;<br>
&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if(lCacheList==null)<br>
&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {<br>&gt;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; lCacheList = MiscCodeDao
.fetchList_A(pSession);<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; MISC_LISTS_CACHE.put(new Element(lListKey,lCacheList));
<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&gt;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return lCacheList;
<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&gt;<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;
public static List fetchList_B(Session pSession)<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp
; throws HibernateException<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp; {<br>&gt;&nbsp;&nbsp
;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; String lListKey = &quot;LIST_B&quot;;<br>
&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; List lCacheList = (List)
<br>&gt; getObjectValueOrNull(MISC_LISTS_CACHE.get(lListKey));<br>&gt;<br>&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if(lCacheList==null)<br>&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {<br>&gt;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; lCacheList = MiscCodeDao
.fetchList_B(pSession);<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; MISC_LISTS_CACHE.put(new Element(lListKey,lCacheList));
<br>&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&gt;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return lCacheList;<br>&gt;&nbsp;&nbsp;&nbsp
;&nbsp; }<br>&gt;<br>&gt; The reason I want to refactor this is because we are
going to have 10-20<br>&gt; list stored in the cache.&nbsp;&nbsp;Here's the rub
: I need to avoid hardcoding a
<br>&gt; string for the method name (i.e.<br>&gt; invokeMethod(&quot;fetchList
_A&quot;,MiscCodeDao.class, paramArray) ). We've found<br>&gt; issues with
refactoring when the method names are hardcoded as a String<br>&gt; variable.
&nbsp;&nbsp;If possible, I'd also like to avoid a switch as well (
i.e.<br>&gt; fetchList(&quot;LIST_A&quot;) )<br>&gt;<br>&gt;&nbsp;&nbsp;Any
thoughts?<br>&gt;<br>&gt; Thanks,<br>&gt; snekse<br>&gt; ======================
==============================================<br>&gt; Companion Site: <a href=
"http://www.corej2eepatterns.com">
http://www.corej2eepatterns.com</a> J2EE BluePrints:<br>&gt; <a href="http:/
/java.sun.com/blueprints/corej2eepatterns">http://java.sun.com/blueprints
/corej2eepatterns</a> List<br>&gt; Archive:<br>&gt; <a href="http://archives
.java.sun.com/archives/j2eepatterns-interest.html">
http://archives.java.sun.com/archives/j2eepatterns-interest.html</a><br>&gt;
Unsubscribing: email &quot;signoff J2EEPATTERNS-INTEREST&quot; to<br>&gt; <a
href="mailto:listserv@(protected)">listserv@(protected)</a><br><br>
====================================================================<br
>Companion Site: <a href="http://www.corej2eepatterns.com">http://www
.corej2eepatterns.com</a><br>J2EE BluePrints: <a href="http://java.sun.com
/blueprints/corej2eepatterns">
http://java.sun.com/blueprints/corej2eepatterns</a><br>List Archive: <a href=
"http://archives.java.sun.com/archives/j2eepatterns-interest.html">http:/
/archives.java.sun.com/archives/j2eepatterns-interest.html</a><br>Unsubscribing:
email &quot;signoff J2EEPATTERNS-INTEREST&quot; to
<a href="mailto:listserv@(protected)">listserv@(protected)</a><br><
/blockquote></div><br>
====================================================================
Companion Site: http://www.corej2eepatterns.com
J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
List Archive: http://archives.java.sun.com/archives/j2eepatterns-interest.html
Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to listserv@(protected)

©2008 junlu.com - Jax Systems, LLC, U.S.A.