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

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

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

    Ordinary hut

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

    2011年3月4日

    java中wait和notify的簡單理解
    1 它們都是Object的屬性;
    2 wait:釋放對象鎖;由于把鎖釋放了,當(dāng)前線程就會卡住,繼續(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對象的鎖,同時當(dāng)前線程立即卡住,陷入等待
                    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) { //當(dāng)線程1釋放這個對象的鎖時,本線程立即得到
                TestMain.obj.name = "2"; //改值
                TestMain.obj.notify();//通知占用了TestMain.obj且當(dāng)前是等待的線程(線程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 閱讀(365) | 評論 (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來標(biāo)記上下午。
    以這個電子郵件的發(fā)送時間為例,如果要把這個時間轉(zhuǎn)化為UTC,可以使用一下公式:
    UTC + 時區(qū)差 = 本地時間
    時區(qū)差東為正,西為負。在此,把東八區(qū)時區(qū)差記為 +0800,
    UTC + (+0800) = 本地(北京)時間 (1)
    那么,UTC = 本地時間(北京時間))- 0800 (2)
    0942 - 0800 = 0142
    即UTC是當(dāng)天凌晨一點四十二分二十二秒。如果結(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 閱讀(295) | 評論 (0)編輯 收藏

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

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

         摘要: Camel與cxf  閱讀全文

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

         摘要: XPath記錄  閱讀全文

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

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

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

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

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

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

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

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

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

    主站蜘蛛池模板: 久久精品国产亚洲av麻豆蜜芽| 卡1卡2卡3卡4卡5免费视频| 午夜神器成在线人成在线人免费| 亚洲AV无码成人精品区天堂| 中文字幕不卡高清免费| 91麻豆精品国产自产在线观看亚洲 | 一级毛片免费播放试看60分钟| 日本特黄特色免费大片| 亚洲成AV人片高潮喷水| 免费一级特黄特色大片在线| 特级毛片aaaa级毛片免费| 亚洲午夜精品第一区二区8050| 免费国产成人午夜电影| 日韩在线视频线视频免费网站| 亚洲国产精品成人网址天堂| 亚洲免费日韩无码系列| 亚洲AV日韩AV永久无码久久| 最近2019中文字幕免费直播 | 亚洲一卡2卡3卡4卡5卡6卡| 在线看片无码永久免费aⅴ| 免费人成在线观看播放a| 狠狠综合久久综合88亚洲| 久久久久久久岛国免费播放| 亚洲国产日韩在线一区| 免费无码国产V片在线观看| 区久久AAA片69亚洲| 99久久人妻精品免费二区| 精品丝袜国产自在线拍亚洲| 日本一道本高清免费| 精品一区二区三区高清免费观看| 四虎影视大全免费入口| 日韩久久无码免费毛片软件 | 亚洲美女高清一区二区三区 | 日韩精品无码免费专区午夜 | 亚洲狠狠ady亚洲精品大秀| 免费无码又爽又刺激毛片| 久久嫩草影院免费看夜色| 亚洲一区在线视频| 国产亚洲美女精品久久久2020| 中文字幕免费高清视频| 青娱乐在线免费观看视频|