如何學好java

          如何學好java,其實很簡單,只要用心體會,慢慢積累!
          posts - 106, comments - 7, trackbacks - 0, articles - 3
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          2012年11月21日

          http://www.luocong.com/dsaanotes/index-Z-H-1.htm

          posted @ 2014-01-02 22:50 哈希 閱讀(139) | 評論 (0)編輯 收藏

               摘要: 冒泡排序(Bubble Sort)是一種簡單的排序算法。它重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個算法的名字由來是因為越小的元素會經由交換慢慢“浮”到數列的頂端。   冒泡排序算法的運作如下:  比較相鄰的元素。如果第一個比第二個大,就交換他們...  閱讀全文

          posted @ 2014-01-02 22:32 哈希 閱讀(194) | 評論 (0)編輯 收藏

          http://www.cnblogs.com/szfei/archive/2012/08/08/2628208.html    hashmap遍歷

          posted @ 2012-12-22 10:45 哈希 閱讀(156) | 評論 (0)編輯 收藏

          基本介紹:
                    showModalDialog()         (IE 4+ 支持)
                    showModelessDialog()      (IE 5+ 支持)
                    window.showModalDialog()                  方法用來創建一個顯示HTML內容的模態對話框。
                    window.showModelessDialog()             方法用來創建一個顯示HTML內容的非模態對話框。
          使用方法:
                    vReturnValue = window.showModalDialog(sURL [, vArguments] [,sFeatures])
                    vReturnValue = window.showModelessDialog(sURL [, vArguments] [,sFeatures])
          參數說明:
                   sURL          --  必選參數,類型:字符串。用來指定對話框要顯示的文檔的URL。
                   vArguments    -- 可選參數,類型:變體。用來向對話框傳遞參數。傳遞的參數類型不限,包括數組等。對話框通過
           

                                    window.dialogArguments來取得傳遞進來的參數。
                   sFeatures     -- 可選參數,類型:字符串。用來描述對話框的外觀等信息,可以使用以下的一個或幾個,用分號“;”隔開。
          ----------------
          1.    dialogHeight:    對話框高度,不小于100px
          2.    dialogWidth:    對話框寬度。
          3.    dialogLeft:     離屏幕左的距離。
          4.    dialogTop:     離屏幕上的距離。
          5.    center:          { yes | no | 1 | 0 } :              是否居中,默認yes,但仍可以指定高度和寬度。
          6.    help:             {yes | no | 1 | 0 }:                是否顯示幫助按鈕,默認yes。
          7.    resizable:       {yes | no | 1 | 0 } [IE5+]:     是否可被改變大小。默認no。
          8.    status:          {yes | no | 1 | 0 } [IE5+]:      是否顯示狀態欄。默認為yes[ Modeless]或no[Modal]。
          9.    scroll:            { yes | no | 1 | 0 | on | off }:是否顯示滾動條。默認為yes。

          下面幾個屬性是用在HTA中的,在一般的網頁中一般不使用。
          10.    dialogHide:{ yes | no | 1 | 0 | on | off }:在
          打印或者打印預覽時對話框是否隱藏。默認為no。
          11.    edge:{ sunken | raised }:指明對話框的邊框樣式。默認為raised。
          12.    unadorned:{ yes | no | 1 | 0 | on | off }:默認為no。

          參數傳遞:
          1. 要想對話框傳遞參數,是通過vArguments來進行傳遞的。類型不限制,對于字符串類型,最大為4096個字符。也可以傳遞對象,例如:
          -------------------------------
          parent.htm
          <script>
                    var obj = new Object();
                    obj.name="51js";
                    window.showModalDialog("modal.htm",obj,"dialogWidth=200px;dialogHeight=100px");
          </script>
          modal.htm
          <script>
                    var obj = window.dialogArguments
                    alert("您傳遞的參數為:" + obj.name)
          </script>
          -------------------------------
          2.可以通過window.returnValue向打開對話框的窗口返回信息,當然也可以是對象。例如:
          ------------------------------
          parent.htm
          <script>
                    str =window.showModalDialog("modal.htm",,"dialogWidth=200px;dialogHeight=100px");
                    alert(str);
          </script>
          modal.htm
          <script>
                    window.returnValue="http://homepage.yesky.com";
          </script>

          常見技巧:

          一、怎樣才讓在showModalDialog和showModelessDialog的超連接不彈出新窗口?
            在被打開的網頁里加上<base target="_self">就可以了。這句話一般是放在<head>之間的。

          二、怎樣才刷新showModalDialog和showModelessDialog里的內容?
            在showModalDialog和showModelessDialog里是不能按F5刷新的,又不能彈出菜單。這個只能依靠

          javascript了,以下是相關代碼:

          <body onkeydown="if (event.keyCode==116){reload.click()}">
          <a id="reload" href="filename.htm" style="display:none">reload...</a>

            將filename.htm替換成網頁的名字然后將它放到你打開的網頁里,按F5就可以刷新了,注意,這個要

          配合<base target="_self">使用,不然你按下F5會彈出新窗口的。

          三、如何用javascript關掉showModalDialog(或showModelessDialog)打開的窗口。
            <input type="button" value="關閉" onclick="window.close()">
            也要配合<base target="_self">,不然會打開一個新的IE窗口,然后再關掉的。

          四、Math.random與showModalDialog。

             當你設置的彈出網頁固定時(如上面的"modal.htm"頁面),ie很可能到臨時文件區,下載上次產生的該頁面(openPage.html),而沒有重新加載,

             對于動態加載的頁面來說,這樣往往產生誤會,如沒有及時更新數據,也就更不利于開發者測試。所以,你可以采用如下方式:

                var strPage = “/medal.htm?random="+Math.random();

             這樣每次產生的strPage是不一樣的,原因也就不言自明了。

           

          下面舉兩個例子

          一、返回一個字符串

          首先是父頁面有個按鈕,用來打開Modal頁面userList.aspx

          復制代碼
           function openWin()
              {
                   str =window.showModalDialog("userList.aspx",window,"status:0;help:0;edge:sunken;dialogWidth=700px;dialogHeight=400px");

                  if(str!=undefined && typeof(str)!=undefined && str!="undefined" && str!="")
                  {
                    document.getElementById("txtuserid").value=str;
                  }else
                  {
                   document.getElementById("txtuserid").value="";
                  }
              }
          復制代碼

          str就是子頁面返回過來的數據,我們把它添加到父類的一個表單元素中

          子頁面

              function getValue()
                  {          
                   var selectValue=$(":radio:checked").val();
                   window.returnValue=selectValue;
                   window.close();
                  }

          在這里我們把子頁面里的值返回到父頁面里就可以了,然后關閉頁面就可以了

          二、返回一個數據

          父頁面

          復制代碼
               function openWin()
               {
           
                  array =window.showModalDialog("demo2.aspx",window,"status:0;help:0;edge:sunken;dialogWidth=700px;dialogHeight=400px;scroll:no");
                 
                    document.getElementById("username").value=array[0];
                    document.getElementById("sex").value=array[0];
                   
               
              }
          復制代碼

          子頁面

           

          復制代碼
             function getValue()
                 {
                   var array=new Array();
                   
                   array[0]=document.getElementById("username").value;
                   Array[1]=document.getElementById("sex").value;
                   window.returnValue=array;
                   window.close();
                 }
          復制代碼

          返回一個數組就可以了,如果用open打開的話,在搜狗或者360瀏覽器打開的是一個頁面或者阻攔什么的

           前段時間在后臺使用JS的winodw.showModalDialog來查看靜態頁面內容,發現不能及時顯示更新后的頁面內容,用open打開有時也會出現這種問題

          解決辦法 
            window.showModalDialog(getUrl+"?Rnd="+Math.random(),"","dialogWidth:600px;dialogHeight:400px;help:no;scroll:yes;center:yes;status:no;");
          這樣就不會有緩存了

          多思考,多創新,才是正道!

          posted @ 2012-11-26 12:51 哈希 閱讀(917) | 評論 (1)編輯 收藏

          1.判斷select選項中 是否存在Value="paraValue"的Item 
          $("#selectid option[@value='paraValue']").length>0
          2.向select選項中 加入一個Item 
          $("#selectid").append("<option value=''>1111<option>");
          3.從select選項中 刪除一個Item 
          $("#selectid").remove("<option value=''>1111<option>");
          4.修改select選項中 value="paraValue"的text為"paraText" 
          $("#selectid option:selected").attr("value","paraValue").attr("text","paraText");
          5. 設置select中text="paraText"的第一個Item為選中 
          $("#selectid option[@text='paraText']").attr("selected","true")
          6.設置select中 value="paraValue"的Item為選中 
          $("#selectid option[@value='paraValue']").attr("selected","true")

          7.設置select中第一 個Item為選中 
          $("#selectid option").eq(0).attr('selected', 'true');

          8. 得到select的當前選中項的value 
          $("#selectid").val();
          9.得到select的當前選中項的text 
          $("#selectid").text();
          10. 得到select的當前選中項的Index 
          document.getElementById("select1").selectedIndex;
          $("#selectid").get(0).selectedIndex
          11. 清空select的項
          $("#selectid").empty();

          JS版本的:

        1. //1.判斷select選項中 是否存在Value="paraValue"的Item   
        2. function jsSelectIsExitItem(objSelect,objItemValue)   
        3. {   
        4.      var isExit = false ;   
        5.      for ( var i=0;i;I++)   
        6.      {   
        7.          if (objSelect.options[i].value == objItemValue)   
        8.          {   
        9.              isExit = true ;   
        10.              break ;   
        11.          }   
        12.      }        
        13.      return isExit;   
        14. }   
        15.   
        16. //2.向select選項中 加入一個Item   
        17. function jsAddItemToSelect(objSelect,objItemText,objItemValue, objItemPos)   
        18. {   
        19.      //判斷是否存在   
        20.      if (jsSelectIsExitItem(objSelect,objItemValue))   
        21.      {   
        22.          alert( "該Item的 Value值已經存在" );   
        23.      }   
        24.      else   
        25.      {   
        26.          var varItem = new Option(objItemText,objItemValue);   
        27. //       objSelect.options[objSelect.options.length] = varItem;   
        28.          objSelect.options.add(varItem, objItemPos);   
        29.          alert( "成功加入" );   
        30.      }      
        31. }   
        32.   
        33. //3.從select選項中 刪除一個Item   
        34. function jsRemoveItemFromSelect(objSelect,objItemValue)   
        35. {   
        36.      //判斷是否存在   
        37.      if (jsSelectIsExitItem(objSelect,objItemValue))   
        38.      {   
        39.          for ( var i=0;i;I++)   
        40.          {   
        41.              if (objSelect.options[i].value == objItemValue)   
        42.              {   
        43.                  objSelect.options.remove(i);   
        44.                  break ;   
        45.              }   
        46.          }          
        47.          alert( "成功刪除" );              
        48.      }   
        49.      else   
        50.      {   
        51.          alert( "該 select中 不存在該項" );   
        52.      }      
        53. }   
        54.   
        55. //4.修改select選項中 value="paraValue"的text為"paraText"   
        56. function jsUpdateItemToSelect(objSelect,objItemText,objItemValue)   
        57. {   
        58.      //判斷是否存在   
        59.      if (jsSelectIsExitItem(objSelect,objItemValue))   
        60.      {   
        61.          for ( var i=0;i;I++)   
        62.          {   
        63.              if (objSelect.options[i].value == objItemValue)   
        64.              {   
        65.                  objSelect.options[i].text = objItemText;   
        66.                  break ;   
        67.              }   
        68.          }          
        69.          alert( "成功修改" );              
        70.      }   
        71.      else   
        72.      {   
        73.          alert( "該 select中 不存在該項" );   
        74.      }      
        75. }   
        76.           
        77. //5.設置select中text="paraText"的第一個 Item為選中   
        78. function jsSelectItemByValue(objSelect,objItemText)   
        79. {      
        80.      //判斷是否存在   
        81.      var isExit = false ;   
        82.      for ( var i=0;i;I++)   
        83.      {   
        84.          if (objSelect.options[i].text == objItemText)   
        85.          {   
        86.              objSelect.options[i].selected = true ;   
        87.              isExit = true ;   
        88.              break ;   
        89.          }   
        90.      }        
        91.      //Show出結果   
        92.      if (isExit)   
        93.      {   
        94.          alert( "成功選中" );              
        95.      }   
        96.      else   
        97.      {   
        98.          alert( "該 select中 不存在該項" );   
        99.      }      
        100. }   
        101.   
        102. //6.設置select中value="paraValue"的Item 為選中   
        103. document.all.objSelect.value = objItemValue;   
        104.   
        105. //7.得到select的當前選中項的value   
        106. var currSelectValue = document.all.objSelect.value;   
        107.   
        108. //8.得到select的當前選中項的text   
        109. var currSelectText = document.all.objSelect.options[document.all.objSelect.selectedIndex].text;   
        110.   
        111. //9.得到select的當前選中項的Index   
        112. var currSelectIndex = document.all.objSelect.selectedIndex;   
        113.   
        114. //10.清空select的項   
        115. document.all.objSelect.options.length = 0;  
        116. posted @ 2012-11-26 12:46 哈希 閱讀(237) | 評論 (0)編輯 收藏

          封裝 繼承 多態

          面向對象的三個基本特征是:封裝、繼承、多態。

           

          封裝

          封裝最好理解了。封裝是面向對象的特征之一,是對象和類概念的主要特性。

          封裝,也就是把客觀事物封裝成抽象的類,并且類可以把自己的數據和方法只讓可信的類或者對象操作,對不可信的進行信息隱藏。

          繼承

          面向對象編程 (OOP) 語言的一個主要功能就是“繼承”。繼承是指這樣一種能力:它可以使用現有類的所有功能,并在無需重新編寫原來的類的情況下對這些功能進行擴展。

          通過繼承創建的新類稱為“子類”或“派生類”。

          被繼承的類稱為“基類”、“父類”或“超類”。

          繼承的過程,就是從一般到特殊的過程。

          要實現繼承,可以通過“繼承”(Inheritance)和“組合”(Composition)來實現。

          在某些 OOP 語言中,一個子類可以繼承多個基類。但是一般情況下,一個子類只能有一個基類,要實現多重繼承,可以通過多級繼承來實現。

          繼承概念的實現方式有三類:實現繼承、接口繼承和可視繼承。

          Ø 實現繼承是指使用基類的屬性和方法而無需額外編碼的能力;

          Ø 接口繼承是指僅使用屬性和方法的名稱、但是子類必須提供實現的能力;

          Ø 可視繼承是指子窗體(類)使用基窗體(類)的外觀和實現代碼的能力。

          在考慮使用繼承時,有一點需要注意,那就是兩個類之間的關系應該是“屬于”關系。例如,Employee 是一個人,Manager 也是一個人,因此這兩個類都可以繼承 Person 類。但是 Leg 類卻不能繼承 Person 類,因為腿并不是一個人。

          抽象類僅定義將由子類創建的一般屬性和方法,創建抽象類時,請使用關鍵字 Interface 而不是 Class。

          OO開發范式大致為:劃分對象→抽象類→將類組織成為層次化結構(繼承和合成) →用類與實例進行設計和實現幾個階段。

          多態

          多態性(polymorphisn)是允許你將父對象設置成為和一個或更多的他的子對象相等的技術,賦值之后,父對象就可以根據當前賦值給它的子對象的特性以不同的方式運作。簡單的說,就是一句話:允許將子類類型的指針賦值給父類類型的指針。

          實現多態,有二種方式,覆蓋,重載。

          覆蓋,是指子類重新定義父類的虛函數的做法。

          重載,是指允許存在多個同名函數,而這些函數的參數表不同(或許參數個數不同,或許參數類型不同,或許兩者都不同)。

          其實,重載的概念并不屬于“面向對象編程”,重載的實現是:編譯器根據函數不同的參數表,對同名函數的名稱做修飾,然后這些同名函數就成了不同的函數(至少對于編譯器來說是這樣的)。如,有兩個同名函數:function func(p:integer):integer;和function func(p:string):integer;。那么編譯器做過修飾后的函數名稱可能是這樣的:int_func、str_func。對于這兩個函數的調用,在編譯器間就已經確定了,是靜態的(記住:是靜態)。也就是說,它們的地址在編譯期就綁定了(早綁定),因此,重載和多態無關!真正和多態相關的是 “覆蓋”。當子類重新定義了父類的虛函數后,父類指針根據賦給它的不同的子類指針,動態(記住:是動態!)的調用屬于子類的該函數,這樣的函數調用在編譯期間是無法確定的(調用的子類的虛函數的地址無法給出)。因此,這樣的函數地址是在運行期綁定的(晚邦定)。結論就是:重載只是一種語言特性,與多態無關,與面向對象也無關!引用一句Bruce Eckel的話:“不要犯傻,如果它不是晚邦定,它就不是多態。”

          那么,多態的作用是什么呢?我們知道,封裝可以隱藏實現細節,使得代碼模塊化;繼承可以擴展已存在的代碼模塊(類);它們的目的都是為了——代碼重用。而多態則是為了實現另一個目的——接口重用!多態的作用,就是為了類在繼承和派生的時候,保證使用“家譜”中任一類的實例的某一屬性時的正確調用。

          泛化(Generalization)

           

          在上圖中,空心的三角表示繼承關系(類繼承),在UML的術語中,這種關系被稱為泛化(Generalization)。Person(人)是基類,Teacher(教師)、Student(學生)、Guest(來賓)是子類。

          若在邏輯上B是A的“一種”,并且A的所有功能和屬性對B而言都有意義,則允許B繼承A的功能和屬性。

          例如,教師是人,Teacher 是Person的“一種”(a kind of )。那么類Teacher可以從類Person派生(繼承)。

          如果A是基類,B是A的派生類,那么B將繼承A的數據和函數。

          如果類A和類B毫不相關,不可以為了使B的功能更多些而讓B繼承A的功能和屬性。

          若在邏輯上B是A的“一種”(a kind of ),則允許B繼承A的功能和屬性。

          聚合(組合)

           

          若在邏輯上A是B的“一部分”(a part of),則不允許B從A派生,而是要用A和其它東西組合出B。

          例如,眼(Eye)、鼻(Nose)、口(Mouth)、耳(Ear)是頭(Head)的一部分,所以類Head應該由類Eye、Nose、Mouth、Ear組合而成,不是派生(繼承)而成。

          聚合的類型分為無、共享(聚合)、復合(組合)三類。

          聚合(aggregation)

           

          上面圖中,有一個菱形(空心)表示聚合(aggregation)(聚合類型為共享),聚合的意義表示has-a關系。聚合是一種相對松散的關系,聚合類B不需要對被聚合的類A負責。

          組合(composition)

           

          這幅圖與上面的唯一區別是菱形為實心的,它代表了一種更為堅固的關系——組合(composition)(聚合類型為復合)。組合表示的關系也是has-a,不過在這里,A的生命期受B控制。即A會隨著B的創建而創建,隨B的消亡而消亡。

          依賴(Dependency)

           

          這里B與A的關系只是一種依賴(Dependency)關系,這種關系表明,如果類A被修改,那么類B會受到影響

          posted @ 2012-11-21 09:32 哈希 閱讀(221) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 贵南县| 烟台市| 哈密市| 临西县| 南木林县| 岳西县| 武山县| 博爱县| 盈江县| 林周县| 新宾| 东辽县| 宁都县| 宜兴市| 阜南县| 庆安县| 抚顺市| 股票| 华阴市| 青海省| 凤凰县| 政和县| 吴忠市| 临湘市| 牡丹江市| 开远市| 沂水县| 嘉峪关市| 商城县| 博湖县| 平果县| 西贡区| 古田县| 深圳市| 新竹市| 视频| 佳木斯市| 安丘市| 金乡县| 凤凰县| 会同县|