91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Egret之數據集合類型

發布時間:2020-07-11 18:20:03 來源:網絡 閱讀:424 作者:Aonaufly 欄目:開發技術

一 : 前景

首先必須說一下JS ES6里面有Map等數據集合類,BUT目前有些瀏覽器不支持,就像Webp一樣.目前無論是Egret還是LayaAir,默認都是ES5.為了在ES5中使用一些數據集合,本人寫了一個類庫.本文最后會附下載的地址.

二 : 測試HashMap

            let $hashmap : Data_sets_lib.HashMap<string , number > = null;
            let $arr : Array<Data_sets_lib.IConten2MapHash<string , number>> = [];
            let $prefix : string = null;
            for( let $i : number = 0 ; $i < 200000 ; $i ++ ){
                switch( $i % 10 ){
                    case 0:$prefix = `a`;break;
                    case 1:$prefix = `b`;break;
                    case 2:$prefix = `c`;break;
                    case 3:$prefix = `d`;break;
                    case 4:$prefix = `e`;break;
                    case 5:$prefix = `f`;break;
                    case 6:$prefix = `g`;break;
                    case 7:$prefix = `h`;break;
                    case 8:$prefix = `i`;break;
                    case 9:$prefix = `j`;break;
                }
                $arr.push({
                    _key : `${$prefix}_${$i}`,
                    _value : $i
                });
            }
            $hashmap = new Data_sets_lib.HashMap( $arr , Data_sets_lib.TYPE_SORT.___ASC___ , true , true , false );

            console.info( $hashmap );
            let $start_time : number = egret.getTimer();
            let $value : number =  $hashmap.getValue( "a_25501" );

            console.info( `Done : ${egret.getTimer() - $start_time} ms` );

            console.info(` Key : a_25501 , Value : ${$value}`);
            $hashmap.add( `a_25501` , 111 );
            $value = $hashmap.getValue( "a_25501" );
            console.info(` Key : a_25501 , Value : ${$value}`);

三 : 結果

Egret之數據集合類型

四 : 對比

本版的HashMap加入了對二分查找的支持 . 其意義我至少可以總結一個 :
目前中大型游戲都有很多的配置表,配置表都有ID號(一般是ASC升序排序的),這樣錄入HashMap,使用二分查找的時候,可以提高查找的速度.(冒泡查找的時間復雜度為 : n^2 , 二分查找的時間復雜度為 : logn ) .

使用非二分查找的情況(改動代碼如下):
Egret之數據集合類型
解釋 , 因為不用二分查找(使用的是冒泡排序),所以排序也沒有那個必要了.
得到結果如下(比使用二分查找的方案多耗時4ms):
Egret之數據集合類型

五 : 總結

雖說 , 在插入新數據時 , 二分方案耗時多于冒泡(二分需要先找到插入點(使用二分找點) , 再插入 , 冒泡直接使用push ) . 但是在錄入配置等工作時 , 二分完美得避開這一點 (配置表的ID號 , 本身就是排好序的). 拋開這一點 , 在中大型項目上 , 總體看 , 二分比冒泡的要好.

六 : 附件(類庫)

http://down.51cto.com/data/2457148

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

驻马店市| 宝坻区| 柘城县| 财经| 贡山| 额敏县| 平果县| 平顺县| 兴安盟| 成安县| 冕宁县| 云霄县| 犍为县| 开原市| 青神县| 富源县| 星座| 内丘县| 寻乌县| 合肥市| 阳江市| 灌阳县| 万载县| 杂多县| 兴国县| 扎鲁特旗| 宁武县| 武威市| 昭觉县| 临桂县| 牡丹江市| 白城市| 保德县| 临高县| 嘉兴市| 元朗区| 梁平县| 若羌县| 磐石市| 沅陵县| 莎车县|