<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>李文兵</title>
	<atom:link href="http://liwenbing.cn/feed/" rel="self" type="application/rss+xml" />
	<link>http://liwenbing.cn</link>
	<description>世界上最好最美的东西你看不见，也摸不着.......但是能在心里感受到</description>
	<lastBuildDate>Fri, 21 May 2010 00:56:29 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>&#8220;我从来不用if-else&#8230;&#8221;</title>
		<link>http://liwenbing.cn/2010/05/01/programming-without-if-else/</link>
		<comments>http://liwenbing.cn/2010/05/01/programming-without-if-else/#comments</comments>
		<pubDate>Sat, 01 May 2010 04:20:50 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[javascript]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=299</guid>
		<description><![CDATA[前几天，同事面试完回来哈哈大笑说，面试的人折腾了半天一个简单的程序没有搞定，还很牛逼哄哄地说我写程序从来不用if-else&#8230;连Mark同学听到也开心地笑了，呵呵 这几天路上无聊琢磨到底不用if-else怎么写程序，倒是想了几个办法。(使用JavaScript) 方法一：用while代替. function noifelsewhile&#40;condition&#41;&#123; while&#40;condition&#41;&#123; alert&#40;&#34;I'm Jack&#34;&#41;; break; &#125; while&#40;!condition&#41;&#123; alert&#40;&#34;I'm Rose&#34;&#41;; break; &#125; &#125; noifelsewhile&#40;true&#41;; noifelsewhile&#40;false&#41;; 方法二：用for代替. 和while一个套路 function noifelsefor&#40;condition&#41;&#123; for&#40;;condition;&#41;&#123; alert&#40;&#34;I'm Jack&#34;&#41; break; &#125; &#160; for&#40;;!condition;&#41;&#123; alert&#40;&#34;I'm Rose&#34;&#41;; break; &#125; &#125; noifelsefor&#40;true&#41;; noifelsefor&#40;false&#41;; 办法三:三元表达式 因为三元表达式只能使用表达式，所以需要使用一个function用来支持多行statements function noifelseternary&#40;condition&#41;&#123; condition?function&#40;&#41;&#123; alert&#40;&#34;I'm Jack&#34;&#41;; &#125;&#40;&#41;: function&#40;&#41;&#123; alert&#40;&#34;I'm Rose&#34;&#41;; &#125;&#40;&#41;; &#125; noifelseternary&#40;true&#41;; noifelseternary&#40;false&#41;; 办法四:逻辑与或-Default 在JavaScript中&#038;&#038;是logical and, 也可以称谓guard。如果第一个参数是false，那么返回第一个值，否则返回第二个值。而并不一定返回true或false； [...]]]></description>
			<content:encoded><![CDATA[<p>前几天，同事面试完回来哈哈大笑说，面试的人折腾了半天一个简单的程序没有搞定，还很牛逼哄哄地说我写程序从来不用if-else&#8230;连Mark同学听到也开心地笑了，呵呵</p>
<p>这几天路上无聊琢磨到底不用if-else怎么写程序，倒是想了几个办法。(使用JavaScript)</p>
<p><strong>方法一：用while代替.</strong></p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">function</span> noifelsewhile<span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
    <span style="color: #000066; font-weight: bold;">while</span><span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Jack&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #000066; font-weight: bold;">break</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    <span style="color: #000066; font-weight: bold;">while</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Rose&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #000066; font-weight: bold;">break</span><span style="color: #339933;">;</span>
   <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
noifelsewhile<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
noifelsewhile<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p><strong>方法二：用for代替.</strong><br />
和while一个套路</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">function</span> noifelsefor<span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
   <span style="color: #000066; font-weight: bold;">for</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">;</span>condition<span style="color: #339933;">;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Jack&quot;</span><span style="color: #009900;">&#41;</span>
	<span style="color: #000066; font-weight: bold;">break</span><span style="color: #339933;">;</span>
   <span style="color: #009900;">&#125;</span>
&nbsp;
   <span style="color: #000066; font-weight: bold;">for</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">;!</span>condition<span style="color: #339933;">;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Rose&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #000066; font-weight: bold;">break</span><span style="color: #339933;">;</span>
   <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
noifelsefor<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
noifelsefor<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p><strong>办法三:三元表达式</strong><br />
因为三元表达式只能使用表达式，所以需要使用一个function用来支持多行statements</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">function</span> noifelseternary<span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
    condition<span style="color: #339933;">?</span><span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		    <span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Jack&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">:</span>
		<span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		    <span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Rose&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
noifelseternary<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
noifelseternary<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p><strong>办法四:逻辑与或-Default</strong><br />
在JavaScript中&#038;&#038;是logical and, 也可以称谓guard。如果第一个参数是false，那么返回第一个值，否则返回第二个值。而并不一定返回true或false；</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">var</span> value <span style="color: #339933;">=</span> p <span style="color: #339933;">&amp;&amp;</span> p.<span style="color: #000066;">name</span><span style="color: #339933;">;</span> <span style="color: #006600; font-style: italic;">/* The name value will only be retrieved from p if p has a value, avoiding an error. */</span></pre></div></div>

<p>||是logical or，也可以成为default。如果第一个参数是false，那么返回第二个值，反则返回第一个只。同样并不是一定返回true或者false。</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;">value <span style="color: #339933;">=</span> v <span style="color: #339933;">||</span> <span style="color: #CC0000;">10</span><span style="color: #339933;">;</span> <span style="color: #006600; font-style: italic;">/* Use the value of v, but if v doesn't have a value, use 10 instead. */</span></pre></div></div>

<p>更多这个信息可以查看<a href="http://javascript.crockford.com/survey.html">A Survey of the JavaScript Programming Language</a>。<br />
好，现在就运用这个两个操作来模拟if-else</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">function</span> noifelsedefault<span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
 <span style="color: #009900;">&#40;</span>condition <span style="color: #339933;">||</span> 
	<span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Rose&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">&amp;&amp;</span> 
	<span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Jack&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
noifelsedefault<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
noifelsedefault<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p><strong>办法五:逻辑与或-Guard</strong><br />
这一次把&#038;&#038;放到前面。这种逻辑与或在其他语言也有，比如python中的and，or</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #003366; font-weight: bold;">function</span> noifelseguard<span style="color: #009900;">&#40;</span>condition<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
  <span style="color: #009900;">&#40;</span>condition <span style="color: #339933;">&amp;&amp;</span> 
	<span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Jack&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #000066; font-weight: bold;">return</span> <span style="color: #003366; font-weight: bold;">true</span><span style="color: #339933;">;</span> <span style="color: #006600; font-style: italic;">//注意一定要有return true，要保证这个函数返回true。</span>
                <span style="color: #006600; font-style: italic;">//其实办法4中需要保证第一个函数返回false，因为没有返回值就是null，所以就可以不用显式加return false了。</span>
	<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">||</span>
	<span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000066;">alert</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">&quot;I'm Rose&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
noifelseguard<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
noifelseguard<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>还有其他的办法吗？大家来变态~，:)<br />
五一快乐~</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2010/05/01/programming-without-if-else/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>WebSphere Application Server Feature Pack for Dynamic Scripting</title>
		<link>http://liwenbing.cn/2010/05/01/websphere-application-server-feature-pack-for-dynamic-scripting/</link>
		<comments>http://liwenbing.cn/2010/05/01/websphere-application-server-feature-pack-for-dynamic-scripting/#comments</comments>
		<pubDate>Sat, 01 May 2010 01:41:37 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[projectzero]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=301</guid>
		<description><![CDATA[The WAS feature pack (sMash Enterprise Packager) is LIVE！see IBM.com announcement letter， WebSphere Application Server Feature Pack for Dynamic Scripting. 终于将这baby从无到有，一步一步终于走了出来。很高兴能看到它成为zero现在的主要组成部分，想想自己也不是在做打杂的事情，在这半年迷茫的时间中有了些许的安慰。也最后要和sMash say goodbye了。希望sMash走好。]]></description>
			<content:encoded><![CDATA[<p>The WAS feature pack (sMash Enterprise Packager)  is <a href="http://www.projectzero.org/packager/">LIVE</a>！see <a href="http://www.ibm.com/common/ssi/cgi-bin/ssialias?infotype=an&amp;subtype=ca&amp;supplier=897&amp;appname=IBMLinkRedirect&amp;letternum=ENUS210-144">IBM.com  announcement letter</a>， <a href="http://www-01.ibm.com/software/webservers/appserv/was/featurepacks/dynamicscripting/">WebSphere  Application Server Feature Pack for Dynamic Scripting</a>.</p>
<p>终于将这baby从无到有，一步一步终于走了出来。很高兴能看到它成为zero现在的主要组成部分，想想自己也不是在做打杂的事情，在这半年迷茫的时间中有了些许的安慰。也最后要和sMash say goodbye了。希望sMash走好。</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2010/05/01/websphere-application-server-feature-pack-for-dynamic-scripting/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>站点终于恢复了</title>
		<link>http://liwenbing.cn/2010/01/31/%e7%ab%99%e7%82%b9%e7%bb%88%e4%ba%8e%e6%81%a2%e5%a4%8d%e4%ba%86/</link>
		<comments>http://liwenbing.cn/2010/01/31/%e7%ab%99%e7%82%b9%e7%bb%88%e4%ba%8e%e6%81%a2%e5%a4%8d%e4%ba%86/#comments</comments>
		<pubDate>Sun, 31 Jan 2010 13:29:50 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[blog]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=295</guid>
		<description><![CDATA[非常感谢redphp.net,这家host不错。虽然源于国内无耻的严打，经过一点折腾，终于回到正常。我一个小小blog就这么麻烦，真不知道国内那些网站怎么过来的。 希望国内互联网环境能恢复理性健康。]]></description>
			<content:encoded><![CDATA[<p>非常感谢redphp.net,这家host不错。虽然源于国内无耻的严打，经过一点折腾，终于回到正常。我一个小小blog就这么麻烦，真不知道国内那些网站怎么过来的。</p>
<p>希望国内互联网环境能恢复理性健康。</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2010/01/31/%e7%ab%99%e7%82%b9%e7%bb%88%e4%ba%8e%e6%81%a2%e5%a4%8d%e4%ba%86/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>用jconsole来管理WebSphere AppServer的MBean</title>
		<link>http://liwenbing.cn/2009/11/29/using-jconsole-in-websphere-application-server/</link>
		<comments>http://liwenbing.cn/2009/11/29/using-jconsole-in-websphere-application-server/#comments</comments>
		<pubDate>Sun, 29 Nov 2009 09:40:19 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[webpshere application server was jmx jconsole mbean RMI]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=289</guid>
		<description><![CDATA[最近需要在WebSphere中做点魔术，所以要使用WAS(WebSphere Application Server)中的管理能力。JMX是WAS的管理的核心，苦于WAS Mbean文档并不是那么详细，这个时候就可以使用jconsole了。jconsole是一个JDK自带的JMX兼容的JVM管理工具，可以用它来可视化的查看和操作Mbean。 在启动jconsole时需要一些WAS的jar，所以我这样来做： 1.创建一个文件夹，例如：C:\programs\jconsole 2.将一些需要的jar 拷贝进入到这个文件夹的libs中： com.ibm.ws.admin.client_6.1.0.jar   （在&#60;WAS_HOME&#62;/runtimes) ibmorbapi.jar  (在&#60;WAS_HOME&#62;/java/jre/lib) ibmorb.jar (在&#60;WAS_HOME&#62;/java/jre/lib) ibmcfw.jar (在&#60;WAS_HOME&#62;/java/jre/lib) 3.编写一个bat文件 set JAVA_HOME=&#34;C:\Program Files\Java\jdk1.6.0_16&#34; set WAS6.1_JARS=C:\programs\jconsole\libs &#160; set BOOTJARS=%WAS6.1_JARS%\ibmorbapi.jar set BOOTJARS=%BOOTJARS%;%WAS6.1_JARS%\ibmorb.jar set BOOTJARS=%BOOTJARS%;%WAS6.1_JARS%\ibmcfw.jar &#160; set CLASSPATH=%WAS6.1_JARS%\com.ibm.ws.admin.client_6.1.0.jar set CLASSPATH=%CLASSPATH%;%JAVA_HOME%\lib\tools.jar set CLASSPATH=%CLASSPATH%;%JAVA_HOME%\lib\jconsole.jar &#160; %JAVA_HOME%\bin\jconsole  -J-Xbootclasspath/p:%BOOTJARS% -J-Djava.class.path=%CLASSPATH% 4.使用如下URL来远程连接WAS中的JMX server service:jmx:iiop://localhost:2809/jndi/JMXConnector 其中这个端口号是RMI Connector的端口号，可以在启动的logs发现。 ADMC0026I:The RMI Connector is available at port 2809 或者到admin console中查看 [...]]]></description>
			<content:encoded><![CDATA[<p>最近需要在WebSphere中做点魔术，所以要使用WAS(WebSphere Application Server)中的管理能力。JMX是WAS的管理的核心，苦于<a href="http://publib.boulder.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=/com.ibm.websphere.javadoc.doc/public_html/mbeandocs/index.html" target="_blank">WAS Mbean文档</a>并不是那么详细，这个时候就可以使用jconsole了。jconsole是一个JDK自带的JMX兼容的JVM管理工具，可以用它来可视化的查看和操作Mbean。</p>
<p>在启动jconsole时需要一些WAS的jar，所以我这样来做：</p>
<p>1.创建一个文件夹，例如：C:\programs\jconsole</p>
<p>2.将一些需要的jar 拷贝进入到这个文件夹的libs中：</p>
<ul>
<li>com.ibm.ws.admin.client_6.1.0.jar   （在&lt;WAS_HOME&gt;/runtimes)</li>
<li>ibmorbapi.jar  (在&lt;WAS_HOME&gt;/java/jre/lib)</li>
<li>ibmorb.jar (在&lt;WAS_HOME&gt;/java/jre/lib)</li>
<li>ibmcfw.jar (在&lt;WAS_HOME&gt;/java/jre/lib)</li>
</ul>
<p>3.编写一个bat文件</p>

<div class="wp_syntax"><div class="code"><pre class="batch" style="font-family:monospace;">set JAVA_HOME=&quot;C:\Program Files\Java\jdk1.6.0_16&quot;
set WAS6.1_JARS=C:\programs\jconsole\libs
&nbsp;
set BOOTJARS=%WAS6.1_JARS%\ibmorbapi.jar
set BOOTJARS=%BOOTJARS%;%WAS6.1_JARS%\ibmorb.jar
set BOOTJARS=%BOOTJARS%;%WAS6.1_JARS%\ibmcfw.jar
&nbsp;
set CLASSPATH=%WAS6.1_JARS%\com.ibm.ws.admin.client_6.1.0.jar
set CLASSPATH=%CLASSPATH%;%JAVA_HOME%\lib\tools.jar
set CLASSPATH=%CLASSPATH%;%JAVA_HOME%\lib\jconsole.jar
&nbsp;
%JAVA_HOME%\bin\jconsole  -J-Xbootclasspath/p:%BOOTJARS% -J-Djava.class.path=%CLASSPATH%</pre></div></div>

<p>4.使用如下URL来远程连接WAS中的JMX server</p>
<pre>
service:jmx:iiop://localhost:2809/jndi/JMXConnector
</pre>
<p>其中这个端口号是RMI Connector的端口号，可以在启动的logs发现。</p>
<pre>ADMC0026I:The RMI Connector is available at port  2809
</pre>
<p>或者到admin console中查看<br />
Application servers &gt; server1 &gt;   Administration Services &gt; JMX   connectors</p>
<p>好，这样就可以了。</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/11/29/using-jconsole-in-websphere-application-server/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>一直在写</title>
		<link>http://liwenbing.cn/2009/09/14/keep-writing/</link>
		<comments>http://liwenbing.cn/2009/09/14/keep-writing/#comments</comments>
		<pubDate>Mon, 14 Sep 2009 15:25:15 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[blog]]></category>
		<category><![CDATA[life]]></category>
		<category><![CDATA[articles]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=282</guid>
		<description><![CDATA[刚和同学聊天时，问我blog怎么好长时间都没有更新了。看了看上篇文章的日期，离现在也有两个月有余了，有些惭愧。最近在做一些有意思的技术调研，倒是会在接下来的文章中分享一些。其实这段日子也在写一些东西，不过不在自己的blog上面了罢了。 带给PHP 和 Java 世界的双赢  (朱可&#38;me) -《 程序员》杂志 2009年09月刊 Ajax &#8211; 超越桌面的Web 用户体验 &#8211; 《WebSphere 中国》纸质杂志第二期 在WebSphere sMash中使用Dojo开发Ajax的Web应用程序 &#8211; developerWorks 时间总是匆匆，让我们继续前行&#8230;]]></description>
			<content:encoded><![CDATA[<p>刚和同学聊天时，问我blog怎么好长时间都没有更新了。看了看上篇文章的日期，离现在也有两个月有余了，有些惭愧。最近在做一些有意思的技术调研，倒是会在接下来的文章中分享一些。其实这段日子也在写一些东西，不过不在自己的blog上面了罢了。</p>
<ul>
<li>带给PHP 和 Java 世界的双赢  (<a href="http://www.netvibes.com/shawnzhu" target="_blank">朱可</a>&amp;me) -《 程序员》杂志 2009年09月刊</li>
<li>Ajax &#8211; 超越桌面的Web 用户体验 &#8211; 《<a href="http://www.webspherechina.net" target="_blank">WebSphere 中国</a>》纸质杂志第二期</li>
<li><a href="http://www.ibm.com/developerworks/cn/websphere/library/techarticles/0909_smash_dojo_Ajaxdev/index.html" target="_blank">在WebSphere sMash中使用Dojo开发Ajax的Web应用程序</a> &#8211; developerWorks</li>
</ul>
<p>时间总是匆匆，让我们继续前行&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/09/14/keep-writing/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>读《PPK on JavaScript》</title>
		<link>http://liwenbing.cn/2009/07/08/read-ppk-on-javascript/</link>
		<comments>http://liwenbing.cn/2009/07/08/read-ppk-on-javascript/#comments</comments>
		<pubDate>Tue, 07 Jul 2009 23:53:46 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[book]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[ppk javascript book accessability usability]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=269</guid>
		<description><![CDATA[PPK也是在JavaScript世界中的风云人物了，这位老兄对于浏览器端的技术以及各种浏览器的兼容性有极其丰富的经验。在这本书中，他谈了很多关于可访问性(Accessibility)和可用性(Usability)的一些问题，非常有趣。比如他说“不同的开发者以不同的方式诠释了JavaScript的目的。简单而形象地说就是：深受CSS革命影响的传统Web开发者们，创建的是瘦的、可访问性很强、乱糟糟的JavaScript代码；而来至服务器端开发的‘资深程序员们’用完美的面向对象代码、创建的是胖的、可访问性很差的Ajax客户端”。显然，ppk同学应该属于写乱糟糟但可访问性很好的人，而现在我做的大量事情却是后者。他更多相信现在的Ajax只是一种泡沫，当这个泡沫破灭并且大量‘资深服务器程序员’消失时，JS的开发者会更加注重可访问性。 可能体会不到ppk经历浏览器各种痛苦的经历，但是总体来说浏览器都在坚定地遵循Web标准，JavaScript的支持也会成为浏览器必备要求。anyway，事情总在发展，好戏在后头。分享一下我觉得这本书中几个有趣的地方。 可访问性和可用性 可访问性(Accessibility)是指你的网页对于任何人、在任何环境下都是可持续访问的。特别是指某些用户，比如弱视、浏览器不支持JavaScript或者另外一些情况，比如用户使用Mobile使用你的网页等等。而可用性(Usability)是指使用或者浏览你的网页的容易程度(这里我们只谈web页面),通常它指我们能更有效率地使用、更容易地学习以及更加满意地使用它。举个例子来说，你让你的web页面支持IE6，或者支持mobile都是在提高它的可访问性；而是用CSS来改善布局让用户更容易阅读、使用JavaScript做一些对用户有帮助的互动都是在提高它的可用性。 Web页面都是由下面三个层组成的，通过它们我们可以了解到它们之间的关系以及它们和可访问性和可用性之间的关系。 HTML结构层 CSS表现层 JavaScript行为层 Web页面的三个层，HTML结构层是必需的基础，CSS表现层和JavaScript行为层建于它之上。所以在客户端代码中不得不关注的话题就是这三个层的关注点分离。具体探讨一下这三个的分离： 表现与结构的分离(CSS与HTML) 这个分离很好理解，基本思想就是确保HTML来定义结构，而所有的表现都定义在另外单独的CSS文件中。HTML不应该出现&#60;font&#62;标签和用于表现的表格。如果想定义字体和布局，都应该在CSS中处理。 大部分情况下面我们知道达到某个效果是修改表现或者结构是清楚的。但是有些情况下当更改HTML和修改CSS都可以时，你需要慎重地思考到底哪种是合理的。比如一个节点，你希望它不显示，那么你可以在HTML上面删除该节点或者使用CSS来“display:none”。当这种情况是，需要自己分析所需要的效果属于哪种情况，然后修改合理的层。 行为与结构的分离(JavaScript与HTML) 这个也比较好理解，就是不要把任何的JavaScript代码写到你的HTML页面中。应该把所有JavaScript代码放到一个独立的js文件中，然后将它链入到所有需要它的HTML页面中。 关于这个有一个有趣的话题就是：无侵入脚本编程(unobtrusive scripting).简单来说它就是通过HTML和JavaScript的分离以达到页面的可访问性和可用性的最大化。既JavaScript失效了，页面还是可阅读和理解的；而通过引入脚本和JavaScript的hook，就可以让脚本运行，增强可用性。 行为与表现的分离(JavaScript与CSS) 这个的分离是非常复杂的，而且并没有总结出什么特别系统的规则。CSS和JavaScript是有重合的灰色地带的，有时候完全不能确切地把某个效果归为表现还是行为。比如是使用CSS中的hover还是JavaScript的mouseover/mouseout。基本来说你自己得根据具体情况做合理的选择吧。 事件捕捉模型 在HTML的事件模型中有一个有趣的话题。这个简单的问题就是：如果一个节点和它的父亲节点都有对同一个事件的处理，那么到底哪个事件会被先执行呢？这就是关于事件的冒泡和捕获。事件冒泡是说事件从它的目标元素开始，沿着文档树依次向上冒泡，并触发相应的事件处理函数。而事件的捕捉是刚好相反的，它从文档的第一级开始，然后沿着文档树向下游，知道事件目标为止。 在W3C模型中，捕获和冒泡都会发生。当一个事件触发时，它先被文档捕获，到了事件目标后，再冒泡到文档顶层。而传统模型和微软模型只支持事件冒泡，而不支持事件捕获。所以最好是限制使用事件冒泡。其实在我们的实际编程中，很少关心这个话题，是因为大部分情况我们都只使用了事件冒泡。 更加具体的可以查看ppk的文章：http://www.quirksmode.org/js/events_order.html 小记 应该来说PPK所谈的JavaScript是一个更加全面的浏览器编程的世界，让人可以全面来了解这个世界包含的东西。其实大部分的内容在PPK的网站上都有，值得读读。http://www.quirksmode.org/js/contents.html]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.quirksmode.org/" target="_blank">PPK</a>也是在JavaScript世界中的风云人物了，这位老兄对于浏览器端的技术以及各种浏览器的兼容性有极其丰富的经验。在这本书中，他谈了很多关于可访问性(Accessibility)和可用性(Usability)的一些问题，非常有趣。比如他说“不同的开发者以不同的方式诠释了JavaScript的目的。简单而形象地说就是：深受CSS革命影响的传统Web开发者们，创建的是瘦的、可访问性很强、乱糟糟的JavaScript代码；而来至服务器端开发的‘资深程序员们’用完美的面向对象代码、创建的是胖的、可访问性很差的Ajax客户端”。显然，ppk同学应该属于写乱糟糟但可访问性很好的人，而现在我做的大量事情却是后者。他更多相信现在的Ajax只是一种泡沫，当这个泡沫破灭并且大量‘资深服务器程序员’消失时，JS的开发者会更加注重可访问性。  可能体会不到ppk经历浏览器各种痛苦的经历，但是总体来说浏览器都在坚定地遵循Web标准，JavaScript的支持也会成为浏览器必备要求。anyway，事情总在发展，好戏在后头。分享一下我觉得这本书中几个有趣的地方。</p>
<h3>可访问性和可用性</h3>
<p>可访问性(<a href="http://en.wikipedia.org/wiki/Accessibility" target="_blank">Accessibility</a>)是指你的网页对于任何人、在任何环境下都是可持续访问的。特别是指某些用户，比如弱视、浏览器不支持JavaScript或者另外一些情况，比如用户使用Mobile使用你的网页等等。而可用性(Usability)是指使用或者浏览你的网页的容易程度(这里我们只谈web页面),通常它指我们能更有效率地使用、更容易地学习以及更加满意地使用它。举个例子来说，你让你的web页面支持IE6，或者支持mobile都是在提高它的可访问性；而是用CSS来改善布局让用户更容易阅读、使用JavaScript做一些对用户有帮助的互动都是在提高它的可用性。</p>
<p>Web页面都是由下面三个层组成的，通过它们我们可以了解到它们之间的关系以及它们和可访问性和可用性之间的关系。</p>
<ul>
<li>HTML结构层</li>
<li>CSS表现层</li>
<li>JavaScript行为层</li>
</ul>
<p><img class="alignnone size-medium wp-image-275" title="web3layers" src="http://liwenbing.cn/wp-content/uploads/2009/07/web3layers-300x245.PNG" alt="web3layers" width="300" height="245" /></p>
<p>Web页面的三个层，HTML结构层是必需的基础，CSS表现层和JavaScript行为层建于它之上。所以在客户端代码中不得不关注的话题就是这三个层的关注点分离。具体探讨一下这三个的分离：</p>
<p><strong>表现与结构的分离(CSS与HTML)</strong></p>
<p>这个分离很好理解，基本思想就是确保HTML来定义结构，而所有的表现都定义在另外单独的CSS文件中。HTML不应该出现&lt;font&gt;标签和用于表现的表格。如果想定义字体和布局，都应该在CSS中处理。</p>
<p>大部分情况下面我们知道达到某个效果是修改表现或者结构是清楚的。但是有些情况下当更改HTML和修改CSS都可以时，你需要慎重地思考到底哪种是合理的。比如一个节点，你希望它不显示，那么你可以在HTML上面删除该节点或者使用CSS来“display:none”。当这种情况是，需要自己分析所需要的效果属于哪种情况，然后修改合理的层。</p>
<p><strong>行为与结构的分离(JavaScript与HTML)</strong></p>
<p>这个也比较好理解，就是不要把任何的JavaScript代码写到你的HTML页面中。应该把所有JavaScript代码放到一个独立的js文件中，然后将它链入到所有需要它的HTML页面中。</p>
<p>关于这个有一个有趣的话题就是：<strong>无侵入脚本编程(unobtrusive scripting).</strong>简单来说它就是通过HTML和JavaScript的分离以达到页面的可访问性和可用性的最大化。既JavaScript失效了，页面还是可阅读和理解的；而通过引入脚本和JavaScript的hook，就可以让脚本运行，增强可用性。</p>
<p><strong>行为与表现的分离(JavaScript与CSS)</strong></p>
<p>这个的分离是非常复杂的，而且并没有总结出什么特别系统的规则。CSS和JavaScript是有重合的灰色地带的，有时候完全不能确切地把某个效果归为表现还是行为。比如是使用CSS中的hover还是JavaScript的mouseover/mouseout。基本来说你自己得根据具体情况做合理的选择吧。</p>
<h3>事件捕捉模型</h3>
<p>在HTML的事件模型中有一个有趣的话题。这个简单的问题就是：如果一个节点和它的父亲节点都有对同一个事件的处理，那么到底哪个事件会被先执行呢？这就是关于事件的冒泡和捕获。事件冒泡是说事件从它的目标元素开始，沿着文档树依次向上冒泡，并触发相应的事件处理函数。而事件的捕捉是刚好相反的，它从文档的第一级开始，然后沿着文档树向下游，知道事件目标为止。</p>
<p>在W3C模型中，捕获和冒泡都会发生。当一个事件触发时，它先被文档捕获，到了事件目标后，再冒泡到文档顶层。而传统模型和微软模型只支持事件冒泡，而不支持事件捕获。所以最好是限制使用事件冒泡。其实在我们的实际编程中，很少关心这个话题，是因为大部分情况我们都只使用了事件冒泡。</p>
<p>更加具体的可以查看ppk的文章：<a href="http://www.quirksmode.org/js/events_order.html" target="_blank">http://www.quirksmode.org/js/events_order.html</a></p>
<h3>小记</h3>
<p>应该来说PPK所谈的JavaScript是一个更加全面的浏览器编程的世界，让人可以全面来了解这个世界包含的东西。其实大部分的内容在PPK的网站上都有，值得读读。<a href="http://www.quirksmode.org/js/contents.html" target="_blank">http://www.quirksmode.org/js/contents.html</a></p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/07/08/read-ppk-on-javascript/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>一些UX的电子书</title>
		<link>http://liwenbing.cn/2009/07/02/some-ux-books/</link>
		<comments>http://liwenbing.cn/2009/07/02/some-ux-books/#comments</comments>
		<pubDate>Wed, 01 Jul 2009 23:55:04 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[book]]></category>
		<category><![CDATA[books]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[emotional design]]></category>
		<category><![CDATA[user experience]]></category>
		<category><![CDATA[users]]></category>
		<category><![CDATA[ux]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=235</guid>
		<description><![CDATA[最近找到了一系列的Ueser Experience方面的书籍，分享出来(点击图标下载)。自己还没有看了，希望能多看几本吧。有特别喜欢的书记得推荐一下.:)。 (Since there are too many downloads and make my website out of network bandwidth, I decide to remove them from my website. If you&#8217;re interested in some books, mailto me and I will share them to you. )]]></description>
			<content:encoded><![CDATA[<p>最近找到了一系列的Ueser Experience方面的书籍，分享出来(点击图标下载)。自己还没有看了，希望能多看几本吧。有特别喜欢的书记得推荐一下.:)。 (Since there are too many downloads and make my website out of network bandwidth, I decide to remove them from my website. If you&#8217;re interested in some books, <a href="mailto:wbinglee@gmail.com">mailto</a> me and I will share them to you. )</p>
<table border="0">
<tbody>
<tr>
<td>
<p><div id="attachment_249" class="wp-caption alignnone" style="width: 107px"><a href="http://liwenbing.cn/download/books/user_interface_design.pdf"><img class="size-full wp-image-249" title="User Interface Design" src="http://liwenbing.cn/wp-content/uploads/2009/06/user-interface-design.jpg" alt="User Interface Design" width="97" height="152" /></a><p class="wp-caption-text">User Interface Design</p></div></td>
<td>
<p><div id="attachment_248" class="wp-caption alignnone" style="width: 119px"><a href="http://liwenbing.cn/download/books/understanding_your_users.pdf"><img class="size-full wp-image-248" title="Understanding Your Users" src="http://liwenbing.cn/wp-content/uploads/2009/06/understanding-your-users.jpg" alt="Understanding Your Users" width="109" height="135" /></a><p class="wp-caption-text">Understanding Your Users</p></div></td>
<td>
<p><div id="attachment_247" class="wp-caption alignnone" style="width: 110px"><a href="http://liwenbing.cn/download/books/the_humane_interface.pdf"><img class="size-full wp-image-247" title="The Human  Interface" src="http://liwenbing.cn/wp-content/uploads/2009/06/the-humane-interface.jpg" alt="The Human  Interface" width="100" height="147" /></a><p class="wp-caption-text">The Human  Interface</p></div></td>
</tr>
<tr>
<td>
<p><div id="attachment_245" class="wp-caption alignnone" style="width: 118px"><a href="http://liwenbing.cn/download/books/observing_the_user_experience.pdf"><img class="size-full wp-image-245" title="Observing The User Experience" src="http://liwenbing.cn/wp-content/uploads/2009/06/observing-the-user-experience.jpg" alt="Observing The User Experience" width="108" height="136" /></a><p class="wp-caption-text">Observing The User Experience</p></div></td>
<td>
<p><div id="attachment_244" class="wp-caption alignnone" style="width: 115px"><a href="http://liwenbing.cn/download/books/information_architecture_for_the_world_wide_web.chm"><img class="size-full wp-image-244" title="Information Architecture For The World Wide Web" src="http://liwenbing.cn/wp-content/uploads/2009/06/information-architecture-for-the-world-wide-web.jpg" alt="Information Architecture For The World Wide Web" width="105" height="140" /></a><p class="wp-caption-text">Information Architecture For The World Wide Web</p></div></td>
<td>
<p><div id="attachment_243" class="wp-caption alignnone" style="width: 108px"><a href="http://liwenbing.cn/download/books/emotional_design.pdf"><img class="size-full wp-image-243" title="Emotional Design" src="http://liwenbing.cn/wp-content/uploads/2009/06/emotional_design.jpg" alt="Emotional Design" width="98" height="151" /></a><p class="wp-caption-text">Emotional Design</p></div></td>
</tr>
<tr>
<td>
<p><div id="attachment_242" class="wp-caption alignnone" style="width: 117px"><a href="http://liwenbing.cn/download/books/don%27t_make_me_think_.pdf"><img class="size-full wp-image-242" title="Don't Make Me Think" src="http://liwenbing.cn/wp-content/uploads/2009/06/dont_make_me_think.jpg" alt="Don't Make Me Think" width="107" height="138" /></a><p class="wp-caption-text">Don&#39;t Make Me Think</p></div></td>
<td>
<p><div id="attachment_241" class="wp-caption alignnone" style="width: 116px"><a href="http://liwenbing.cn/download/books/designing_web_navigation.pdf"><img class="size-full wp-image-241" title="Designing Web Navigation" src="http://liwenbing.cn/wp-content/uploads/2009/06/designing_web_navigation.jpg" alt="Designing Web Navigation" width="106" height="139" /></a><p class="wp-caption-text">Designing Web Navigation</p></div></td>
<td>
<p><div id="attachment_240" class="wp-caption alignnone" style="width: 109px"><a href="http://liwenbing.cn/download/books/designing_the_obvious.pdf"><img class="size-full wp-image-240" title="Designing the obvious" src="http://liwenbing.cn/wp-content/uploads/2009/06/designing-the-obvious.jpg" alt="Designing the obvious" width="99" height="149" /></a><p class="wp-caption-text">Designing the obvious</p></div></td>
</tr>
<tr>
<td>
<p><div id="attachment_238" class="wp-caption alignnone" style="width: 108px"><a href="http://liwenbing.cn/download/books/design_of_everyday_things--norman_donald.pdf"><img class="size-full wp-image-238" title="Design of Everyday Things" src="http://liwenbing.cn/wp-content/uploads/2009/06/design_of_everyday_things.jpg" alt="Design of Everyday Things" width="98" height="150" /></a><p class="wp-caption-text">Design of Everyday Things</p></div></td>
<td>
<p><div id="attachment_237" class="wp-caption alignnone" style="width: 113px"><a href="http://liwenbing.cn/download/books/about_face3.pdf"><img class="size-full wp-image-237" title="About Face 3.0" src="http://liwenbing.cn/wp-content/uploads/2009/06/aboutface3.jpg" alt="About Face 3.0" width="103" height="144" /></a><p class="wp-caption-text">About Face 3.0</p></div></td>
<td>
<p><div id="attachment_236" class="wp-caption alignnone" style="width: 118px"><a href="http://liwenbing.cn/download/books/about_face2.chm"><img class="size-full wp-image-236" title="About Face 2.0" src="http://liwenbing.cn/wp-content/uploads/2009/06/aboutface2.jpg" alt="About Face 2.0" width="108" height="136" /></a><p class="wp-caption-text">About Face 2.0</p></div></td>
</tr>
</tbody>
</table>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/07/02/some-ux-books/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>蓝色的血液</title>
		<link>http://liwenbing.cn/2009/06/18/blue-blood/</link>
		<comments>http://liwenbing.cn/2009/06/18/blue-blood/#comments</comments>
		<pubDate>Wed, 17 Jun 2009 16:51:16 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[thought]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=230</guid>
		<description><![CDATA[我是一名pure blue，从在IBM实习到开始工作到现在，在这样的一家百年老店工作，虽然有太多让人抱怨的地方，但是你会喜欢这里的人（虽然不是全部），并且从心里慢慢接受它的文化和价值观。这样的一个公司的价值观是令人敬佩的，足以指导你做人做事。特别不喜欢一些人张口闭口说这不如人那不爽，只怕自己没有自信罢了。不足就努力去改变它，你真受不了了就quit，what&#8217;s the big deal？一个人在外人面前骂娘（自己老娘）的时候，是不可能得到尊重的，只是哗众取宠罢了。当你流淌着蓝色的血液时，你是自豪的。 今早一聊天之不爽，故有此文。下面摘除一些从《品味蓝色》上句子。我很喜欢。 任何一名优秀的IBM人，当你问他成功之道的时候，他也许无法教会你具体的流程和方法，但他一定会告诉你，没有什么，不过是秉承诚信负责之道好好做人、好好做事罢了，因为在IBM，机会永远青睐于那些有好的工作表现和正直诚实的人。 &#8212; 周伟焜 学会尊重别人，同时赢得别人尊重，这很重要。尊重别人身上的优点，你会变得更宽容。执着、专业、深入是赢得他人尊重的根本。谁都有缺点，包括我们的公司。但是要学会用宽容的心来对待周围的一切。得到尊重，你每天都会快乐。 &#8212; 郭希文 所谓分享成功其实就是看你怎样Increase your influence，这并不是仅指依靠手中的权力发号施令，而是指能够提供给别人有价值的意见或见地。同时，在团队合作中，“诚信（integrity）”则是最重要的原则。无论对公司，还是对在公司团队中工作的个体，诚信都是立足之本，信任之基。对一个科学家来说，诚信就更重要，科学是不容半点虚假成分的，谁想投机取巧，违背科学规律，只能是搬起石头砸自己的脚。&#8211; 叶天正 认真积极地工作，让我在事业上可以不断进步；以尊重、信任的态度与家人、同事沟通，让我得到了家人的支持，同事的尊敬，从而拥有了和谐美满的家庭和成功的事业。面对这一切，我最深的感受就是四个字——“知福惜福”。 &#8211;于雪莉]]></description>
			<content:encoded><![CDATA[<p>我是一名pure blue，从在IBM实习到开始工作到现在，在这样的一家百年老店工作，虽然有太多让人抱怨的地方，但是你会喜欢这里的人（虽然不是全部），并且从心里慢慢接受它的文化和价值观。这样的一个公司的价值观是令人敬佩的，足以指导你做人做事。特别不喜欢一些人张口闭口说这不如人那不爽，只怕自己没有自信罢了。不足就努力去改变它，你真受不了了就quit，what&#8217;s the big deal？一个人在外人面前骂娘（自己老娘）的时候，是不可能得到尊重的，只是哗众取宠罢了。当你流淌着蓝色的血液时，你是自豪的。</p>
<p>今早一聊天之不爽，故有此文。下面摘除一些从《品味蓝色》上句子。我很喜欢。</p>
<blockquote><p>任何一名优秀的IBM人，当你问他成功之道的时候，他也许无法教会你具体的流程和方法，但他一定会告诉你，没有什么，不过是秉承诚信负责之道好好做人、好好做事罢了，因为在IBM，机会永远青睐于那些有好的工作表现和正直诚实的人。 &#8212; 周伟焜</p></blockquote>
<blockquote><p>学会尊重别人，同时赢得别人尊重，这很重要。尊重别人身上的优点，你会变得更宽容。执着、专业、深入是赢得他人尊重的根本。谁都有缺点，包括我们的公司。但是要学会用宽容的心来对待周围的一切。得到尊重，你每天都会快乐。 &#8212; 郭希文</p></blockquote>
<blockquote><p>所谓分享成功其实就是看你怎样Increase your influence，这并不是仅指依靠手中的权力发号施令，而是指能够提供给别人有价值的意见或见地。同时，在团队合作中，“诚信（integrity）”则是最重要的原则。无论对公司，还是对在公司团队中工作的个体，诚信都是立足之本，信任之基。对一个科学家来说，诚信就更重要，科学是不容半点虚假成分的，谁想投机取巧，违背科学规律，只能是搬起石头砸自己的脚。&#8211; 叶天正</p></blockquote>
<blockquote><p>认真积极地工作，让我在事业上可以不断进步；以尊重、信任的态度与家人、同事沟通，让我得到了家人的支持，同事的尊敬，从而拥有了和谐美满的家庭和成功的事业。面对这一切，我最深的感受就是四个字——“知福惜福”。 &#8211;于雪莉</p></blockquote>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/06/18/blue-blood/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>sMash Stakeholder Meeting</title>
		<link>http://liwenbing.cn/2009/06/17/smash-stakeholder-meeting/</link>
		<comments>http://liwenbing.cn/2009/06/17/smash-stakeholder-meeting/#comments</comments>
		<pubDate>Wed, 17 Jun 2009 15:41:37 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[projectzero]]></category>
		<category><![CDATA[video]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=224</guid>
		<description><![CDATA[上周进行了sMash的stakeholder meeting，在这个会上我介绍了Flow的新的特性，并且进行Demo的演示。我们的演示大概从5分钟开始，之前是产品开发经理的一些介绍。本人英文口语比较烂，不知道他们到底听懂了没有。详细的信息可以看projectzero 的blog。Vido在Viddler上，至于为什么在viddler上，我想可能是为了照顾中国用户无法访问YouTube的原因吧，呵呵。 http://www.viddler.com/explore/projectzero/videos/4/]]></description>
			<content:encoded><![CDATA[<p>上周进行了sMash的stakeholder meeting，在这个会上我介绍了Flow的新的特性，并且进行Demo的演示。我们的演示大概从5分钟开始，之前是产品开发经理的一些介绍。本人英文口语比较烂，不知道他们到底听懂了没有。详细的信息可以看<a href="http://www.projectzero.org/blog/index.php/2009/06/15/june-stakeholder-meeting-replay/" target="_blank">projectzero 的blog</a>。Vido在Viddler上，至于为什么在viddler上，我想可能是为了照顾中国用户无法访问YouTube的原因吧，呵呵。</p>
<p><a href="http://www.viddler.com/explore/projectzero/videos/4/" target="_blank">http://www.viddler.com/explore/projectzero/videos/4/</a><br />
<object width="437" height="288" data="http://www.viddler.com/player/bbc71748/" type="application/x-shockwave-flash"><param name="id" value="viddler" /><param name="allowScriptAccess" value="always" /><param name="allowFullScreen" value="true" /><param name="src" value="http://www.viddler.com/player/bbc71748/" /><param name="name" value="viddler" /><param name="allowfullscreen" value="true" /></object></p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/06/17/smash-stakeholder-meeting/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Dojo widget的析构过程</title>
		<link>http://liwenbing.cn/2009/06/05/dojo-widget-destructor/</link>
		<comments>http://liwenbing.cn/2009/06/05/dojo-widget-destructor/#comments</comments>
		<pubDate>Fri, 05 Jun 2009 11:09:13 +0000</pubDate>
		<dc:creator>liwenbing</dc:creator>
				<category><![CDATA[javascript]]></category>
		<category><![CDATA[javascript dojo dijit widget destructor]]></category>

		<guid isPermaLink="false">http://liwenbing.cn/?p=204</guid>
		<description><![CDATA[了解dojo widget（或者说dijit）的析构过程，不仅让你更加了解整个dijit的生命周期，同样也能帮助我们在自己定制化的dijit中如何正确地释放资源。（这里讨论的dojo应该是在0.9或者以上版本的) 下面是dijit的析构过程： destroyRecursive / \ destroy destroyDescendants / &#124; \ uninitialize disconnect&#40;&#41; destroyRendering 一些常见的错误是如下： 使用destroy()去销毁一个dijit。我们应该使用destroyRecursive()去销毁一个dijit，从上面的过程可以看出，destroyRecursive()会销毁其孩子widgets。 使用destory()去销毁定制dijit中的资源。更可怕的是有的代码可能是直接覆盖destroy，而根本不调用_Widget中的destory。uninitialize()才是dijit暴露出来给定制化widget进行析构的stub function。 结论 使用destroyRecursive()去销毁dijit，使用uninitialize()在定制化的dijit来释放自己的资源。destroyDescendants，destroyRendering基本上用不到，也不要去覆盖它们。]]></description>
			<content:encoded><![CDATA[<p>了解dojo widget（或者说dijit）的析构过程，不仅让你更加了解整个dijit的生命周期，同样也能帮助我们在自己定制化的dijit中如何正确地释放资源。（这里讨论的dojo应该是在0.9或者以上版本的)</p>
<p>下面是dijit的析构过程：</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;">                        destroyRecursive
                    <span style="color: #339933;">/</span>                      \
                destroy                   destroyDescendants
        <span style="color: #339933;">/</span>        <span style="color: #339933;">|</span>        \
uninitialize  disconnect<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> destroyRendering</pre></div></div>

<p>一些常见的<strong>错误</strong>是如下：</p>
<ul>
<li>使用destroy()去销毁一个dijit。我们应该使用destroyRecursive()去销毁一个dijit，从上面的过程可以看出，destroyRecursive()会销毁其孩子widgets。</li>
<li>使用destory()去销毁定制dijit中的资源。更可怕的是有的代码可能是直接覆盖destroy，而根本不调用_Widget中的destory。uninitialize()才是dijit暴露出来给定制化widget进行析构的stub function。</li>
</ul>
<h3>结论</h3>
<p><strong>使用destroyRecursive()去销毁dijit，使用uninitialize()在定制化的dijit来释放自己的资源</strong>。destroyDescendants，destroyRendering基本上用不到，也不要去覆盖它们。</p>
]]></content:encoded>
			<wfw:commentRss>http://liwenbing.cn/2009/06/05/dojo-widget-destructor/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
