﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-JBahamut</title><link>http://www.blogjava.net/JBahamut/</link><description>&lt;br&gt;最“邪恶”的问题是那些需要解决或者部分解决才能够定义的问题</description><language>zh-cn</language><lastBuildDate>Sat, 06 Sep 2008 02:47:11 GMT</lastBuildDate><pubDate>Sat, 06 Sep 2008 02:47:11 GMT</pubDate><ttl>60</ttl><item><title>读 Erlang mailing list 有感</title><link>http://www.blogjava.net/JBahamut/archive/2008/05/28/203362.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Tue, 27 May 2008 16:32:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2008/05/28/203362.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/203362.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2008/05/28/203362.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/203362.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/203362.html</trackback:ping><description><![CDATA[多谢 erlang-china 的提醒，今天从 mailing list 中翻出了关于RPC的讨论，深有感触 -- 牛人就是牛人！！！<br />
<br />
关于 RPC is bad 的主要论点如下：<br />
<pre wrap=""><span style="font-size: 18pt;"><span style="color: red;">The fundamental problem of RPC, which is trying to make remote calls look local, is based on essentially trying to ignore the problems covered by the fallacies or trying to pretend they don't even exist</span></span><br />
<br />
严重同意，理由如下：<br />
<br />
<strong>Network partitions are real, timeouts are real, remote host and service<br />
crashes are real, the need for piecemeal system upgrade and handling<br />
version differences between systems is real, etc. The distributed<br />
systems programmer </strong><strong>*must* deal with these and other issues because<br />
they affect different applications very differently.</strong><br />
<br />
这一点非常赞同，也深有同感。在做FileServer的时候所有的节点都是通过RMI进行通讯，最初使用RMI的目的就是<br />
简化网络部分的开发，对于一般的开发人员无须理解RMI，动态代理，只需要像使用本地方法一样就可以访问远程<br />
节点。这种方案确实很好的隐藏了网络细节，使网络对开发人员完全透明，但有个问题始终无法很好的处理：<strong>异常。<br />
</strong>网络错误是随时都有可能发生的，对于不同的错误需要根据环境和需要做具体的处理，比如，多试几次，尝试下一个<br />
节点，对于无法处理的还可以直接抛出。而这种策略的选择和使用必须由应用逻辑层完成，可是应用层假设是不知道<br />
网络存在的，它甚至无法知道自己调用的方法中哪个是远程调用，哪个是本地调用。这种矛盾从根本上说明了网络的<br />
复杂性和多样性是开发分布式应用的程序员必须面对的，是逃不掉的，要直面这惨淡的人生T_T<br />
<br />
下面阐述了使用类型系统的缺陷：<br />
Such systems also have problems with impedance mismatch between the<br />
IDL and whatever languages you're translating it to. If the IDL is<br />
minimal so that it can be used with a wide variety of programming<br />
languages, it means advanced features of well-stocked languages like<br />
Java and C++ can't be used. OTOH if you make the IDL more powerful so<br />
that it's closer to such languages, then translating it to C or other<br />
more basic languages becomes quite difficult.<br />
On top of all that, no matter how you design the IDL type system, all <br />
the types won't -- indeed, can't -- map cleanly into every desired <br />
programming language.<br />
<br />
类型系统一直都在进化，从弱到强到动态，你相信会有一种类型系统可以和所有<br />
的其他语言进行完美的映射吗？如果真存在，类型系统的进化就毫无意义了。定义<br />
一个新的语言，然后映射到其他语言，最后号称&#8220;我是跨语言跨平台的！&#8221;，这种<br />
解决问题的方式根本就是有问题的。WSDL使用XML描述，有着更好的可扩展性，只是<br />
酒瓶换新酒，根烂了，再换也没用。<br />
<br />
Ultimately, RPC is a leaky abstraction. It can't hide what it tries to<br />
hide, and because of that, it can easily make the overall problem more<br />
difficult to deal with by adding a lot of accidental complexity.<br />
<br />
下面对为什么 message queuing system 适合分布式系统做了很好的总结：<br />
Message queuing systems work well because (in no particular<br />
order):<br />
<br />
* they don't pretend to be programming language procedure or method<br />
calls, so they avoid the associated impedance mismatch problems<br />
* they don't try to hide distributed systems issues<br />
* coupling is low -- drop a message into a queue here, pick up a<br />
message from a queue there<br />
* queues can be persistent, or more generally, delivery guarantees can<br />
be varied as needed<br />
* asynchrony<br />
* payloads need not conform to some made-up IDL type system<br />
* getting two different messaging systems to interoperate is easier<br />
than getting two different RPC or distributed object systems to<br />
interoperate<br />
</pre>
这和我在自己的硕士论文中的观点有些相似：完全使用消息机制进行构件间的通讯。构件可以<br />
是分布式的或在容器中的，基于消息的通讯都是完全适用的。对于网络应用同样如此。对于流行<br />
的网络协议，HTTP，FTP，LDAP 等等都是消息式的，完全经历了时间的考验。<br />
<br />
<img src ="http://www.blogjava.net/JBahamut/aggbug/203362.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2008-05-28 00:32 <a href="http://www.blogjava.net/JBahamut/archive/2008/05/28/203362.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>感谢blogjava</title><link>http://www.blogjava.net/JBahamut/archive/2007/10/07/150936.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Sun, 07 Oct 2007 15:10:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2007/10/07/150936.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/150936.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2007/10/07/150936.html#Feedback</comments><slash:comments>2</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/150936.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/150936.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp; 感谢blogjava，大半年没更新了，我的blog竟然还可以登录<img src="/CuteSoft_Client/CuteEditor/images/emdgust.gif" align="absmiddle" border="0"  alt="" /><br />
&nbsp;&nbsp;&nbsp; 发现自己真的是很懒啊，总是没法坚持写些东西，从本质上说我还是个不擅长写作的<br />
程序员，正确的表达自己比写出正确的程序要困难许多，表达出能让别让共鸣的东西<br />
更是难上加难。<br />
&nbsp;&nbsp;&nbsp; 但是，文章还是必须要是会写的，牛皮也是必须要会吹的。神啊，请允许我再一次许诺吧，<br />
试着写点东西吧。<br />
<br />
<img src ="http://www.blogjava.net/JBahamut/aggbug/150936.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2007-10-07 23:10 <a href="http://www.blogjava.net/JBahamut/archive/2007/10/07/150936.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>惊喜！！发现了自己的blog-_-!!!</title><link>http://www.blogjava.net/JBahamut/archive/2006/12/26/90171.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Tue, 26 Dec 2006 13:29:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2006/12/26/90171.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/90171.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2006/12/26/90171.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/90171.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/90171.html</trackback:ping><description><![CDATA[整理收藏夹竟然发现了自己的blog-_-!!<br /><br />
翻翻发现最新的文章竟然是半年以前了，还号称“不再偷懒了”，实在惭愧啊。项目一忙起来<br />
确实是顾不上了，回来还有看动画片的重任在身自然更是无暇顾及了，说到底自己终久不是<br />
喜欢码字的人。不过翻翻以前写的东西还是蛮有意思的，有些东西回头看看还是很有好处<br />
的，于是决定还是写写吧，哪怕下一次会是半年以后^_^<br /><br />
最近工作搞定了，FileServer也初见成果，正在整理代码，是时候好好整理一下前段时间工作的体会了，第一次组织项目还是有很多感想可写的，请各位看官（如果有的话）敬请期待吧！！！<br /><br /><img src ="http://www.blogjava.net/JBahamut/aggbug/90171.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2006-12-26 21:29 <a href="http://www.blogjava.net/JBahamut/archive/2006/12/26/90171.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>要开始写日志了</title><link>http://www.blogjava.net/JBahamut/archive/2006/05/20/47133.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Fri, 19 May 2006 17:05:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2006/05/20/47133.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/47133.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2006/05/20/47133.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/47133.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/47133.html</trackback:ping><description><![CDATA[    最近一直在准备做File
Server，要支持分布式存储和虚拟文件系统，我还希望能再进一步，加上日志系统。一切都始于我无止境的yy，现在仔细想想，难度真的是挺大的，不知道
我这半瓶酒能不能应付。不过是我负责，终于可以按我的想法组织项目了^_^<br />
    作为一次难得的锻炼机会，我准备把整个过程都记录下来，希望能够坚持下来。那就先表个态：<br />
        <font size="5"><b><br />
    我要写Blog了！！！不能偷懒了！！！！<br /><br /></b></font><p><font size="5"><b>
   </b><font size="3">之所以突然要写了，是因为前两天写自然基金的申请，发现许多东西只有写出来了才会有更
深刻的理解，并且写的过程还可以整理思绪，提供了足够的时间给我这样反应迟钝的人思考。而且想想研究生已经一年了，好像什么也没有留下，遇到什么问题还是
google，虽然许多已经见过并且解决了。就因为没有记录下来，没有形成积累白白浪费了许多时间，希望以后能有改观。今天就到这里，先贴个链接：</font></font></p><font size="5"><font size="3"><a href="http://www.sdsc.edu/srb/index.php/Main_Page">http://www.sdsc.edu/srb/index.php/Main_Page</a><br />
一个分布式存储系统，貌似很不错<br />
ps：竟然不能插入链接，难道是Firefox的问题？<br /></font></font><img src ="http://www.blogjava.net/JBahamut/aggbug/47133.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2006-05-20 01:05 <a href="http://www.blogjava.net/JBahamut/archive/2006/05/20/47133.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>关于对象序列化的研究</title><link>http://www.blogjava.net/JBahamut/archive/2005/09/09/12539.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Fri, 09 Sep 2005 06:07:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2005/09/09/12539.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/12539.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2005/09/09/12539.html#Feedback</comments><slash:comments>2</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/12539.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/12539.html</trackback:ping><description><![CDATA[
		<div style="text-align: left;">    序列化是将对象变为连续的字节流，用于对象的持久化，网络传输等场合<br /><br />
一个类希望能被序列化必须实现 Serializable 接口，Serializable 本身并没有声明任何<br />
方法，只是起标记作用。可序列化类的子类自然也是可序列化的。因而实现序列化是非常方<br />
便的，只要在类的声明时添加 implenment Serializable 就可以了，java 虚拟机会帮你处<br />
理剩下的工作。序列化是递归的，一个类想要序列化则它的所有数据成员都必须是可以序列<br />
化的，否则在序列化时会抛出 NotSerializableException 异常。jsdk 中基本数据类型的<br />
封装类（Integer， Float etc），Component 都是可序列化的，如果容器中的对象都是可<br />
序列化的，则容器时可序列化的。java.lang.refect 包中的类不能序列化，Socket,<br />
URLConnection 不能序列化。<br /><br />
对于只实现了 Serializable 接口的类，可以想象 java 是如何将它们序列化的：首先要利<br />
用反射机制得到所有需要序列化的数据成员，包括 private 成员，得到 private 成员的过<br />
程是非常规的，必定要经过严格的权限和安全检查。所以用 java 自己的序列化方式开销是<br />
非常大的，这也是为什么会有这篇文章的原因，这里要讨论 java 提供的可以由我们自己控<br />
制的序列化对象的方式。<br /><br />
覆写<br />
private void writeObject(ObjectOutputStream out)<br />
private void readObject(ObjectInputStream in)<br /><br />
这两个方法会在对象序列化和反序列化时被调用，通过覆写这两个方法我们可以完全控制整<br />
个序列化的过程。我们注意到这两个方法都是 private ，这意味我们无法显示的调用这两<br />
个方法，而 java 虚拟机在调用这两个方法时也必然要经过严格的权限和安全检查。与传统<br />
的序列化方式（只实现 Serializable 接口）相比，这种方法减少了利用反射的次数以及获<br />
取 private 成员所需要的额外开销，因为在这两个方法中所有的数据成员都是可以自由使<br />
用的<br /><br />
实现 Externalizable 接口<br />
该接口中定义了两个方法<br />
public void readExternal(ObjectInput in) throws IOException<br />
public void writeExternal(ObjectOutput out) <br />
       throws IOException, ClassNotFoundException<br /><br />
这两个方法会在对象序列化和反序列化时被调用。很明显这两个方法都是 public 的，所以<br />
我们可以显示的将一个对象序列化到一个输出流，而 java 虚拟机在调用这两个方法时也不<br />
会有任何的限制。<br /><br />ANY-ACCESS_MODIFIER Object writeReplace() throws ObjectStreamException;<br />ANY-ACCESS_MODIFIER Object readResolve() throws ObjectStreamException;<br />这两个方法在序列化和反序列化时被调用,可以替换将要写入或读出的对象,在实现Singleton模式<br />时可能会用到<br /><br />
这三种方法实现序列化效率是显而易见的:传统方式最慢，实现 Externalizable 接口方式<br />
最快。但自己控制序列化过程有个明显的缺点就是当类的数据成员改变时，序列化过程也同<br />
时需要修改，相反这正好是传统方式的优点：任何改动都不会影响对象的正确序列化，虚拟<br />
机会帮你完成一切工作，虽然不算出色。<br /><br />
当我们考虑性能问题时，序列化总应该是我们首先要注意的方面，尤其是那些只实现了<br />
Serializable 接口的类，它们往往就是性能的瓶颈所在，特别是一些对象需要反复的被序<br />
列化和反序列化，实现 Externalizable 接口会给你不小的惊喜。而对于实现<br />
Externalizable 接口后需要保持数据成员和序列化方法一致的问题实际算不上问题，因为<br />
当我们考虑性能问题时应该已经到了编码的最后阶段，这时整体框架和数据结构都已经非常<br />
稳定了，数据成员被修改的可能已经非常低了，即使被修改了，能大幅提高性能，多写两行代<br />
码也不是令人沮丧的事情。<br /><br />
以上只是单纯的讨论序列化的过程，实际上序列化总是和 I/O 操作同时发生，因为序列化<br />
就是为了传输或是存储，所以对 I/O 的优化方法在这里也是同样适用的。<br /><br />使用ObjectOutputStream.writeObject()时,在流的内部会有一个引用缓存,所有已经写入流的<br />对象如果再次被写入则直接使用以前引用而不重新传输新的对象,这样可以提到流的效率,但同样带来<br />问题,一个对象写入流后,被修改,再次写入流,再另一端ObjectInputStream得到的是<br />两个相同的对象,这一点一定要注意<br /><br /></div>
<img src ="http://www.blogjava.net/JBahamut/aggbug/12539.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2005-09-09 14:07 <a href="http://www.blogjava.net/JBahamut/archive/2005/09/09/12539.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>考古－－inheritance</title><link>http://www.blogjava.net/JBahamut/archive/2005/08/24/10850.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Tue, 23 Aug 2005 17:17:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2005/08/24/10850.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/10850.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2005/08/24/10850.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/10850.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/10850.html</trackback:ping><description><![CDATA[关于 overloading 和 overriding<br>
首先 java 中所有的方法都采用后绑定，就是在运行时绑定（除了被声明为 final 和 static 的）<br>
<br>
java通过方法的 signature 来判断一个方法与其他方法的关系，是无关的，overload 或 override<br>
方法的 signature 可以肯定的是方法名和参数。返回值，权限修饰词（public private），final，<br>
static 修饰词的情况有点复杂后面依次讨论。<br>
<br>
final &amp;&amp; private<br>
被声明为 final 或 private 的方法都是不能被 override 的，一定要注意这是两个语义完全不同的词，<br>
他们除此以外没有任何联系。final 不仅不允许子类 override，并且禁止子类使用名字和参数相同但返回<br>
值不同的方法 overload(如例子中的 functionEight（）），而 private 不同，他对子类是不可见的<br>
你完全可以在子类中定义一个与父类一摸一样的方法（这完全合理）。因此说 private 隐含有 final 的<br>
意思并不准确。 private 就是说 It's mine~~~~~~~~~ 对于类以外，没有人知道它的存在。final<br>
只是说这个方法不想被你覆写。<br>
<br>
返回值<br>
返回值不是方法的 signature，当方法名和参数相同时编译器会强制要求返回值必须一致，但子类 override<br>
父类的方法返回值可以不同,同样有一个条件返回值类型之间要有继承关系！！（例子中的<br>
functionTwo() functionThree() functionFour() 很好的演示这种关系）。要 override，<br>
子类的返回值类型必须是父类的返回值类型的子类（有点拗口，看看 fanctionTwo() functionFour <br>
就会明白了），这也应该是我们想要的行为。<br>
<br>
public &amp;&amp; private &amp;&amp; protected<br>
继承时方法的权限可以扩大但不能缩小(public &gt; protected &gt; none &gt; private)(例子 <br>
functionSix() and functionSeven())<br>
<br>
static<br>
你可以覆写 static 方法，就像 functionFive() 一样，看起来是 override，但实际上 static<br>
方法始终是前绑定，即在编译时绑定的。所有永远不会产生多态的效果，我们还是打消 override<br>
static 方法的念头吧<img src ="http://www.blogjava.net/JBahamut/aggbug/10850.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2005-08-24 01:17 <a href="http://www.blogjava.net/JBahamut/archive/2005/08/24/10850.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>考古－－Exception</title><link>http://www.blogjava.net/JBahamut/archive/2005/08/24/10849.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Tue, 23 Aug 2005 17:15:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2005/08/24/10849.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/10849.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2005/08/24/10849.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/10849.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/10849.html</trackback:ping><description><![CDATA[用 catch 捕获异常后程序会继续执行，如果一个异常被抛出至到被 catch 程序继续执行，<br>
或者被抛出 main，printTrace。程序继续执行的位置是异常被catch的地方。所有初看起来<br>
在catch后的语句和finally里的语句没什么区别，在catch后都会执行。这里要强调的是<br>
finally中的语句是一定会执行的，在下面的几种情况中finally的语句会执行而catch后的<br>
语句不会执行<br>
1.在catch中又抛出异常<br>
2.try，catch，finally在循环中，try块中使用 coninue 或 break<br>
finally是在出现异常后必须要处理的事情，而catch后的语句是认为程序已经从错误中恢复，<br>
在正常状态下继续执行。<br>
<br>
<br>
在一个 try 块之后可以后多个 catch 块，每块捕获不同的异常。当一个异常被抛出后，安<br>
顺序找到匹配的为止<br>
<br>
<br>
一个异常可以说明是谁引起了他（cause），可以用构造函数或initCause（Throwable e）<br>
函数来说明。许多异常没有带 Throwable参数的构造函数，但 initCause 一定是可用的<br>
<br>
<br>
继承于 RuntimeException 的异常是 unchecked，也就是说编译器不会强制程序捕获或向上<br>
抛出异常，这类异常不强制用户处理，（当然你依然可以捕获这类异常，只要你愿意）。<br>
这类异常会一路闯过 main。<br>
<br>
<br>
复写父类的方法时，你只能抛出那些在父类方法中抛出的异常。这样一来子类方法抛出的异<br>
常只能是父类方法抛出异常的子集。但这个约束对构造函数是无效的。注意：派生类的构造<br>
函数不能捕获任何基类抛出的异常<br>
<br><img src ="http://www.blogjava.net/JBahamut/aggbug/10849.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2005-08-24 01:15 <a href="http://www.blogjava.net/JBahamut/archive/2005/08/24/10849.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>最近在实验室学习的一些心得体会</title><link>http://www.blogjava.net/JBahamut/archive/2005/08/23/10841.html</link><dc:creator>JBahamut</dc:creator><author>JBahamut</author><pubDate>Tue, 23 Aug 2005 15:04:00 GMT</pubDate><guid>http://www.blogjava.net/JBahamut/archive/2005/08/23/10841.html</guid><wfw:comment>http://www.blogjava.net/JBahamut/comments/10841.html</wfw:comment><comments>http://www.blogjava.net/JBahamut/archive/2005/08/23/10841.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/JBahamut/comments/commentRss/10841.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/JBahamut/services/trackbacks/10841.html</trackback:ping><description><![CDATA[

<p class="MsoNormal" style="text-align: center;" align="center"><b><span style="font-size: 15pt; font-family: 宋体;">个人心得</span></b><b><span style="font-size: 15pt;" lang="EN-US"><o:p></o:p></span></b></p>


<p class="MsoNormal" style="text-indent: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">这段时间一直在修改</span><span style="font-size: 12pt;" lang="EN-US">ECperf</span><span style="font-size: 12pt; font-family: 宋体;">，主要心得都是</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">应用方面的，对</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">部署的复杂和调试的痛苦深有感触，其中主要原因可能是我对</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">不太熟悉，没有用</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">开发应用的经验，以下的几点心得在熟手看来可能是理所当然的，但却折磨我了好久。</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt; text-indent: -18pt;"><!--[if !supportLists]--><span style="font-size: 14pt;" lang="EN-US">1．<span style="font-family: &quot;Times New Roman&quot;; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span></span><!--[endif]--><span style="font-size: 14pt;" lang="EN-US">EJB</span><span style="font-size: 14pt; font-family: 宋体;">部署</span><span style="font-size: 14pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">部署应用实际上就是将应用安装到应用服务器上，按书上部署</span><span style="font-size: 12pt;" lang="EN-US">Hell Word</span><span style="font-size: 12pt; font-family: 宋体;">时没有遇到丝毫困难，但在部署</span><span style="font-size: 12pt;" lang="EN-US">ECperf</span><span style="font-size: 12pt; font-family: 宋体;">时却冒出了一堆问题。其中困扰我最久的就是</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">互相引用的问题，实际上只需要将所有的引用关系和</span><span style="font-size: 12pt;" lang="EN-US">JNDI</span><span style="font-size: 12pt; font-family: 宋体;">名写入</span><span style="font-size: 12pt;" lang="EN-US">sun-ejb-jar.xml</span><span style="font-size: 12pt; font-family: 宋体;">就可以了（借助</span><span style="font-size: 12pt;" lang="EN-US">sun</span><span style="font-size: 12pt; font-family: 宋体;">的部署工具很容易实现，不同的应用服务器会有不同的文件名如，格式可能也会不同）。在</span><span style="font-size: 12pt;" lang="EN-US">ejb-jar.xml</span><span style="font-size: 12pt; font-family: 宋体;">中，每个</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">必须申明自己引用的</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">的类型，</span><span style="font-size: 12pt;" lang="EN-US">home</span><span style="font-size: 12pt; font-family: 宋体;">接口，</span><span style="font-size: 12pt;" lang="EN-US">remote</span><span style="font-size: 12pt; font-family: 宋体;">接口，和</span><span style="font-size: 12pt;" lang="EN-US">ejb</span><span style="font-size: 12pt; font-family: 宋体;">的引用名，引用名不需要与</span><span style="font-size: 12pt;" lang="EN-US">JNDI</span><span style="font-size: 12pt; font-family: 宋体;">名相同，在</span><span style="font-size: 12pt;" lang="EN-US">sun-ejb-jar.xml</span><span style="font-size: 12pt; font-family: 宋体;">要申明</span><span style="font-size: 12pt;" lang="EN-US">ejb</span><span style="font-size: 12pt; font-family: 宋体;">引用名对应的</span><span style="font-size: 12pt;" lang="EN-US">JNDI</span><span style="font-size: 12pt; font-family: 宋体;">名。</span><span style="font-size: 12pt;" lang="EN-US">DataSource</span><span style="font-size: 12pt; font-family: 宋体;">也需要如此设置，对于</span><span style="font-size: 12pt;" lang="EN-US">env-entry</span><span style="font-size: 12pt; font-family: 宋体;">好像不需要在</span><span style="font-size: 12pt;" lang="EN-US">sun-ejb-jar.xml</span><span style="font-size: 12pt; font-family: 宋体;">中申明。由此可以看出应用服务器对</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">所能访问的资源做了严格的控制，而</span><span style="font-size: 12pt;" lang="EN-US">ejb</span><span style="font-size: 12pt; font-family: 宋体;">不是直接引用</span><span style="font-size: 12pt;" lang="EN-US">JNDI</span><span style="font-size: 12pt; font-family: 宋体;">名，也为</span><span style="font-size: 12pt;" lang="EN-US">ejb</span><span style="font-size: 12pt; font-family: 宋体;">应用提供了一定的灵活性。</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt; text-indent: -18pt;"><!--[if !supportLists]--><span style="font-size: 14pt;" lang="EN-US">2．<span style="font-family: &quot;Times New Roman&quot;; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span></span><!--[endif]--><span style="font-size: 14pt;" lang="EN-US">EJB</span><span style="font-size: 14pt; font-family: 宋体;">调用</span><span style="font-size: 14pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">在同一容器调用</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">和远程调用</span><span style="font-size: 12pt;" lang="EN-US">EJB</span><span style="font-size: 12pt; font-family: 宋体;">有很大不同。同一容器中调用者与被调用者有相同的</span><span style="font-size: 12pt;" lang="EN-US">Context</span><span style="font-size: 12pt; font-family: 宋体;">，因此不需要额外设置，而在远程调用需要指定</span><span style="font-size: 12pt;" lang="EN-US">java.naming.factory.initial</span><span style="font-size: 12pt; font-family: 宋体;">和</span><span style="font-size: 12pt;" lang="EN-US">java.naming.provider.url</span><span style="font-size: 12pt; font-family: 宋体;">，另外还要部署时产生的</span><span style="font-size: 12pt;" lang="EN-US">client
jar</span><span style="font-size: 12pt; font-family: 宋体;">。</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">在调用</span><span style="font-size: 12pt;" lang="EN-US">PortableRemoteObject.narrow()</span><span style="font-size: 12pt; font-family: 宋体;">得到</span><span style="font-size: 12pt;" lang="EN-US">home</span><span style="font-size: 12pt; font-family: 宋体;">接口时抛出</span><span style="font-size: 12pt;" lang="EN-US">java.lang.ClassCastException<o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">一般将</span><span style="font-size: 12pt;" lang="EN-US">client
jar </span><span style="font-size: 12pt; font-family: 宋体;">放到</span><span style="font-size: 12pt;" lang="EN-US"> classpath</span><span style="font-size: 12pt; font-family: 宋体;">中就可以解决，这里主要用到的是</span><span style="font-size: 12pt;" lang="EN-US">remote</span><span style="font-size: 12pt; font-family: 宋体;">接口和</span><span style="font-size: 12pt;" lang="EN-US">home</span><span style="font-size: 12pt; font-family: 宋体;">接口的</span><span style="font-size: 12pt;" lang="EN-US">stub</span><span style="font-size: 12pt; font-family: 宋体;">。如果不将</span><span style="font-size: 12pt;" lang="EN-US">client jar </span><span style="font-size: 12pt; font-family: 宋体;">放到</span><span style="font-size: 12pt;" lang="EN-US">classpath</span><span style="font-size: 12pt; font-family: 宋体;">中也可以得到</span><span style="font-size: 12pt;" lang="EN-US">home</span><span style="font-size: 12pt; font-family: 宋体;">的接口，但由于使用了不同的</span><span style="font-size: 12pt;" lang="EN-US">classload</span><span style="font-size: 12pt; font-family: 宋体;">，在用</span><span style="font-size: 12pt;" lang="EN-US">PortableRemoteObject.narrow()</span><span style="font-size: 12pt; font-family: 宋体;">进行转型被视为不同的类而转型失败，我在用</span><span style="font-size: 12pt;" lang="EN-US">sun</span><span style="font-size: 12pt; font-family: 宋体;">的部署工具得到的</span><span style="font-size: 12pt;" lang="EN-US">
client jar</span><span style="font-size: 12pt; font-family: 宋体;">中竟然没有</span><span style="font-size: 12pt;" lang="EN-US">stub</span><span style="font-size: 12pt; font-family: 宋体;">（可能是部署文件的问题），所以远程调用始终不成功。</span><span style="font-size: 12pt;">
</span></p>


<p class="MsoNormal" style="margin-left: 18pt; text-indent: -18pt;"><!--[if !supportLists]--><span style="font-size: 14pt;" lang="EN-US">3．<span style="font-family: &quot;Times New Roman&quot;; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span></span><!--[endif]--><span style="font-size: 14pt; font-family: 宋体;">下一步学习的方向</span><span style="font-size: 14pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">继续研究远程对象是如何返回的</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt;" lang="EN-US">Classload </span><span style="font-size: 12pt; font-family: 宋体;">是如何工作的</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt;" lang="EN-US">JDBC</span><span style="font-size: 12pt; font-family: 宋体;">中关于分布式事务的处理方式</span><span style="font-size: 12pt;" lang="EN-US"><o:p></o:p></span></p>


<p class="MsoNormal" style="margin-left: 18pt;"><span style="font-size: 12pt; font-family: 宋体;">容器处理事务的规则</span></p>

<img src ="http://www.blogjava.net/JBahamut/aggbug/10841.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/JBahamut/" target="_blank">JBahamut</a> 2005-08-23 23:04 <a href="http://www.blogjava.net/JBahamut/archive/2005/08/23/10841.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>