﻿<?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-J2EE之巅</title><link>http://www.blogjava.net/chaocai/</link><description /><language>zh-cn</language><lastBuildDate>Mon, 20 Apr 2026 11:47:42 GMT</lastBuildDate><pubDate>Mon, 20 Apr 2026 11:47:42 GMT</pubDate><ttl>60</ttl><item><title>The Clojure Program To solve N Queens Problem (Without back tracing)</title><link>http://www.blogjava.net/chaocai/archive/2012/11/26/Clojure.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Mon, 26 Nov 2012 04:21:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2012/11/26/Clojure.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/391968.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2012/11/26/Clojure.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/391968.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/391968.html</trackback:ping><description><![CDATA[Not like the previous solution here&nbsp;http://www.blogjava.net/chaocai/archive/2012/08/05/384844.html<br />The following solution not using the back tracing way is more concise and readable, but for the searching space becomes huger, the performance is much worser then the previous one.<br /><br /><span style="background-color: #eeeeee; font-size: 13px; ">(ns&nbsp;SICP.unit3)</span><div style="background-color:#eeeeee;font-size:13px;border:1px solid #CCCCCC;padding-right: 5px;padding-bottom: 4px;padding-left: 4px;padding-top: 4px;width: 98%;word-break:break-all">(defn&nbsp;conflictInCol?&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">s&nbsp;col</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;(<span style="color: #808080; ">some</span>&nbsp;#(<span style="color: #808080; ">=</span>&nbsp;col&nbsp;<span style="color: #808080; ">%</span>)&nbsp;s)<br />)<br /><br />(defn&nbsp;conflictInDia?&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">s&nbsp;col</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;(let&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">dia&nbsp;(count&nbsp;s)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;n1&nbsp;(fn&nbsp;[c</span><span style="color: #FF0000; ">]</span>&nbsp;(Math<span style="color: #808080; ">/</span><span style="color: #FF00FF; ">abs</span>&nbsp;(<span style="color: #808080; ">-</span>&nbsp;dia&nbsp;(.indexOf&nbsp;s&nbsp;c))))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;n2&nbsp;(fn&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">c</span><span style="color: #FF0000; ">]</span>&nbsp;(Math<span style="color: #808080; ">/</span><span style="color: #FF00FF; ">abs</span>&nbsp;(<span style="color: #808080; ">-</span>&nbsp;col&nbsp;c)))]<br />&nbsp;&nbsp;&nbsp;&nbsp;(<span style="color: #808080; ">some</span>&nbsp;#(<span style="color: #808080; ">=</span>&nbsp;(n1&nbsp;<span style="color: #808080; ">%</span>)&nbsp;(n2&nbsp;<span style="color: #808080; ">%</span>))&nbsp;s)<br />&nbsp;&nbsp;)<br />)<br /><br />(defn&nbsp;safe?&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">s&nbsp;col</span><span style="color: #FF0000; ">]</span>&nbsp;<br />&nbsp;&nbsp;(<span style="color: #808080; ">not</span>&nbsp;(<span style="color: #808080; ">or</span>&nbsp;(conflictInCol?&nbsp;s&nbsp;col)&nbsp;(conflictInDia?&nbsp;s&nbsp;col)))<br />)<br />&nbsp;&nbsp;<br />(defn&nbsp;<span style="color: #0000FF; ">next</span><span style="color: #808080; ">-</span><span style="color: #0000FF; ">level</span><span style="color: #808080; ">-</span>queens&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">solutions-for-prev-level&nbsp;board-size&nbsp;current-level</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;(let&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">solutions&nbsp;(atom&nbsp;[</span><span style="color: #FF0000; ">]</span>)]<br />&nbsp;&nbsp;&nbsp;&nbsp;(doseq&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">s&nbsp;solutions-for-prev-level</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(doseq&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">col&nbsp;(range&nbsp;0&nbsp;board-size)</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(<span style="color: #0000FF; ">if</span>&nbsp;(safe?&nbsp;s&nbsp;col)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(reset!&nbsp;solutions&nbsp;(cons&nbsp;(conj&nbsp;s&nbsp;col)&nbsp;<span style="color: #008000; ">@solutions</span>))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br />&nbsp;&nbsp;&nbsp;<br />&nbsp;&nbsp;&nbsp;&nbsp;)<br />&nbsp;&nbsp;&nbsp;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(<span style="color: #0000FF; ">if</span>&nbsp;(<span style="color: #808080; ">&lt;</span>&nbsp;<span style="color: #0000FF; ">current</span><span style="color: #808080; ">-</span><span style="color: #0000FF; ">level</span>&nbsp;(<span style="font-weight: bold; ">dec</span>&nbsp;board<span style="color: #808080; ">-</span>size))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(recur&nbsp;<span style="color: #008000; ">@solutions</span>&nbsp;board<span style="color: #808080; ">-</span>size&nbsp;(inc&nbsp;<span style="color: #0000FF; ">current</span><span style="color: #808080; ">-</span><span style="color: #0000FF; ">level</span>))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(<span style="color: #FF00FF; ">count</span>&nbsp;<span style="color: #008000; ">@solutions</span>)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br />&nbsp;&nbsp;&nbsp;)<br />)<br /><br />(defn&nbsp;queens&nbsp;<span style="color: #FF0000; ">[</span><span style="color: #FF0000; ">board-size</span><span style="color: #FF0000; ">]</span><br />&nbsp;&nbsp;(<span style="color: #0000FF; ">next</span><span style="color: #808080; ">-</span><span style="color: #0000FF; ">level</span><span style="color: #808080; ">-</span>queens&nbsp;&nbsp;(apply&nbsp;vector&nbsp;(map&nbsp;#(vector&nbsp;<span style="color: #808080; ">%</span>)&nbsp;(range&nbsp;<span style="color: #800000; font-weight: bold; ">0</span>&nbsp;board<span style="color: #808080; ">-</span>size)))&nbsp;board<span style="color: #808080; ">-</span>size&nbsp;<span style="color: #800000; font-weight: bold; ">1</span>)</div><span style="background-color: #eeeeee; font-size: 13px; ">)<br /><br />Chao Cai (蔡超）<br />Sr. SDE<br />Amazon<br /><br /></span><br />&nbsp;<img src ="http://www.blogjava.net/chaocai/aggbug/391968.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2012-11-26 12:21 <a href="http://www.blogjava.net/chaocai/archive/2012/11/26/Clojure.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Clojure XPath</title><link>http://www.blogjava.net/chaocai/archive/2012/10/15/ClojureXPath.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Mon, 15 Oct 2012 02:15:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2012/10/15/ClojureXPath.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/389555.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2012/10/15/ClojureXPath.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/389555.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/389555.html</trackback:ping><description><![CDATA[<div><div>The functions to support using XPath in Clojure.</div><h1>Source Code</h1><div style="background-color:#eeeeee;font-size:13px;border:1px solid #CCCCCC;padding-right: 5px;padding-bottom: 4px;padding-left: 4px;padding-top: 4px;width: 98%;word-break:break-all"><span style="color: #008080; ">&nbsp;1</span>&nbsp;<span style="color: #000000; ">;The&nbsp;code&nbsp;was&nbsp;implemented&nbsp;by&nbsp;caichao@amazon.com<br /></span><span style="color: #008080; ">&nbsp;2</span>&nbsp;<span style="color: #000000; ">;You&nbsp;could&nbsp;use&nbsp;the&nbsp;code&nbsp;anyway,&nbsp;but&nbsp;should&nbsp;keep&nbsp;the&nbsp;comments<br /></span><span style="color: #008080; ">&nbsp;3</span>&nbsp;<span style="color: #000000; ">;Created&nbsp;</span><span style="color: #000000; ">2012.10</span><span style="color: #000000; "><br /></span><span style="color: #008080; ">&nbsp;4</span>&nbsp;<span style="color: #000000; ">(ns&nbsp;clojure.ccsoft.xml<br /></span><span style="color: #008080; ">&nbsp;5</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;(:require&nbsp;[clojure.xml&nbsp;:as&nbsp;xml]))<br /></span><span style="color: #008080; ">&nbsp;6</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">&nbsp;7</span>&nbsp;<span style="color: #000000; ">(</span><span style="color: #0000FF; ">import</span>&nbsp;<span style="color: #000000; ">'</span><span style="color: #000000; ">(java.io&nbsp;StringReader)</span><span style="color: #000000; "><br /></span><span style="color: #008080; ">&nbsp;8</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">'</span><span style="color: #000000; ">(java.io&nbsp;ByteArrayInputStream))</span><span style="color: #000000; "><br /></span><span style="color: #008080; ">&nbsp;9</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">10</span>&nbsp;<span style="color: #000000; ">(defn&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">structure&nbsp;[xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">txt]&nbsp;<br /></span><span style="color: #008080; ">11</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;[&nbsp;(xml</span><span style="color: #000000; ">/</span><span style="color: #000000; ">parse&nbsp;(</span><span style="color: #000000; ">-&gt;</span><span style="color: #000000; ">&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">txt<br /></span><span style="color: #008080; ">12</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(.getBytes)<br /></span><span style="color: #008080; ">13</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(ByteArrayInputStream.)<br /></span><span style="color: #008080; ">14</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">15</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;)]<br /></span><span style="color: #008080; ">16</span>&nbsp;<span style="color: #000000; ">)<br /></span><span style="color: #008080; ">17</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">18</span>&nbsp;<span style="color: #000000; ">(defn&nbsp;node&nbsp;[tag&nbsp;xmlStruct]<br /></span><span style="color: #008080; ">19</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">20</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;(first&nbsp;(filter&nbsp;#(</span><span style="color: #000000; ">=</span><span style="color: #000000; ">&nbsp;(:tag&nbsp;</span><span style="color: #000000; ">%</span><span style="color: #000000; ">)&nbsp;tag)&nbsp;(:content&nbsp;xmlStruct)))<br /></span><span style="color: #008080; ">21</span>&nbsp;<span style="color: #000000; ">)<br /></span><span style="color: #008080; ">22</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">23</span>&nbsp;<span style="color: #000000; ">(defn&nbsp;node&nbsp;[path&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">txt]<br /></span><span style="color: #008080; ">24</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;(loop&nbsp;[path&nbsp;path&nbsp;<br /></span><span style="color: #008080; ">25</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">content&nbsp;(xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">structure&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">txt)&nbsp;<br /></span><span style="color: #008080; ">26</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;]<br /></span><span style="color: #008080; ">27</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(let&nbsp;[current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">tag&nbsp;(first&nbsp;path)&nbsp;current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">elem&nbsp;(first&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">content)]<br /></span><span style="color: #008080; ">28</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(</span><span style="color: #0000FF; ">if</span><span style="color: #000000; ">&nbsp;(</span><span style="color: #000000; ">=</span><span style="color: #000000; ">&nbsp;(:tag&nbsp;current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">elem&nbsp;)&nbsp;current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">tag)<br /></span><span style="color: #008080; ">29</span>&nbsp;<span style="color: #000000; ">&nbsp;<br /></span><span style="color: #008080; ">30</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(</span><span style="color: #0000FF; ">if</span><span style="color: #000000; ">&nbsp;(</span><span style="color: #000000; ">=</span><span style="color: #000000; ">&nbsp;(count&nbsp;path)&nbsp;</span><span style="color: #000000; ">1</span><span style="color: #000000; ">)<br /></span><span style="color: #008080; ">31</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">elem&nbsp;<br /></span><span style="color: #008080; ">32</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(recur&nbsp;&nbsp;(rest&nbsp;path)&nbsp;(:content&nbsp;current</span><span style="color: #000000; ">-</span><span style="color: #000000; ">elem&nbsp;))<br /></span><span style="color: #008080; ">33</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">34</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(</span><span style="color: #0000FF; ">if</span><span style="color: #000000; ">&nbsp;(</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; ">&nbsp;(count&nbsp;&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">content)&nbsp;</span><span style="color: #000000; ">1</span><span style="color: #000000; ">)<br /></span><span style="color: #008080; ">35</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(recur&nbsp;path&nbsp;&nbsp;(rest&nbsp;xml</span><span style="color: #000000; ">-</span><span style="color: #000000; ">content))<br /></span><span style="color: #008080; ">36</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">37</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">38</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">39</span>&nbsp;<span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;)<br /></span><span style="color: #008080; ">40</span>&nbsp;<span style="color: #000000;">&nbsp;)<br /><br /></span><h1><span style="color: #000000;">How to Use</span></h1><div style="background-color:#eeeeee;font-size:13px;border:1px solid #CCCCCC;padding-right: 5px;padding-bottom: 4px;padding-left: 4px;padding-top: 4px;width: 98%;word-break:break-all"><span style="color: #000000; ">(def&nbsp;cmd</span><span style="color: #000000; ">-</span><span style="color: #000000; ">example&nbsp;</span><span style="color: #000000; ">"</span><span style="color: #000000; ">&lt;command&gt;</span><span style="color: #000000; "><br /></span><span style="color: #000000; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;</span><span style="color: #000000; ">header</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;</span><span style="color: #000000; ">type</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; ">script</span><span style="color: #000000; ">&lt;/</span><span style="color: #000000; ">type</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;</span><span style="color: #000000; ">transaction_id</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; ">12345</span><span style="color: #000000; ">&lt;/</span><span style="color: #000000; ">transaction_id</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;/</span><span style="color: #000000; ">header</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;</span><span style="color: #000000; ">body</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;println&nbsp;</span><span style="color: #000000; ">3</span><span style="color: #000000; ">+</span><span style="color: #000000; ">4</span><span style="color: #000000; ">;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;/</span><span style="color: #000000; ">body</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; "><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #000000; ">&lt;/</span><span style="color: #000000; ">command</span><span style="color: #000000; ">&gt;</span><span style="color: #000000; ">"</span><span style="color: #000000; ">)</span><span style="color: #000000; "><br /></span><span style="color: #000000; ">&nbsp;<br />&nbsp;<br />(node&nbsp;[:command&nbsp;:header&nbsp;:transaction_id]&nbsp;cmd</span><span style="color: #000000; ">-</span><span style="color: #000000; ">example)</span></div><h1><span style="color: #000000; "><br /></span></h1></div></div><img src ="http://www.blogjava.net/chaocai/aggbug/389555.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2012-10-15 10:15 <a href="http://www.blogjava.net/chaocai/archive/2012/10/15/ClojureXPath.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>The Clojure Program To solve N Queens Problem</title><link>http://www.blogjava.net/chaocai/archive/2012/08/05/384844.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Sun, 05 Aug 2012 15:26:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2012/08/05/384844.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/384844.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2012/08/05/384844.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/384844.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/384844.html</trackback:ping><description><![CDATA[<div>The following program is about solving N-Queens problem (http://en.wikipedia.org/wiki/Eight_queens_puzzle) by Clojure. If you have the better solution in Clojure or Haskell, welcome to provide your solution.<br />
(ns queens)</div>
<div>(defn conflictInRow? [queens newqueen]</div>
<div>&nbsp; (some #(= newqueen %) queens)</div>
<div>)</div>
<div></div>
<div>(defn conflictInDia? [queens newqueen]</div>
<div>&nbsp; (let [dia (count queens)&nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; n1 (fn [queen] (Math/abs (- dia (.indexOf queens queen))))</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; n2 (fn [queen] (Math/abs (- newqueen queen)))]</div>
<div>&nbsp; &nbsp; (some #(= (n1 %) (n2 %)) queens)</div>
<div>&nbsp; &nbsp;)</div>
<div>&nbsp;)</div>
<div></div>
<div>(defn conflict? [queens newqueen]</div>
<div>&nbsp; (or (conflictInRow? queens newqueen) (conflictInDia? queens newqueen))</div>
<div>&nbsp;)</div>
<div></div>
<div>(def cnt (atom 0))</div>
<div></div>
<div>(defn put-queens [queens newqueen boardSize ]</div>
<div></div>
<div>&nbsp; (if (= (count queens) boardSize) &nbsp;</div>
<div>&nbsp; &nbsp; (do</div>
<div>&nbsp; &nbsp; &nbsp; (println queens)</div>
<div>&nbsp; &nbsp; &nbsp; (reset! cnt (inc @cnt))</div>
<div>&nbsp; &nbsp; )</div>
<div>&nbsp; &nbsp; (do&nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; ;(println queens)</div>
<div>&nbsp; &nbsp; &nbsp; (if (&gt; newqueen boardSize)</div>
<div>&nbsp; &nbsp; &nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(if (and (= (peek queens) boardSize) (= (count queens) 1))</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(throw (Exception. (str "That's all " @cnt)))</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(recur (pop queens) (inc (peek queens)) boardSize )</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;)</div>
<div>&nbsp; &nbsp; &nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; (if (conflict? queens newqueen)</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(recur queens (inc newqueen) boardSize )</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; (do</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(put-queens (conj queens newqueen) 1 boardSize )</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;(recur queens (inc newqueen) boardSize )</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;)</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; )</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp;)</div>
<div>&nbsp; &nbsp; &nbsp; )</div>
<div>&nbsp; &nbsp; )</div>
<div>&nbsp; &nbsp;&nbsp;</div>
<div>)</div>
<div></div>
<div></div>
<div></div>
<div>(defn queens [boardSize]&nbsp;</div>
<div>&nbsp; &nbsp; (put-queens [] 1 boardSize)</div>
<div>&nbsp;)<br /><br /><br />Chao Cai (蔡超）</div>
<div><br />Sr. Software Dev Engineer&nbsp;<br />Amazon.com<br /><br /></div>
<div>&nbsp;</div>
<div></div><img src ="http://www.blogjava.net/chaocai/aggbug/384844.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2012-08-05 23:26 <a href="http://www.blogjava.net/chaocai/archive/2012/08/05/384844.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Spring AOP on Annotation</title><link>http://www.blogjava.net/chaocai/archive/2011/06/07/351844.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Tue, 07 Jun 2011 03:34:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2011/06/07/351844.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/351844.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2011/06/07/351844.html#Feedback</comments><slash:comments>3</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/351844.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/351844.html</trackback:ping><description><![CDATA[<div>1 The annotation:<br />@Retention(RetentionPolicy.RUNTIME)<br />@Target(ElementType.METHOD)<br />@Inherited<br />public @interface NeedToRetry {<br />&nbsp;&nbsp; &nbsp;Class&lt;?&gt;[] recoverableExceptions();<br />&nbsp;&nbsp; &nbsp;int retryTime();<br />&nbsp;&nbsp; &nbsp;int intervalIncrementalFactor() default 0;<br />&nbsp;&nbsp; &nbsp;long retryInterval() default 0L;<br />}<br /><br />2 The Aspect<br />@Aspect<br />public class InvokingRetryInterceptor {<br />&nbsp;&nbsp; &nbsp;private static Logger log = Logger.getLogger(InvokingRetryInterceptor.class);<br />&nbsp;&nbsp; &nbsp;private boolean isNeedToRetry(Throwable t,Class&lt;?&gt;[] recoverableExceptions){<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;String exceptionName= t.getClass().getName();<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;for (Class&lt;?&gt; exp:recoverableExceptions){&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;if (exp.isInstance(t)){<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;return true;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;log.warn("The exception doesn't need recover!"+exceptionName);<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;return false;<br />&nbsp;&nbsp; &nbsp;}<br /><br />&nbsp;&nbsp; &nbsp;private long getRetryInterval(int tryTimes,long interval,int incrementalFactor){<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;return interval+(tryTimes*incrementalFactor);<br />&nbsp;&nbsp; &nbsp;}<br />&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;@Around(value="@annotation(amazon.internal.dropship.common.NeedToRetry)&amp;&amp;@annotation(retryParam)",argNames="retryParam")<br />&nbsp;&nbsp; &nbsp;public Object process(ProceedingJoinPoint pjp,NeedToRetry retryParam ) throws Throwable{<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;boolean isNeedTry=true;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;int count=0;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;Throwable fault;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;Class&lt;?&gt;[] recoverableExceptions=retryParam.recoverableExceptions();<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;int retryTime=retryParam.retryTime();<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;long retryInterval=retryParam.retryInterval();<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;int incrementalFactor=retryParam.intervalIncrementalFactor();<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;do{<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;try{&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;return pjp.proceed();&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}catch(Throwable t){<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;fault=t;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;if (!isNeedToRetry(t,recoverableExceptions)){<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;break;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;Thread.sleep(getRetryInterval(retryTime,retryInterval,incrementalFactor));<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;count++;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;}while(count&lt;(retryTime+1));<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;throw fault;<br />&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />&nbsp;&nbsp; &nbsp;}<br />}</div><img src ="http://www.blogjava.net/chaocai/aggbug/351844.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2011-06-07 11:34 <a href="http://www.blogjava.net/chaocai/archive/2011/06/07/351844.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>发现自己是2010年下半年软考系统架构师总成绩第10名</title><link>http://www.blogjava.net/chaocai/archive/2011/05/22/350770.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Sun, 22 May 2011 05:50:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2011/05/22/350770.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/350770.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2011/05/22/350770.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/350770.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/350770.html</trackback:ping><description><![CDATA[<div>http://www.rkb.gov.cn/jsj/cms/s_contents/download/s_dt201103170102.html</div><img src ="http://www.blogjava.net/chaocai/aggbug/350770.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2011-05-22 13:50 <a href="http://www.blogjava.net/chaocai/archive/2011/05/22/350770.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>JBehave in practice</title><link>http://www.blogjava.net/chaocai/archive/2011/02/26/345233.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Sat, 26 Feb 2011 05:34:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2011/02/26/345233.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/345233.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2011/02/26/345233.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/345233.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/345233.html</trackback:ping><description><![CDATA[<p style="page-break-after: avoid" class="MsoNormal">ATDD (Acceptance Test Driven Development) is the extension of TDD, which helps us deliver exactly what the customer wants. Now ATDD has already been the hot spot in the software development world. There are several variations of ATDD including BDD, EDD and etc, also more and more frameworks have been created to help us develop with ATDD, for example&nbsp; FIT and JBehave.<br />
The followings will introduce how to use the JBehave in your real project effectively.<span style="line-height: 115%; font-family: 'NewBaskerville-Roman','serif'; font-size: 10.5pt">
<div align="center"><img border="0" alt="" src="http://www.blogjava.net/images/blogjava_net/chaocai/jbehave.jpg" /></div>
<br />
</span>
<p>&nbsp;</p>
<p>Figure 1 Test Code Structure</p>
<p>Each test implementation could be divided into four layers, this structure could help us improve the codes reusability and maintainability, So, it will make us implement the tests quickly and easily.</p>
<p>Specification/Scenario layer: </p>
<p>This layer describes system&#8217;s behaviors and functionalities by the scenarios.&nbsp; For using JBehave, we can use the natural language describe the scenarios and just need to follow the JBehave &#8216;Given-When-Then&#8217; rule.</p>
<p>Parser layer:</p>
<p>We don&#8217;t need to implement this layer , this layer has been implemented by JBehave. What exactly JBehave do is to relate the steps of the scenario to the methods of the test codes.</p>
<p>Step Logic Layer:</p>
<p>The layer implements test logics associating with every step of the scenarios. Every step are implemented by a Java method.</p>
<p>Action/Utils layer</p>
<p>This the very important layer to improve the reusability of our codes. This layer provides the utility methods to help you implement step logics. These utility methods usually involved the system state checking, mock requests sending and so on.</p>
<p>For example, we can provide the methods to check the data in database/file or check the state of the middleware, also so frameworks are very useful to implement the logic simulating the client browser&#8217;s requests.</p>
<p>&nbsp;</p>
<p><br />
Chao Cai</p>
<p>Working for Amazon.com</p>
<p>chaocai2001@yahoo.com.cn</p>
<p class="MsoCaption" align="center">&nbsp;</p>
<img src ="http://www.blogjava.net/chaocai/aggbug/345233.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2011-02-26 13:34 <a href="http://www.blogjava.net/chaocai/archive/2011/02/26/345233.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>TDD Tips</title><link>http://www.blogjava.net/chaocai/archive/2011/01/09/342623.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Sun, 09 Jan 2011 08:55:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2011/01/09/342623.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/342623.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2011/01/09/342623.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/342623.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/342623.html</trackback:ping><description><![CDATA[<p>How to design the testable software? You may always find some best practices about designing for scalable, extensible or maintainable. To be testable, the best way should be TDD. Followings are some tips from my real practices on TDD.</p>
<p>1 TDD is design process; it let you design for testing, naturally</p>
<p>Write the test firstly, it does not only help you find the bugs; but the most important point is to let you design for test naturally. </p>
<p>Also you should keep in mind, tests not only help you find bugs, but also protect your codes; when some changes impact on your existing codes, the tests will be broken.</p>
<p>&nbsp;</p>
<p>2 Keep the implementation simple</p>
<p>Keep your implementation simple, just let the test pass. The complex implementation may introduce the logics or codes not covered by the tests, even leads some codes not testable.</p>
<p>&nbsp;</p>
<p>3 TDD in each scope.</p>
<p>You may get to know the concept ATDD (acceptance test driven development). TDD could be used in every phase of the development and by the different granularity.</p>
<p>To ATDD, you could consider on using some existing framework such as FIT, these frameworks will be bridge between business logic and implementation logic.</p>
<p>Recently, the concept BDD (behavior driven development) is introduced to the ATDD process, so the BDD frameworks such as JBehave is also the good choice. </p>
<p>&nbsp;<img height="367" alt="" src="http://www.blogjava.net/images/blogjava_net/chaocai/TDD.JPG" width="523" border="0" /></p>
<p><br />
Different TDD process could be nested and should be nested don&#8217;t let your step too large.</p>
<p>&nbsp;</p>
<p>4 keep each step small enough</p>
<p>Always keep each step small to avoid introducing the untestable codes or logics and pass each test quickly.</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>6 Always refactor</p>
<p>This step is always overlooked in TDD process; however it is the very important step. Also, never forget refactor should involve all your tests.</p>
<p>&nbsp;</p>
<p>Why can't write test firstly?</p>
<p>&nbsp;1.not think how to meature the codes </p>
<p>2. The current step maybe too large, should separate into small ones </p>
<p>3. The codes with ugly dependencies<br />
</p>
<p><br />
<a title="http://blog.csdn.net/chaocai2004/archive/2011/01/09/6125479.aspx" href="http://blog.csdn.net/chaocai2004/archive/2011/01/09/6125479.aspx">&nbsp;http://blog.csdn.net/chaocai2004/archive/2011/01/09/6125479.aspx</a><br />
</p>
<p><br />
Chao Cai (蔡超)</p>
<p>Sr. SDE</p>
<p>Amazon.com</p>
<p>&nbsp;</p>
<img src ="http://www.blogjava.net/chaocai/aggbug/342623.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2011-01-09 16:55 <a href="http://www.blogjava.net/chaocai/archive/2011/01/09/342623.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>算法的时间复杂度</title><link>http://www.blogjava.net/chaocai/archive/2010/06/18/323815.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Fri, 18 Jun 2010 07:26:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2010/06/18/323815.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/323815.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2010/06/18/323815.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/323815.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/323815.html</trackback:ping><description><![CDATA[&nbsp;
<p><span style="font-family: 宋体">相信大家对于算法的时间复杂度</span><span style="font-family: 宋体">O都不会陌生，不过你知道一个算法的时间复杂度是如何计算出来的吗？</span></p>
<p><span style="font-family: 宋体">以前在学习算法和数据结构的时候，对于每种算法的复杂度都是死记的并没有真正的去研究他们是如何计算出来，最近突然对算法产生了兴趣，迫使自己研究了一下算法复杂度的计算方法。</span></p>
<p><span style="font-family: 宋体">概念</span></p>
<p><span style="font-family: 宋体">大</span><span style="font-family: 宋体">O表示法表示时间复杂性，注意它是某一个算法的时间复杂性。大O表示只是说有上界，由定义如果f(n)=O(n)，那显然成立f(n)=O(n^2)，它给你一个上界，但并不是上确界，但人们在表示的时候一般都习惯表示前者</span><span style="font-family: 宋体">。</span></p>
<p><span style="font-family: 宋体">另外除了这个官方概念，个人认为大</span><span style="font-family: 宋体">O表示的是问题规模n和算法中语句执行次数的关系。</span></p>
<p><span style="font-family: 宋体">以二分查找为例，我们求解它的时间复杂度</span></p>
<p><span style="font-family: 宋体">1 设规模为n个元素时，要执行T(n)次</span></p>
<p><span style="font-family: 宋体">T(n)=T(n/2)+1</span></p>
<p><span style="font-family: 宋体">T(n)=[T(n/4)+1]+1</span></p>
<p><span style="font-family: 宋体">&#8230;</span></p>
<p><span style="font-family: 宋体">T(n)=T(n/2^m)+m</span></p>
<p><span style="font-family: 宋体">当</span><span style="font-family: 宋体">n=2^m</span></p>
<p><span style="font-family: 宋体">T(n)=T(1)+log2n</span></p>
<p><span style="font-family: 宋体">T(1)=1</span></p>
<p><span style="font-family: 宋体">所以其算法复杂度为</span><span style="font-family: 宋体">O（log2n）</span></p><img src ="http://www.blogjava.net/chaocai/aggbug/323815.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2010-06-18 15:26 <a href="http://www.blogjava.net/chaocai/archive/2010/06/18/323815.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>DSL实现要点(3)--利用脚本语言实现DSL</title><link>http://www.blogjava.net/chaocai/archive/2010/04/06/317576.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Tue, 06 Apr 2010 10:21:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2010/04/06/317576.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/317576.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2010/04/06/317576.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/317576.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/317576.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: &nbsp;由于脚本语言通常提供了更为简洁的语法及Java所不具有的一些新的语言特性（如：闭包，元编程等），所以在一些情况下可以创造出比Java程序更具有可读性的代码。另外，众多基于JVM的脚本语言也为与Java程序整合带来了便利。Client: 语义模型实例的调用者SemanticConcept: 语义模型定义,可以通过脚本语言或Java实现ModelBuilder: 语...&nbsp;&nbsp;<a href='http://www.blogjava.net/chaocai/archive/2010/04/06/317576.html'>阅读全文</a><img src ="http://www.blogjava.net/chaocai/aggbug/317576.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2010-04-06 18:21 <a href="http://www.blogjava.net/chaocai/archive/2010/04/06/317576.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>在Weblogic中部署CXF的技巧</title><link>http://www.blogjava.net/chaocai/archive/2010/01/15/309709.html</link><dc:creator>超越巅峰</dc:creator><author>超越巅峰</author><pubDate>Fri, 15 Jan 2010 13:11:00 GMT</pubDate><guid>http://www.blogjava.net/chaocai/archive/2010/01/15/309709.html</guid><wfw:comment>http://www.blogjava.net/chaocai/comments/309709.html</wfw:comment><comments>http://www.blogjava.net/chaocai/archive/2010/01/15/309709.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/chaocai/comments/commentRss/309709.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/chaocai/services/trackbacks/309709.html</trackback:ping><description><![CDATA[&nbsp;
<p><span style="font-family: 宋体">由于</span>Weblogic<span style="font-family: 宋体">中包含的相关</span>JWS<span style="font-family: 宋体">及</span>JAX-RPC<span style="font-family: 宋体">实现的影响使得我们在其中部署相关</span>CXF<span style="font-family: 宋体">应用时总是会遇到一些棘手的问题，本人根据自己的实践经验将其中一些注意事项作了一下总结。</span></p>
<p>1 <span style="font-family: 宋体">以</span>EAR<span style="font-family: 宋体">形式部署</span></p>
<p><span style="font-family: 宋体">将</span>CXF<span style="font-family: 宋体">的应用以</span>WAR<span style="font-family: 宋体">的形式包含在</span>EAR<span style="font-family: 宋体">中，在</span>EAR<span style="font-family: 宋体">的</span>META-INF<span style="font-family: 宋体">中的配置文件</span>application.xml<span style="font-family: 宋体">中声明你的</span>WAR<span style="font-family: 宋体">，并在</span>weblogic-application.xml<span style="font-family: 宋体">中加入以下内容：</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;?</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">xml </span><span style="font-size: 10pt; color: #7f007f; font-family: 'Courier New'">version</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">=</span><span style="font-size: 10pt; color: #2a00ff; font-family: 'Courier New'">"1.0" </span><span style="font-size: 10pt; color: #7f007f; font-family: 'Courier New'">encoding</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">=</span><span style="font-size: 10pt; color: #2a00ff; font-family: 'Courier New'">"UTF-8"</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">?&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">weblogic-application </span><span style="font-size: 10pt; color: #7f007f; font-family: 'Courier New'">xmlns</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">=</span><span style="font-size: 10pt; color: #2a00ff; font-family: 'Courier New'">"http://www.bea.com/ns/weblogic/90"</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">application-param</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">param-name</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">webapp.encoding.default</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">param-name</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">param-value</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">UTF-8</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">param-value</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">application-param</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">prefer-application-packages</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">package-name</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span><span style="font-size: 10pt; color: black; font-family: 'Courier New'">javax.jws.*</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">package-name</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p style="margin-bottom: 0pt; line-height: normal"><span style="font-size: 10pt; color: black; font-family: 'Courier New'">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; font-family: 'Courier New'">prefer-application-packages</span><span style="font-size: 10pt; color: teal; font-family: 'Courier New'">&gt;</span></p>
<p><span style="font-size: 10pt; color: teal; line-height: 115%; font-family: 'Courier New'">&lt;/</span><span style="font-size: 10pt; color: #3f7f7f; line-height: 115%; font-family: 'Courier New'">weblogic-application</span><span style="font-size: 10pt; color: teal; line-height: 115%; font-family: 'Courier New'">&gt;</span></p>
<p><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">这个配置是告诉应用服务器的类装载器对于该</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 'Courier New'">EAR</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">而言优先使用该</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 'Courier New'">EAR</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">中</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 'Courier New'">javax.jws.*</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">的实现。</span></p>
<p><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 'Courier New'">2 </span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">在应用服务器启动时加入</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 'Courier New'">Java VM</span><span style="font-size: 10pt; color: black; line-height: 115%; font-family: 宋体">参数</span></p>
<p><span style="color: black">-Djavax.xml.soap.MessageFactory=com.sun.xml.messaging.saaj.soap.ver1_1.SOAPMessageFactory1_1Impl</span></p>
<p><span style="color: black; font-family: 宋体">好了现在一切搞定！<br />
<br />
(蔡超 <a href="&#109;&#97;&#105;&#108;&#116;&#111;&#58;&#99;&#104;&#97;&#111;&#99;&#97;&#105;&#50;&#48;&#48;&#49;&#64;&#121;&#97;&#104;&#111;&#111;&#46;&#99;&#111;&#109;&#46;&#99;&#110;">chaocai2001@yahoo.com.cn</a>)</span></p>
<img src ="http://www.blogjava.net/chaocai/aggbug/309709.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/chaocai/" target="_blank">超越巅峰</a> 2010-01-15 21:11 <a href="http://www.blogjava.net/chaocai/archive/2010/01/15/309709.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>