| 
 | 
Daniel Eyers wrote:
>I know I have a class called myClass
>that inherits from HttpServlet.  I also
>know that implementing SingleThreadModel
>changes the way the HttpServlet is
>handled by WAS.
This highlights yet another use of the interface concept that seems
specific to Java.
There are a couple of "interfaces" that are more stylistic conventions or
functional agreements than true interfaces.  I think this is an example of
one.
Basically, the default and formal definition of servlet is such that you
can have multiple threads against the servlet object.  I always found this
an odd definition, but that's what we have.  So, you can't rely on any
variables in the servlet as "instance" variables without a lot of
synchronizing methods.
While I haven't deployed major servlets of my own yet, my usual approach is
to have a "shadow" object that corresponds to each servlet and then the
servlet proper doGet/doPut code consists largely of constructing the
"shadow" object, including the input and output stuff that came in as
input.  I then provide a "run" method or some such on the shadow object and
away it goes.  In this way, I can have ordinary instance variables that are
threadsafe, because I can put the reference to my "shadow" object on
"thread local stack" storage in my doGet or doPut method.
Given that easy technique, SingleThreadModel is something I haven't
bothered with.  The fact that I do performance for a living influences me
some here, but SingleThreadModel seems to be a very drastic approach that
lets you know you have exactly one copy of the servlet hanging about (or,
at least that's how I read the manual on Servlets where this is described).
This lets you use class and instance variables without synchronization, but
it seems a bit too restrictive to me; doesn't scale.  Of course, the main
effect of this is to signal to WebSphere how you expect to be invoked.
So, even if I don't like it much, SingleThreadModel is a good example of
how very simple interfaces can be used as cues to change behavior of Java
classes.  Another "implements" that seems really for others to look at is
the "Serializable" interface which actually seems to be a signal to the JVM
to permit the object to be "deflated" and written out to a byte stream in
certain circumstances (Serializable actually seems to cheat a bit in that
it allows a default implementation to be provided for the interface by
Java, but it is a very basic function, so it makes sense).
Larry W. Loen  -   Senior Java and AS/400 Performance Analyst
                          Dept HP4, Rochester MN
+---
| This is the JAVA/400 Mailing List!
| To submit a new message, send your mail to JAVA400-L@midrange.com.
| To subscribe to this list send email to JAVA400-L-SUB@midrange.com.
| To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner: joe@zappie.net
+---
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.