日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java中使用HashMap改進查找性能的步驟

瀏覽:145日期:2022-08-17 08:17:46

Java中,HashMap,其實就是鍵值對。一個Key,對應一個值;寫數據時,指定Key寫對應值;讀取時憑Key找到相應值。感覺就跟Redis差不多。

// 創建 HashMap 對象 SitesHashMap<Integer, String> Sites = new HashMap<Integer, String>();// 添加鍵值對Sites.put(1, 'Google');Sites.put(2, 'Runoob');Sites.put(3, 'Taobao');Sites.put(4, 'Zhihu');//讀取String val = Sites.get(1);//得到Google

為什么說可以用HashMap來改進性能呢?原因不是說HashMap這種數據結構存儲性能就比其他的,比如數組,集合先進多少。我主要看中的,是在知道Key的情況下,找到相應值得速度非常快。如果是用數組,最簡單的,用循環;講究一點,排好序,用折半查找(二分查找)。都比不上用Key在HashMap里直接讀取。不知道為什么HashMap在查找方面為啥這么快,估計是存儲結構,使用了啥樹,并為Key建立了索引。這是另外一個課題,以后再了解。昨天,我只是利用了這個特性,將運行幾個小時都沒結束的問題,只耗費了十幾秒。

問題如下:有25萬條記錄,每條記錄含經緯度;存在不同記錄坐標相同情況。現在想將坐標相同的記錄歸并在一起。

如果數據是保存在數據庫里,那么用SQL進行坐標分組,應該能解決問題。然而并沒有數據庫,數據是從gdb文件里讀出來的。

好吧,將數據保存到數組里,再新建一個集合;然后循環數組,與新集合中的記錄逐個比較,坐標相同就歸并到新集合,不同就插入新集合。最簡單了。結果2個小時過去了,還沒有結束的跡象。

想想也對,新集合越來越大,比較的次數也越來越多,仿佛棋盤里的大米一樣,每格的大米數量是前一格的兩倍;最后即使是整個國家糧庫的大米都放進去,都填不滿整個棋盤。

將25萬條記錄先排好序再處理?單是排序就忙死了,不行吧。

將25萬條記錄先保存到數據庫里,再分組?應該也可以,但總覺得笨了一些,而且速度應該也是以分鐘算的。

最后決定用HashMap來做這個新集合。如上所述,HashMap按照Key來寫入或讀取值。關鍵是這個Key怎么得來。上面的例子,是寫代碼的人自己給出了一些字符作為Key。而在我們項目中,可以用經緯度之和的哈希值來作為Key。哈希值相同的,就認為是經緯度相同,只需要判斷新集合中,是否存在這個Key對應的元素就可以了,根本無須循環比較。

由于存在兩個不同的經緯度加起來,結果是一樣的可能性,因此先將經度 乘以1000,再加緯度,這樣基本杜絕沖突的機會。

代碼如下:

private HashMap<Long,SimpleItem> recGeo(HashMap<Long, SimpleItem> map,String geo,int j){ /* 將相同坐標的記錄合成一條 HashMap<Long, SimpleItem> map, 新集合 String geo, 坐標字符串 int j 記錄ID */ try { Point p = (Point)reader.read(geo); /* 計算哈希值 因為如果采用循環來比較,數據量太大,速度太慢了 為避免不同坐標出現經度+緯度結果相同的情況,將經度 * 1000再相加 */ //計算Key long k = Long.valueOf(Double.doubleToLongBits(p.getX() * 1000 + p.getY())).hashCode();SimpleItem si = map.get(k); if(si != null){//新集合中該Key對應元素已存在,應該是相同坐標的記錄 si.getPointers().add(j);//歸并 } else {//否則插入 si = new SimpleItem(); si.setGeo(geo); List<Integer> pointers = new ArrayList(); pointers.add(j); si.setPointers(pointers); map.put(k,si); } } catch (ParseException e) { e.printStackTrace(); } return map;}private static GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory( null );private static WKTReader reader = new WKTReader( geometryFactory );class SimpleItem{ private Point geo; private List<Integer> pointers; public Point getGeo() { return geo; } public void setGeo(String geo) { try { this.geo = (Point)reader.read(geo); } catch (ParseException e) { e.printStackTrace(); } } public List<Integer> getPointers() { return pointers; } public void setPointers(List<Integer> pointers) { this.pointers = pointers; }}

短短幾秒,新集合即得到5萬個元素。

以上就是Java中使用HashMap改進查找性能的步驟的詳細內容,更多關于Java HashMap改進查找性能的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
肉色欧美久久久久久久免费看| 视频一区视频二区中文| 久久亚洲影院| 亚洲欧美日韩精品一区二区| 影音先锋国产精品| 喷白浆一区二区| 日韩中出av| 国产美女撒尿一区二区| 久久亚州av| 日本不卡免费高清视频在线| 天堂日韩电影| 91久久久久| 四虎在线精品| 国产精品毛片久久久| 精品国产黄a∨片高清在线| 国产精品成人a在线观看| 桃色一区二区| 久久国产精品99国产| 久久成人国产| 欧美日韩亚洲一区三区| 福利片在线一区二区| 99久久婷婷| 一区二区不卡| 精品黄色一级片| 日韩毛片视频| 久久大逼视频| 久久国产欧美日韩精品| 日韩1区在线| 久久亚洲精品中文字幕蜜潮电影| 一区免费视频| 国产区精品区| 久久精品一区二区不卡| 综合激情视频| 国产精品入口久久| 99久久亚洲精品| 日韩精品a在线观看91| 日本久久精品| 视频在线观看一区二区三区| 免费一级欧美在线观看视频| 久久国产中文字幕| 日本在线视频一区二区| 日韩久久视频| 日韩亚洲精品在线观看| 日本不卡免费高清视频在线| 蜜桃视频免费观看一区| 91亚洲精品在看在线观看高清| 樱桃成人精品视频在线播放| 欧美一区二区三区免费看| 国产精品天堂蜜av在线播放| 久久国产日韩| 欧美日韩一区二区高清| 亚洲二区在线| 国产精品久久久久久久久久妞妞 | 欧美亚洲免费| 日韩欧美在线中字| 丝袜国产日韩另类美女| 高清久久精品| 日韩美女精品| 免费久久久久久久久| 国产精品videosex极品| 九九久久电影| 国产精品tv| 蜜臀精品一区二区三区在线观看| 三上亚洲一区二区| 日韩成人精品一区二区三区| 国产精品88久久久久久| 精品久久美女| 日本强好片久久久久久aaa| 国产一区清纯| 精品九九久久| 日韩一区二区三区高清在线观看| 久久精品国语| 欧美激情 亚洲a∨综合| 午夜在线精品| 日本精品影院| 麻豆一区二区三区| 首页国产欧美久久| 中文字幕系列一区| 欧美精品不卡| 亚洲免费毛片| 不卡av一区二区| 中文在线免费视频| 国产精品久久久久久久久久白浆| 日韩一区精品视频| 视频福利一区| 福利视频一区| 国产精品久久久一区二区| 日韩在线a电影| 久久免费大视频| 超碰99在线| 久久成人福利| 日本高清久久| 综合国产精品| 丝袜亚洲精品中文字幕一区| 国产99精品| 日本少妇一区| 欧美激情精品| 日韩二区三区在线观看| 视频一区二区不卡| 亚洲女同中文字幕| 久久久人人人| 久久91导航| 精品国产免费人成网站| 久久精品亚洲| 免费在线成人| 国产精品日本一区二区不卡视频| 日韩欧美中文字幕一区二区三区| 蜜臀精品久久久久久蜜臀| 午夜一级久久| 亚洲一区日韩在线| 夜夜精品视频| 欧美日韩四区| 日韩亚洲在线| 久热精品在线| 日韩在线一区二区| 蜜桃传媒麻豆第一区在线观看| 好看的av在线不卡观看| 一区二区小说| 狠狠色综合网| 欧美专区18| 免费日韩视频| 丝袜a∨在线一区二区三区不卡| 香蕉久久夜色精品国产| 视频一区二区三区入口| 免费一级片91| 日韩精品免费观看视频| 91在线成人| 欧美黑人做爰爽爽爽| 精品成av人一区二区三区 | 欧美日韩国产一区二区三区不卡| 久久九九99| 亚洲国产日韩欧美在线| 在线午夜精品| 美女尤物久久精品| 久久99伊人| 亚洲男人在线| 国产伦精品一区二区三区千人斩 | 欧美精品aa| 国产一区二区三区亚洲| 日韩大片在线观看| 蜜桃国内精品久久久久软件9| av不卡免费看| 日韩欧美三区| 国产精品超碰| 免费一二一二在线视频| 午夜日韩在线| 日本久久一区| 国产精品白丝久久av网站| av最新在线| 欧美在线影院| 日精品一区二区三区| 国产精品调教视频| 亚洲欧洲高清| 夜夜嗨av一区二区三区网站四季av| 综合激情视频| 久久99偷拍| 欧美一级精品| 日韩久久99| 国产传媒在线| 六月婷婷一区| 久久99青青| 久久一区二区中文字幕| 免费美女久久99| 国产精品成人**免费视频| 欧美日韩精品免费观看视欧美高清免费大片 | 亚洲激情不卡| 日本午夜精品| 午夜av不卡| 在线免费观看亚洲| 国产精品免费精品自在线观看| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 精品视频一区二区三区在线观看| 国产成人免费av一区二区午夜| 亚洲午夜视频| 久久精品99久久久| 久久视频国产| 久久国产麻豆精品| 精品一区免费| 国产精品密蕾丝视频下载| 久久一区二区三区电影| 日韩综合小视频| 日韩免费久久| 天堂va在线高清一区| 国产66精品| 丝袜美腿亚洲色图| 成人亚洲精品| 亚洲人成网站在线在线观看| 三上亚洲一区二区| 免费不卡在线视频| 黄色在线网站噜噜噜| 蜜臀精品久久久久久蜜臀| 电影91久久久| 亚洲精品一二三**| 另类中文字幕国产精品| 国产日韩免费| 9国产精品视频| 成人国产精品久久| 日韩1区2区3区| 99国产精品视频免费观看一公开| 亚洲三级网址|