国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 編寫Java代碼制造一個內存溢出的情況

編寫Java代碼制造一個內存溢出的情況

2019-12-26 13:14goldensun JAVA教程

這篇文章主要介紹了編寫Java代碼制造一個內存溢出的情況,或許這種有意制造能夠更好地幫助理解Java中的內存溢出情況XD 需要的朋友可以參考下

 這將會是一篇比較邪惡的文章,當你想在某個人的生活中制造悲劇時你可能會去google搜索它。在Java的世界里,內存溢出僅僅只是你在這種情況下可能會引入的一種bug。你的受害者會在辦公室里度過幾天甚至是幾周的不眠之夜。

在這篇文章中我將會介紹兩種溢出方式,它們都是比較容易理解和重現的。并且它們都是來源現實項目的案例研究,但是為了讓你清晰地掌握,我把它們簡化了。

不過放心,在我們遇到和解決了很過溢出bug之后,類似的案例將會比你想象得更加普遍。

先來一個進入狀態的,在使用HashSet/HashMap時,所用鍵值沒有或者其equals()/hashCode()方法不正確,這會導致一個臭名昭著的錯誤。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
class KeylessEntry {
 
  static class Key {
   Integer id;
 
   Key(Integer id) {
     this.id = id;
   }
 
   @Override
   public int hashCode() {
     return id.hashCode();
   }
  }
 
  public static void main(String[] args) {
   Map m = new HashMap();
   while (true)
     for (int i = 0; i < 10000; i++)
      if (!m.containsKey(i))
        m.put(new Key(i), "Number:" + i);
  }
}

當你運行上面的代碼時,你可能會期望它運行起來永遠不會出問題,畢竟內置的緩存方案只會增加到10,000個元素,然后就不會再增加了,所有的key都已經出現在 HashMap中。然而,事情并非如此。元素將會一直增長, 因為Key這個類沒有在hashCode()后實現一個合適的equals()方法。


解決方法很簡單,只要和下面的示例一樣添加一個equals方法就可以了。但是在找到問題所在之前,你肯定已經花費了不少寶貴的腦細胞。
 

?
1
2
3
4
5
6
7
8
@Override
public boolean equals(Object o) {
  boolean response = false;
  if (o instanceof Key) {
   response = (((Key)o).id).equals(this.id);
  }
  return response;
}

下一個你得提醒朋友的是和String處理相關的操作。它的表現會很詭異,特別是結合JVM版本差異的時候。String的內部工作機制在 JDK 7u6中被改變了,所以如果你發現產品環境只是小版本號的區別,那么你已經準備好條件了。把類似下面的代碼給你的朋友調試,然后問他為什么這個bug只會在產品中出現。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
class Stringer {
  static final int MB = 1024*512;
 
  static String createLongString(int length){
   StringBuilder sb = new StringBuilder(length);
   for(int i=0; i < length; i++)
     sb.append('a');
   sb.append(System.nanoTime());
   return sb.toString();
  }
 
  public static void main(String[] args){
   List substrings = new ArrayList();
   for(int i=0; i< 100; i++){
     String longStr = createLongString(MB);
     String subStr = longStr.substring(1,10);
     substrings.add(subStr);
   }
  }
}

上面的代碼出了什么問題呢?當它在JDK 7u6之前的版本上運行的時候,返回的字符串將會保存一個對那個1M左右大小的字符串的引用,如果你運行的時候設置為-Xmx100m,你會得到一個意想不到的oom錯誤。結合你實驗環境中平臺和版本的差異,傷腦經的事情就產生了。

現在如果你想掩蓋你的足跡,我們可以引進一些更加高級的概念。比如

  •     在不同的類加載器中載入有破壞性的代碼,在加載的類被原始類加載器刪除后保持對它的引用,可以模擬一個類加載器溢出
  •     把攻擊性的代碼隱藏在finalize方法中,使得程序表現變得不可預測
  •     在一個長期運行的線程中加入棘手的組合,它可能在ThreadLocals中保存了一些可以被線程池訪問的東西,以便管理應用線程。


我希望我們給了你一些思考的原材料以及當你想修理某人時的一些素材。這將帶來無窮無盡的調試。除非你的朋友使用 Plumbr來查找溢出的所在地。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品xx老女人老配少 | 欧美日韩精品一区二区在线观看 | av在线免费观看一区二区 | 狠狠躁夜夜躁人人爽天天天天97 | 亚洲自拍偷拍精品 | 精品超碰| 北条麻妃在线一区二区免费播放 | 一区二区三区中文字幕 | 精品久久一二三区 | 亚洲国产精品福利 | 99福利影院 | 亚洲国产精品久久久 | 免费日韩 | 91精品免费在线观看 | 91久久久久久久久久久 | 日韩字幕在线 | 久久激情视频 | 国产视频在线播放 | 99亚洲精品| 免费观看h片 | 亚洲欧美日韩成人 | 久久久久久久久综合 | 中文字幕av一区二区 | 亚洲黄色片免费观看 | 91视频导航| 91国自产精品中文字幕亚洲 | 成年人免费在线看网站 | 亚洲 中文 欧美 日韩 在线观看 | 精品国产成人在线 | 偷拍一区二区 | 96自拍视频 | 欧美亚洲国产一区二区三区 | 亚洲精品国精品久久99热 | 国产成人午夜 | 色综合中文 | 午夜精品美女久久久久av福利 | 在线视频一区二区三区 | 精品国产乱码久久久久久久软件 | 国产精品欧美日韩在线观看 | 亚洲精品一 | 人体一区|