Ordinary hut

          人間一福地,勝似天仙宮
          posts - 61, comments - 50, trackbacks - 0, articles - 1

          2009年7月1日

          java中wait和notify的簡單理解
          1 它們都是Object的屬性;
          2 wait:釋放對象鎖;由于把鎖釋放了,當前線程就會卡住,繼續(xù)再等待獲取鎖的機會(也許是干了一半的活后,就把活交出去了,然后等待繼續(xù)干活的機會);
          3 notify:告訴其中一個等待的線程(具體哪一個不知道),我已經(jīng)用完這個對象,你可以繼續(xù)用了
          4 它們都要包含在synchronized塊里,只有先鎖住這個對象,才能進行wait、notify操作;

          例子:
          1 定義一個普通對象
          public class MyObj {
              public String name;
          }
          2 主線程類,定義MyObj對象,new兩個線程
          public class TestMain {

              public static MyObj obj = new MyObj();
              
              /**
               * 
          @param args
               
          */
              public static void main(String[] args) throws Throwable {
                  new TestMain().myTest();
              }
              
              public void myTest() throws Throwable{
                  Test1 test1 = new Test1();
                  Test2 test2 = new Test2();
                  
                  Thread t1 = new Thread(test1); 
                  Thread t2 = new Thread(test2); 
                  
                  t1.start();
                  Thread.sleep(1000);//啟動線程1,然后主線程睡眠1秒鐘,再啟動2
                  t2.start();
                  
              }

          }
          3 定義線程1,:
          public class Test1 implements Runnable{

              @Override
              public void run() {
                  synchronized (TestMain.obj) {//占有對象鎖
                      try {
                          TestMain.obj.name="1";
                          System.out.println(TestMain.obj.name); //打印出1
                          TestMain.obj.wait();  //釋放對TestMain.obj對象的鎖,同時當前線程立即卡住,陷入等待
                          System.out.println(TestMain.obj.name);//只有線程再次搶到TestMain.obj的鎖后,才會運行
                      } catch (InterruptedException e) {
                          e.printStackTrace();
                      }
                  }
              }

          }
          4 線程2:
          public class Test2 implements Runnable{

              @Override
              public void run() {
                  
                  synchronized (TestMain.obj) { //當線程1釋放這個對象的鎖時,本線程立即得到
                      TestMain.obj.name = "2"; //改值
                      TestMain.obj.notify();//通知占用了TestMain.obj且當前是等待的線程(線程1)可以繼續(xù),但是必須等到本synchronized塊執(zhí)行完畢。
                      TestMain.obj.name = "3";
                      TestMain.obj.name = "4";
                      
                      try {
                          Thread.sleep(1000);
                      } catch (InterruptedException e) {
                          e.printStackTrace();
                      }
                      TestMain.obj.name = "7";//執(zhí)行完畢,此時線程1被喚醒,會打印出7
                  }
              }

          }
          結(jié)果顯示1和7


          posted @ 2013-04-27 15:23 landor 閱讀(361) | 評論 (0)編輯 收藏

          轉(zhuǎn)載 http://supertoffy.blog.163.com/blog/static/16447681820116150115743/


          每個地區(qū)都有自己的本地時間,在網(wǎng)上以及無線電通信中時間轉(zhuǎn)換的問題就顯得格外突出。我自己就經(jīng)常混淆于此,特地研究了一下,記錄在此以備忘。
          整個地球分為二十四時區(qū),每個時區(qū)都有自己的本地時間。在國際無線電通信場合,為了統(tǒng)一起見,使用一個統(tǒng)一的時間,稱為通用協(xié)調(diào)時(UTC, Universal Time Coordinated)。UTC與格林尼治平均時(GMT, Greenwich Mean Time)一樣,都與英國倫敦的本地時相同。在本文中,UTC與GMT含義完全相同。
          北京時區(qū)是東八區(qū),領(lǐng)先UTC八個小時,在電子郵件信頭的Date域記為+0800。如果在電子郵件的信頭中有這么一行:
          Date: Fri, 08 Nov 2002 09:42:22 +0800
          說明信件的發(fā)送地的地方時間是二○○二年十一月八號,星期五,早上九點四十二分(二十二秒),這個地方的本地時領(lǐng)先UTC八個小時(+0800,就是東八區(qū)時間)。電子郵件信頭的Date域使用二十四小時的時鐘,而不使用AM和PM來標記上下午。
          以這個電子郵件的發(fā)送時間為例,如果要把這個時間轉(zhuǎn)化為UTC,可以使用一下公式:
          UTC + 時區(qū)差 = 本地時間
          時區(qū)差東為正,西為負。在此,把東八區(qū)時區(qū)差記為 +0800,
          UTC + (+0800) = 本地(北京)時間 (1)
          那么,UTC = 本地時間(北京時間))- 0800 (2)
          0942 - 0800 = 0142
          即UTC是當天凌晨一點四十二分二十二秒。如果結(jié)果是負數(shù)就意味著是UTC前一天,把這個負數(shù)加上2400就是UTC在前一天的時間。例如,本地(北京)時間是 0432 (凌晨四點三十二分),那么,UTC就是 0432 - 0800 = -0368,負號意味著是前一天, -0368 + 2400 = 2032,既前一天的晚上八點三十二分。
          紐約的時區(qū)是西五區(qū),比UTC落后五個小時,記為 -0500:
          UTC + (-0500) = 紐約時間 (3)
          UTC = 紐約時間 + 0500 (4)

          posted @ 2013-04-22 17:04 landor 閱讀(292) | 評論 (0)編輯 收藏

               摘要: struts2單獨使用沒有任何問題,加入spring后,發(fā)現(xiàn)頁面表單可以傳到struts2的action中,但是返回到頁面后,數(shù)據(jù)丟失,  閱讀全文

          posted @ 2012-08-19 23:06 landor 閱讀(1074) | 評論 (0)編輯 收藏

               摘要: Camel與cxf  閱讀全文

          posted @ 2011-09-29 13:50 landor 閱讀(2344) | 評論 (2)編輯 收藏

               摘要: XPath記錄  閱讀全文

          posted @ 2011-09-15 14:49 landor 閱讀(344) | 評論 (0)編輯 收藏

               摘要: JAXB2完成java bean到xml的相互轉(zhuǎn)換  閱讀全文

          posted @ 2011-06-03 12:04 landor 閱讀(7883) | 評論 (1)編輯 收藏

               摘要: Could not parse date - Class: java.text.DateFormat
          Caused by: java.text.ParseException: Unparseable date:  閱讀全文

          posted @ 2011-05-23 15:54 landor 閱讀(1075) | 評論 (0)編輯 收藏

               摘要: 轉(zhuǎn)載 - spring 動態(tài)數(shù)據(jù)源切換  閱讀全文

          posted @ 2011-03-30 21:30 landor 閱讀(351) | 評論 (0)編輯 收藏

               摘要: maven一些說明  閱讀全文

          posted @ 2011-03-04 16:29 landor 閱讀(752) | 評論 (0)編輯 收藏

          1 分組的時候,?可以不記錄一些組,比如:
          var str="abc";
          var reg=/(?:a)b(c)/g
          reg.test(str);
          alert(RegExp.$1);//結(jié)果為c
          此時雖然第一個小括號也滿足,但是如果用?:標注之后,它不會被存入正則表達式的緩存中。

          2 遇見功能,"?=",意識說目標串中肯定存在什么,比如:
          var str="ab4";
          var reg
          =/ab(?=\d)/g
          alert(reg.test(str));//結(jié)果為true
          意思是第三位肯定是數(shù)字;
          "?!",意思說目標串中不應(yīng)該存在什么
          var str="ab1";
          var reg
          =/ab(?!\d)/g
          alert(reg.test(str));//結(jié)果為false
          意思是目標串中的第三位不應(yīng)該是數(shù)字。

          posted @ 2011-03-02 16:29 landor 閱讀(1767) | 評論 (0)編輯 收藏

          1 瀏覽器會根據(jù)content="text/html; charset=gbk"來解析該用什么編碼來把這些字節(jié)流decode成字符串,并顯示;
          2 當客戶端提交表單的時候,比如以post方式提交,瀏覽器同樣會根據(jù)上面的編碼,把這些字符串encode成字節(jié)流,發(fā)送到服務(wù)端;
          3 在服務(wù)端,默認就會認為傳過來的東西就是ASCii碼,沒別的,也就是ISO-8859-1,所以它就去decode,ISO-8859-1中根本沒有中文漢字對應(yīng)的二進制碼,沒找到,就亂了應(yīng)該是一堆口吧;
          4 解決辦法是加一個過濾器,比如gbk,那就設(shè)置成request.setCharacterEncoding("GBK");這樣服務(wù)端在獲取字符串的時候,就用GBK去decode這個二進制流了;
          5 如果是ajax,問題又來了,因為ajax只支持utf-8編碼格式,過程應(yīng)該是這樣:
              a 瀏覽器通過ajax像server端post數(shù)據(jù)時,ajax自動將瀏覽器中的文字用utf-8 encode成二進制流,然后發(fā)送到server端;
              b server端如果配置的filter是gbk,那么會用gbk去decode這個二進制流,顯然亂麻;但是不應(yīng)該是一堆口,因為他應(yīng)該根據(jù)二進制流的每兩位字節(jié),在GBK編碼表中能找到對應(yīng)的內(nèi)容,具體的內(nèi)容是簡體文字還是繁體文字還是其他的,就不一定了;
                  此時要是偶數(shù)個漢字還好(可以把它用gbk進行encode,然后用utf-8進行decode,這樣就還原回來了),
                  如果是奇數(shù)個漢字就出現(xiàn)丟失了(因為一個字符用UTF-8 encode后為3個字節(jié),如果三個字符被encode之后,就是9個字節(jié),當用gbk進行decode 的時候,gbk是用2個字節(jié),結(jié)果剩下了一個字節(jié),這個字節(jié)在gbk的編碼表中不存在(因為gbk編碼表都是2個字節(jié)的),所以就用?號填充了)。
              c 所以必須在服務(wù)端的fiter中對ajax請求進行判斷,用jquery為例:
          $.ajax({
              
              contentType:
          "application/x-www-form-urlencoded;charset=utf-8",

          在server端的filter中,可以判斷charset是不是空,如果加上上面的代碼,那么charset就是utf-8,代碼如下:
          if (request.getCharacterEncoding() == null) {
              request.setCharacterEncoding(this.encoding);//正常提交請求時候,charset是空的,也就是說request.getCharacterEncoding()是空的;
          }

          posted @ 2011-03-02 15:51 landor 閱讀(568) | 評論 (0)編輯 收藏

               摘要: 用itext生成word  閱讀全文

          posted @ 2010-04-21 15:00 landor 閱讀(3290) | 評論 (2)編輯 收藏

               摘要: oracle的鎖和事務(wù)的記錄  閱讀全文

          posted @ 2010-02-19 22:23 landor 閱讀(1526) | 評論 (0)編輯 收藏

               摘要: weblogic集群中獲取jndi的方式  閱讀全文

          posted @ 2010-01-20 21:25 landor 閱讀(1075) | 評論 (0)編輯 收藏

               摘要: 關(guān)于用spring的JtaTransactionManager,配置分布式事務(wù)  閱讀全文

          posted @ 2010-01-09 13:22 landor 閱讀(17355) | 評論 (1)編輯 收藏

               摘要: java ee規(guī)范并沒有實現(xiàn)事務(wù)的隔離級別,所以要依靠不同的服務(wù)器廠商來實現(xiàn),拿weblogic為例,具體的設(shè)置可以參考官方文檔  閱讀全文

          posted @ 2010-01-07 18:20 landor 閱讀(847) | 評論 (0)編輯 收藏

               摘要: oracle行列轉(zhuǎn)換  閱讀全文

          posted @ 2010-01-07 11:08 landor 閱讀(597) | 評論 (0)編輯 收藏

               摘要: classInfoCacheEnabled forceMultipleResultSetSupport errorTracingEnabled defaultStatementTimeout
          statementCachingEnabled  閱讀全文

          posted @ 2009-12-31 13:08 landor 閱讀(1152) | 評論 (4)編輯 收藏

               摘要: 折線圖的一些詳細設(shè)置  閱讀全文

          posted @ 2009-12-30 16:48 landor 閱讀(578) | 評論 (0)編輯 收藏

               摘要: stage nostage external_stage   閱讀全文

          posted @ 2009-12-29 22:39 landor 閱讀(3789) | 評論 (0)編輯 收藏

               摘要: 通過javascript的image對象判斷上傳文件大小  閱讀全文

          posted @ 2009-12-29 08:48 landor 閱讀(1213) | 評論 (1)編輯 收藏

               摘要: 折線圖-按日期統(tǒng)計數(shù)據(jù)(處理中文亂碼)  閱讀全文

          posted @ 2009-12-28 14:31 landor 閱讀(1390) | 評論 (0)編輯 收藏

               摘要: jdbc驅(qū)動列表  閱讀全文

          posted @ 2009-12-21 10:25 landor 閱讀(267) | 評論 (0)編輯 收藏

               摘要: spring中各種切入點指示符
          轉(zhuǎn):http://www.busfly.cn/csdn/post/700.html  閱讀全文

          posted @ 2009-12-04 10:57 landor 閱讀(275) | 評論 (0)編輯 收藏

               摘要: weblogic啟動全局域信任(Enable global trust between domains)和兩個域的跨域信任(Enable Cross Domain Security between domains),weblogic下載地址  閱讀全文

          posted @ 2009-12-02 10:24 landor 閱讀(1469) | 評論 (0)編輯 收藏

               摘要: org.springframework.web.util.IntrospectorCleanupListener  閱讀全文

          posted @ 2009-11-26 16:29 landor 閱讀(3184) | 評論 (0)編輯 收藏

               摘要: spring、hibernate的FlushMode的AUTO、COMMIT、ALWAYS、NEVEL、MANUAL 的區(qū)別,以及和readonly的聯(lián)系  閱讀全文

          posted @ 2009-11-25 22:55 landor 閱讀(5031) | 評論 (0)編輯 收藏

               摘要: 閱讀全文

          posted @ 2009-11-18 12:40 landor 閱讀(2365) | 評論 (0)編輯 收藏

               摘要: java.rmi.RemoteException: Transaction Rolledback.; nested exception is:
          weblogic.transaction.internal.TimedOutException: Transaction timed out after * seconds
          BEA1-0015257A156225A3A3CE  閱讀全文

          posted @ 2009-11-06 14:51 landor 閱讀(4944) | 評論 (0)編輯 收藏

               摘要: 正則表達式中有三個量詞:貪婪、惰性、支配,記錄一下我對貪婪和惰性的理解  閱讀全文

          posted @ 2009-10-30 16:13 landor 閱讀(509) | 評論 (0)編輯 收藏

               摘要: 在網(wǎng)頁中嵌入word、excel、pdf的注意事項  閱讀全文

          posted @ 2009-08-21 14:26 landor 閱讀(9931) | 評論 (1)編輯 收藏

               摘要: 最常用的索引包括:B*樹索引、位圖索引、位圖聯(lián)合索引、基于函數(shù)索引、應(yīng)用域索引  閱讀全文

          posted @ 2009-08-11 16:51 landor 閱讀(2787) | 評論 (0)編輯 收藏

               摘要: jdbc關(guān)于對clob字段的方法setCharacterStream的說明
          java.lang.AbstractMethodError: com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.setCharacterStream(ILjava/io/Reader;J)V at...  閱讀全文

          posted @ 2009-07-03 15:43 landor 閱讀(3542) | 評論 (0)編輯 收藏

               摘要: spring+hibernate的幾種數(shù)據(jù)庫連接配置方式,jdbc proxool c3p0  閱讀全文

          posted @ 2009-07-02 16:57 landor 閱讀(3870) | 評論 (0)編輯 收藏

               摘要: spring配置ibatis的jdbc方式和proxool、c3p0連接池方式  閱讀全文

          posted @ 2009-07-01 16:51 landor 閱讀(9310) | 評論 (1)編輯 收藏

               摘要: spring+ibatis或jdbc配置proxool連接池  閱讀全文

          posted @ 2009-07-01 15:51 landor 閱讀(655) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 嘉定区| 十堰市| 灵寿县| 柳林县| 邯郸县| 洞头县| 凯里市| 化德县| 钦州市| 高碑店市| 崇仁县| 阳江市| 慈利县| 德昌县| 西城区| 兴和县| 永修县| 逊克县| 广平县| 镇原县| 聂拉木县| 安西县| 临高县| 怀集县| 北安市| 秦安县| 湛江市| 卓资县| 浦县| 通河县| 通道| 邵阳市| 淮安市| 武宣县| 襄汾县| 红原县| 富宁县| 天峻县| 桃园市| 清河县| 高碑店市|