<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    七段

    無論怎樣,請讓我先感謝一下國家。

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      35 Posts :: 2 Stories :: 7 Comments :: 0 Trackbacks

    2010年3月28日 #

    有25匹馬,每匹馬都以一個固定不變的速度奔跑,每匹馬的速度都不一樣,如果讓你找出跑的最快的5匹馬,最少需要組織多少場比賽?注:每場比賽最多只能5匹馬參賽。
    re:悲觀10場,樂觀7場。
    posted @ 2012-03-07 21:17 sevenduan 閱讀(833) | 評論 (1)編輯 收藏

    Eclipse:
    ctrl+o
    ctrl+space
    ctrl+t
    ctrl+k
    ctrl+f8/f9/f10

    alt+shift+x , t/j
    alt+shift+d , t/j

    Command:
    cd -
    tab
    ctrl+a/e
    ctrl+u/k/w

    Vim
    shift+g
    m+'mark'
    `+'mark'
    . (repeat)



    posted @ 2010-08-07 23:14 sevenduan 閱讀(247) | 評論 (0)編輯 收藏

    Framework Supported log levels Standard appenders Popularity Cost / licence
    Log4J FATAL ERROR WARN INFO DEBUG TRACE AsyncAppender, JDBCAppender, JMSAppender, LF5Appender, NTEventLogAppender, NullAppender, SMTPAppender, SocketAppender, SocketHubAppender, SyslogAppender, TelnetAppender, WriterAppender Widely used in many project and platforms Apache License, Version 2.0
    Java Logging API SEVERE WARNING INFO CONFIG FINE FINER FINEST Depends on the underlying framework; Sun's default Java Virtual Machine (JVM) has the following: ConsoleHandler, FileHandler, SocketHandler, MemoryHandler Not widely used[citation needed] Comes with the JRE
    Apache Commons Logging FATAL ERROR WARN INFO DEBUG TRACE Depends on the underlying framework Widely used, in conjunction with log4j Apache License, Version 2.0
    SLF4J ERROR WARN INFO DEBUG TRACE Depends on the underlying framework, which is pluggable Probably small but growing MIT License
    posted @ 2010-07-18 22:15 sevenduan 閱讀(486) | 評論 (0)編輯 收藏

    1 definition:

    “A transaction is a complete unit of work. It may comprise many computational tasks,which may include user interface, data retrieval, and communications. A typicaltransaction modifies shared resources.”

    2 transaction features:
    ACID (atomicity, consistency, isolation, durability)

    3 java spec
    JTA, JTS
     1interface javax.transaction.TransactionManager
     2{
     3public abstract void begin();
     4public abstract void commit();
     5public abstract int getStatus();
     6public abstract Transaction getTransaction();
     7public void resume(Transaction tobj);
     8public abstract void rollback();
     9public abstract void setRollbackOnly();
    10public abstract void setTransactionTimeout(intseconds);
    11public abstract Transaction suspend() ;
    12}

    4 Common XAResource
    JDBC 2.0:
    A JDBC driver that supports distributed transactions implements the javax.transaction.xa.XAResource interface, the javax.sql.XAConnectioninterface, and the  javax.sql.XADataSource interface.

    JMS 1.0:

    a JMS provider javax.transaction.xa.XAResource interface, the implements the javax.jms.XAConnection and the javax.jms.XASession interface.

    5 Common TransactionManager

    5.1 EJB Transaction Options:
    NotSupported
        If the method is called within a transaction, this transaction is suspended during the time of the method execution.
    Required
        If the method is called within a transaction, the method is executed in the scope of this transaction; otherwise, a new transaction is started for the execution of the method and committed before the method result is sent to the caller.
    RequiresNew
        The method will always be executed within the scope of a new transaction. The new transaction is started for the execution of the method, and committed before the method result is sent to the caller. If the method is called within a transaction, this transaction is suspended before the new one is started and resumed when the new transaction has completed.
    Mandatory
        The method should always be called within the scope of a transaction, else the container will throw the TransactionRequired exception.
    Supports
        The method is invoked within the caller transaction scope; if the caller does not have an associated transaction, the method is invoked without a transaction scope.
    Never
        The client is required to call the bean without any transaction context; if it is not the case, a java.rmi.RemoteException is thrown by the container.

    5.2 Spring transaction:
          Transaction isolation: The degree of isolation this transaction has from the work of other transactions. For example, can this transaction see uncommitted writes from other transactions? avaliable options:
    ISOLATION_DEFAULT
    ISOLATION_READ_UNCOMMITTED
    ISOLATION_READ_COMMITTED
    ISOLATION_REPEATABLE_READ
    ISOLATION_SERIALIZABLE

          Transaction propagation: Normally all code executed within a transaction scope will run in that transaction. However, there are several options specifying behavior if a transactional method is executed when a transaction context already exists: For example, simply running in the existing transaction (the most common case); or suspending the existing transaction and creating a new transaction. Spring offers the transaction propagation options familiar from EJB CMT. avaliable options:
    PROPAGATION_MANDATORY
    PROPAGATION_NESTED
    PROPAGATION_NEVER
    PROPAGATION_NOT_SUPPORTED
    PROPAGATION_REQUIRED
    PROPAGATION_REQUIRES_NEW
    PROPAGATION_SUPPORTS

          Transaction timeout: How long this transaction may run before timing out (automatically being rolled back by the underlying transaction infrastructure).
          Read-only status: A read-only transaction does not modify any data. Read-only transactions can be a useful optimization in some cases (such as when using Hibernate).


    6 transaction for web service
    Protocol specifications:
    WS-Transaction
    OASIS Business Transaction Protocol (BTP)
    Java API
    JAXTX (JSR-156)

     

    posted @ 2010-04-25 16:44 sevenduan 閱讀(611) | 評論 (0)編輯 收藏

    JavaScript里有兩個容易讓初學者混淆的概念:scope chain and closure。
    比如說,我想創建10個函數,每個函數依次返回0-9.
     1 //wrong: all function refer to global variable i=10 
     2 var fn_list=[];
     3 for(var i=0;i<10;i++){
     4  var _tempFn =function(){
     5         return i;
     6  }
     7  fn_list.push(_tempFn);    
     8 }
     9 //right: every function refer to its closure scope variable a
    10 var fn_list=[];
    11 for(var i=0;i<10;i++){
    12  var _tempFn =function(a){
    13         return function(){
    14          return a;
    15         };
    16  }
    17  fn_list.push(_tempFn(i));    
    18 }
    19 

    Java里也有兩個讓初學者容易混淆的概念:nest class and inner class。
    nest class就是static inner class,
    而inner class就是no-static inner class。沒有為什么,sun就是這么定義的。
    還是上面得例子,創建10個對象,每個對象的getValue接口依次返回0-9.
     1 public class Test {
     2     private int noStaticValue;
     3     private static int staticValue;
     4 
     5     public Test(int noSV, int sv) {
     6         this.noStaticValue = noSV;
     7         this.staticValue = sv;
     8     }
     9 
    10     public Test(int noSV) {
    11         this.noStaticValue = noSV;
    12     }
    13 
    14     interface valueHolder {
    15         int getValue();
    16     }
    17 
    18     class innerClass implements valueHolder {
    19         public int getValue() {
    20             return noStaticValue;
    21         }
    22     }
    23 
    24     static class nestClass implements valueHolder {
    25         public nestClass(int i) {
    26             staticValue = i;
    27         }
    28 
    29         public int getValue() {
    30             return staticValue;
    31         }
    32     }
    33 
    34     public static void main(String[] args) {
    35         Test context1 = new Test(00);
    36         valueHolder[] list = new valueHolder[10];
    37         for (int i = 0; i < 10; i++) {
    38             list[i] = new Test.nestClass(i);
    39         }
    40         for (valueHolder obj : list) {
    41             System.out.println(obj.getValue());// always print 9
    42         }
    43         for (int i = 0; i < 10; i++) {
    44             list[i] = new Test(i).new innerClass();
    45         }
    46         for (valueHolder obj : list) {
    47             System.out.println(obj.getValue());// print 0-9
    48         }
    49     }
    50 }
    可見用inner class可以模擬closure的特性,就是運行時定義class的某些狀態。
    inner class和nest class之間的區別就是后者是靜態類。前者必須通過wrap class的實例來調用new,e.g. new Test().new innerClass。
    因為nest class是靜態類,所以可以添加static member 或者static method,而inner class 不行。
    匿名內部類是inner class的一種特殊形式,所以也不能添加static member 或者static method。



    posted @ 2010-04-17 23:07 sevenduan 閱讀(2787) | 評論 (5)編輯 收藏

    先看一段代碼:
    byte [] b = new byte[]{1,-1,2,-2};
            System.out.println(Arrays.toString(
    new String(b).getBytes()));

    輸出:
    [1, -17, -65, -67, 2, -17, -65, -67]
    解釋:
    byte decode to String,String encode to byte 默認用UTF-8 charset.
    decode遇到不支持的字符 輸出 char ? , encode ? 就是 -17, -65, -67.
    實現細節可見ByteToCharUTF8.java

    解決辦法: 使用 ISO8859_1 charset。

    教訓: 注意charset的范圍。



    posted @ 2010-04-14 23:14 sevenduan 閱讀(2034) | 評論 (0)編輯 收藏

    java bitwise operator:
    ~ The unary bitwise complement operator "~" inverts a bit pattern.
    <<The signed left shift
    >>The signed right shift
    >>>the unsigned right shift

    & The bitwise & operator performs a bitwise AND operation.

    ^ The bitwise ^ operator performs a bitwise exclusive OR operation.

    | The bitwise | operator performs a bitwise inclusive OR operation.



    Usage:
    1,
    • ^ can swap two variables without using an intermediate, temporary variable which is useful if you are short on available RAM or want that sliver of extra speed.

      Usually, when not using ^, you will do:

      temp = a;

      a = b;

      b = temp;

      Using ^, no "temp" is needed:

      a ^= b;

      b ^= a;

      a ^= b;

      This will swap "a" and "b" integers. Both must be integers.

    2,
    an example of using an integer to maintain state flags (common usage):
    // These are my masks

    private static final int MASK_DID_HOMEWORK  = 0x0001;

    private static final int MASK_ATE_DINNER    = 0x0002;

    private static final int MASK_SLEPT_WELL    = 0x0004;



    // This is my current state

    private int m_nCurState;

    To set my state, I use the bitwise OR operator:

    // Set state for'ate dinner' and 'slept well' to 'on'

    m_nCurState
    = m_nCurState | (MASK_ATE_DINNER | MASK_SLEPT_WELL);

    Notice how I 'or' my current state in with the states that I want to turn 'on'. Who knows what my current state is and I don't want to blow it away.

    To unset my state, I use the bitwise AND operator with the complement operator:

    // Turn off the 'ate dinner' flag

    m_nCurState
    = (m_nCurState & ~MASK_ATE_DINNER);

    To check my current state, I use the AND operator:

    // Check if I did my homework

    if (0 != (m_nCurState & MASK_DID_HOMEWORK)) {

       
    // yep

    } else {

       
    // nope...

    }

    Why do I think this is interesting? Say I'm designing an interface that sets my state. I could write a method that accepts three booleans:

    void setState( boolean bDidHomework, boolean bAteDinner, boolean bSleptWell);

    Or, I could use a single number to represent all three states and pass a single value:

    void setState( int nStateBits);

    If you choose the second pattern you'll be very happy when decide to add another state - you won't have to break existing impls of your interface.


    posted @ 2010-04-13 14:39 sevenduan 閱讀(413) | 評論 (0)編輯 收藏

    什么才是激勵你工作的動力?
    這個問題問自己的往往很少。經常思考這些問題的往往是管理者。當管理者想進行一些管理工作的時候,管理本身就成了最大的問題。所以,一個項目的成敗往往在很大程度上取決于受到管理層的負面影響的大小。
    大多數人和大多數管理者有著共同的認識,錢才是激勵我們工作的動力。理由很充分,盈利是企業的唯一目標,說起來就好像人活著就是為了吃飯一樣。所以,各種績效考核與薪酬掛鉤了,各種項目獎、季度獎、年終獎誕生了。為了響應上級政策,我們開始加班加點了,開始趕進度趕業績了。試想,在這種驅動下,如果手頭的事情沒有和獎金掛鉤,你還有動力繼續么?
    結果唯一導向對于重復性的體力勞動來說是有效的。但是對于腦力勞動者來說,自發、專精和目標性才是內在的能夠持續激勵我們工作的動力所在。
    自發:
    對于腦力勞動,命令式的分配任務很難奏效,很顯然,你不能強迫別人的想法。就像強迫學生學習一樣。只有自發的工作,才能培養興趣激發工作熱情。正如敏捷實踐里強調任務應該由個人自發選擇領取一樣。
    專精:
    在自發的前提下,無論我們做什么事情,我們總是希望自己可以做得更好。這就是專精。對專精的向往表現為對工作的癡迷。要想更為專精,必須不斷的練習實踐和分析思考。
    目標性:
    自發和專精也許能在中短期維持動力,但是長期下去,當我們不知道自己為什么工作的時候,動力也會衰竭。目標性要求目標不能太低而沒有成就感,或者太高而很難達到。最好的目標是比你現在的成就更高,且需要一定的努力才能達到。
    Drive: The Surprising Truth About What Motivates Us


    posted @ 2010-04-05 23:43 sevenduan 閱讀(494) | 評論 (0)編輯 收藏

    簡便個人項目管理:
    1,一周一個iteration,一個iteration共計30個man hours:
    只要可以小迭代總是更好。
    story point優勢在于消除個體差異,個人項目man hour更準確直接。
    2, 每周日做iteration plan,計劃下周任務,用gmail tasks來做story wall。
    3,每周五晚做retrospective,總結一周工作,直接用gmail來保存回顧總結。

    posted @ 2010-04-01 00:54 sevenduan 閱讀(244) | 評論 (0)編輯 收藏

    Ref: http://community.jboss.org/wiki/JBossCacheOfficialDocumentation

    Cache的目的是為了以空間換時間,一次計算結果為多次重用。
    空間可以是實時內存空間、持久化的硬盤空間。時間可以是運算時間、連接時間、傳輸時間等。

    Cache可以分為LocalCache和DistributedCache。
    最簡單的LocalCache可以通過維護一個ConcurrentHashMap實現。
    缺點是:
    1,內存有限,容易out of memory (定期清除?持久化?)
    2, 需要對全map做concurrency維護,粗粒度的鎖定爭用會影響性能(樹結構維護?)

    在一個專業的企業級應用中,cache除了高性能和線程安全的要求,還要支持事務、高可用性、持久化、容錯、集群同步等。
    JBossCache是一個典型的企業級cache實現,他采用樹結構且支持集群和事務特性。
    雖然JBossCache這把牛刀也可以在standalone的JS2E應用中用來殺雞,但我們應該更關心用他在集群環境中怎么殺牛。
    JBossCache分為非集群模式(Local)和集群模式。
    集群模式根據實現策略又分為replication和invalidation。
    1 replication:通過拷貝改變的cache對象來保證與集群中其他cache同步。replication又可細分為同步replication和異步repliation兩種,異步replication較快,put以后馬上返回,但是replication出錯了,事務還是算完成了不回回滾。同步replication要花時間等待其他的cache完成replication的通知才能結束。

    2 invalidation: 如果cache狀態改變,僅僅是給其他cache發個通知,收到通知的cache把臟數據清除掉。invalidation也可分為同步和異步兩種,區別是發送通知的廣播方式一個是同步一個是異步。

    在jboss cluster中,我們最好通過MBean來部署jboss cache。這樣又幾個好處:
    1,JBoss NS支持Cluster
    我們就可以通過JBoss NamingService來訪問cache。如果在local NS中查不到cache,jbss NS還會去查cluster中其他的cache。
    2,利用MBean的特性
    通過CacheMBean, 我們可以方便的管理Cache Service,實時的啟動、停止或者改變一些配置,還可以監控到一些cache統計數據。
    3,利用microcontainer的特性
    我們可以通過配置XML文件來完成cache相關的所有對象聲明。簡而言之,就是利用java reflection和AOP的技術就不用寫聲明cache的代碼了。


    <?xml version="1.0" encoding="UTF-8"?>



    <deployment xmlns="urn:jboss:bean-deployer:2.0">



       
    <!-- First we create a Configuration object for the cache -->

       
    <bean name="ExampleCacheConfig"

             class
    ="org.jboss.cache.config.Configuration">

          

           build up the Configuration

          

       
    </bean>

       

       
    <!-- Factory to build the Cache. -->

       
    <bean name="DefaultCacheFactory" class="org.jboss.cache.DefaultCacheFactory">      

          
    <constructor factoryClass="org.jboss.cache.DefaultCacheFactory"

                       factoryMethod
    ="getInstance" />

       
    </bean>

       

       
    <!-- The cache itself -->

       
    <bean name="ExampleCache" class="org.jboss.cache.CacheImpl">

          

          
    <constructor factoryMethod="createnewInstance">

              
    <factory bean="DefaultCacheFactory"/>

              
    <parameter><inject bean="ExampleCacheConfig"/></parameter>

              
    <parameter>false</parameter>

          
    </constructor>

              

       
    </bean>

       

       
    <!-- JMX Management -->

       
    <bean name="ExampleCacheJmxWrapper" class="org.jboss.cache.jmx.CacheJmxWrapper">

          

          
    <annotation>@org.jboss.aop.microcontainer.aspects.jmx.JMX(name="jboss.cache:service=ExampleTreeCache", 

                             exposedInterface=org.jboss.cache.jmx.CacheJmxWrapperMBean.class, 

                             registerDirectly=true)
    </annotation>

          

          
    <constructor>

              
    <parameter><inject bean="ExampleCache"/></parameter>

          
    </constructor>

              

       
    </bean>



    </deployment> 

    后記:
    1,jboss cache的naga版中,采用Multi-versioned concurrency control來實現并發。下次再從中總結一下多線程的學習。
    2,jboss cache通過結合visitor pattern和command pattern,把對cache node的操作與訪問從中隔離出來,不用改變或者擴展node對象就可以添加新的node行為。也就是開閉原則。下次再從中總結一下幾種設計模式的經典應用。



    posted @ 2010-03-28 23:10 sevenduan 閱讀(2504) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 国产免费av片在线看| 免费国产黄网站在线观看视频| 91免费资源网站入口| 亚洲精品456在线播放| 2022久久国产精品免费热麻豆| 久久亚洲精精品中文字幕| 日本免费中文字幕| 亚洲午夜在线电影| 国产精品成人免费福利| 国产.亚洲.欧洲在线| 天天摸天天碰成人免费视频| 亚洲AV无码AV日韩AV网站| 免费在线观看你懂的| xxxx日本在线播放免费不卡| 亚洲国产三级在线观看| 99在线观看免费视频| 亚洲国产视频久久| 亚洲国产精品国产自在在线| 久久最新免费视频| 亚洲最大黄色网站| 午夜爱爱免费视频| 本免费AV无码专区一区| 久久久无码精品亚洲日韩蜜臀浪潮| av大片在线无码免费| 亚洲a无码综合a国产av中文| 亚洲人成色7777在线观看不卡| 免费观看久久精彩视频| xxx毛茸茸的亚洲| 亚洲成a人片在线观看久| 久久免费线看线看| 亚洲乱码无人区卡1卡2卡3| 亚洲国产一级在线观看 | 麻豆一区二区三区蜜桃免费| 红杏亚洲影院一区二区三区| 最近最好最新2019中文字幕免费 | 亚洲AV性色在线观看| 亚洲精品国产自在久久| 99精品免费观看| 亚洲AV无码XXX麻豆艾秋| 久久久久亚洲精品成人网小说 | 亚洲色偷偷综合亚洲av78|