亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Java性能優化之數據結構實例代碼

2024-07-13 10:15:52
字體:
來源:轉載
供稿:網友

—舉例(學生排課)—

正常思路的處理方法和優化過后的處理方法:

比如說給學生排課。學生和課程是一個多對多的關系。

java代碼,性能優化,java,數據結構

按照正常的邏輯 應該有一個關聯表來維護 兩者之間的關系。

java代碼,性能優化,java,數據結構

現在,添加一個約束條件用于校驗。如:張三上學期學過的課程,在排課的時候不應該再排這種課程。

java代碼,性能優化,java,數據結構

所以需要出現一個約束表(即:歷史成績表)。

java代碼,性能優化,java,數據結構

即:學生選課表,需要學生成績表作為約束。

—方案一:正常處理方式—

當一個學生進行再次選課的時候。需要查詢學生選課表看是否已經存在。

即有如下校驗:

//查詢 學生code和課程code分別為 A 和 B的數據是否存在  //list集合中存放 學生選課記錄全部的數據 List<StudentRecordEntity> ListStudentRecord=service.findAll();   //查詢數據,看是否已經存在 StudentRecordEntity enSr=ListStudentRecord.find(s=>s.學生Code==A && s.課程Code==B); If(enSr==null){   //學生沒有選該課程   //.... }else{   //學生已經選過該課程   //.... } 

對于上面這種代碼的寫法,非常的簡練。而且也非常易懂。

首先,假設有5000個學生,100門課程。那么對于學生選課的數據集中,數據量將是5000*100.數據量會是十萬級別的數量級。

在十萬條數據中,查詢學生=A課程=B的一條記錄。執行的效率會很低。因為find方法的查詢也就是where查詢,即通過遍歷數據集合來查找。

所以,使用上面的代碼。在數據量逐漸增長的過程中,程序的執行效率會大幅度下降。

ps:數據量增長,在該例子中并不太適合。例子可能不太恰當。總之,大概就是這個意思。)

—方案二:使用內存進行優化效率—

這種做法,需要消耗內存?;蛘哒f把校驗的工作向前做(數據的初始化,在部署系統的過程中進行)。即:在頁面加載的時候數據只調用提供的public方法進行校驗。

//學生Code 到  數組索引 Private Dictionary<string,int> _DicStudentCodeToArrayIndex;//課程Code 到  數據索引 Private Dictionary<string,int> _DicCourseCodeToArrayIndex;//所有學生 List<StudentEntity> ListStudent=service.findAllStudent();//所有課程 List<CourseEntity> ListCourse=service.findAllCourse();//所有 學生選課記錄 List<StudentCourseEntity> ListStudentRecord=service.finAll();Private int[,] _ConnStudentRecord=new int[ListStudent.count,ListCourse.count];//構造 學生、課程的 數組 用于快速查找字典索引 Private void GenerateDic(){	For(int i=0;	i<ListStudent.Count;	i++) 	    _DicStudentCodeToArrayIndex.Add(ListStudent[i].code,i)}For(int i=0;i<ListCourse.Count;i++){	_DicCourseCodeToArrayIndex.Add(ListCourse[i].code,i)}}//構造學生選課 匹配的 二維數組。 1表示 學生已選該課程 Private void GenerateArray(){Foreach(StudentRecordEntity sre in ListStudentRecord){	int x=_DicStudentCodeToArrayIndex[sre.學生Code];	int y=DicCourseCodeToArrayIndex[sre.課程Code];	ConnStudentRecord[x,y]=1;}}//對外公開的方法:根據學生Code 和課程Code 查詢 選課記錄是否存在 /// <returns>返回1 表示存在。返回0表示不存在</returns> Public void VerifyRecordByStudentCodeAndCourseCode(String pStudentCode,String pCourseCode){int x=_DicStudentCodeToArrayIndex[pStudentCode];int y=_DicCourseCodeToArrayIndex[pCourseCode];Return ConnStudentRecord[x,y];}

—性能分析—

分析一下第二種方案的表象。

1、方法很多。

2、使用的變量很多。

首先要說一下。該優化的目的,是提高學生在選課的時候,所出現的卡頓現象(校驗數據量大)。

分別對以上兩種方案進行分析:

假設學生為N,課程為M

第一種方案:

時間復雜度很容易計算第一種方案最小為O(NM)

第二種方案:

1、代碼多。但是給用戶提供的只有一個VerifyRecordByStudentCodeAndCourseCode方法。

2、變量多,因為該方案就是要使用內存提高效率的。

這個方法執行流程:1、在Dictionary中使用Code找Index2、使用Index查詢數組。

第一步中,Dictionary中查詢是使用的Hash查找算法。時間復雜度為O(lgN)時間比較快。第二步,時間復雜度為O(1),因為數組是連續的使用索引會直接查找對應的地址。

所以,使用第二種方案進行校驗,第二種方案時間復雜度為O(lgN+lgM)

—總結—

通過上面的分析,可以看出,內存的付出是可以提高程序的執行效率的。以上只是一個例子,優化的好壞取決于使用的數據結構。

以上就是本文關于Java性能優化之數據結構實例代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合久久久888| 亚洲已满18点击进入在线看片| 岛国av一区二区在线在线观看| 国产91精品视频在线观看| 国产一区视频在线播放| 精品久久久久久中文字幕| 亚洲第一区在线观看| 亚洲视频国产视频| 国产欧美久久久久久| 国产精品久久婷婷六月丁香| 亚洲美女久久久| 国产精品久久久久91| 亚洲人成亚洲人成在线观看| 精品国产户外野外| 国产精品久久久久久av下载红粉| 9.1国产丝袜在线观看| 亚洲一级免费视频| 国产精品视频白浆免费视频| 日韩在线免费高清视频| 红桃视频成人在线观看| 亚洲精品乱码久久久久久按摩观| 欧美精品中文字幕一区| 国产视频精品免费播放| 久久国产精品影片| 国外视频精品毛片| 黑人狂躁日本妞一区二区三区| 国产v综合ⅴ日韩v欧美大片| 欧美性生活大片免费观看网址| 在线视频亚洲欧美| 成人激情春色网| 中文字幕日韩高清| 色噜噜狠狠色综合网图区| 尤物精品国产第一福利三区| 久久天天躁狠狠躁夜夜av| 欧美激情va永久在线播放| 亚洲欧美日韩精品久久奇米色影视| 精品久久中文字幕| 91精品国产自产在线观看永久| 久久久亚洲国产天美传媒修理工| 亚洲一区二区免费在线| 国产成人综合亚洲| 亚洲午夜久久久久久久| 久久精品国产欧美亚洲人人爽| 国产精品成人av在线| 日韩av一区二区在线观看| 亚洲女人天堂视频| 亚洲色图欧美制服丝袜另类第一页| 亚洲天堂成人在线视频| 免费91麻豆精品国产自产在线观看| 欧美在线一区二区三区四| 亚洲全黄一级网站| 狠狠躁夜夜躁人人爽超碰91| 日韩欧美成人网| 久久影视电视剧凤归四时歌| 国产欧美一区二区白浆黑人| 欧美中文字幕在线视频| 成人午夜黄色影院| 日韩欧美一区二区三区| 欧美性受xxxx白人性爽| 欧美日韩国产精品一区二区不卡中文| 亚洲欧美日韩另类| 国产女人18毛片水18精品| 欧美第一淫aaasss性| 亚洲国产精品yw在线观看| 国产成人精品av| 国产精品尤物福利片在线观看| 国产视频精品免费播放| 日韩美女视频中文字幕| 国产97在线亚洲| 精品亚洲aⅴ在线观看| 91精品视频观看| 国内精品久久久久久影视8| 国产精品成人久久久久| 北条麻妃99精品青青久久| 性金发美女69hd大尺寸| 久热精品视频在线免费观看| 国产精品美乳一区二区免费| 最近中文字幕日韩精品| 亚洲精品第一国产综合精品| 亚洲区中文字幕| www.欧美精品一二三区| 国产成人一区二区三区小说| 欧美在线影院在线视频| 欧美激情精品在线| 在线观看欧美视频| 成人亚洲综合色就1024| 一本色道久久综合亚洲精品小说| 亚洲电影免费观看高清完整版| 亚洲国产日韩欧美在线动漫| 国产精品久久久久久久久久小说| 国产亚洲精品久久久久久牛牛| 秋霞av国产精品一区| 日韩视频免费在线观看| 中文字幕v亚洲ⅴv天堂| 欧美在线观看www| 国产精品99导航| 一夜七次郎国产精品亚洲| 日韩欧美精品免费在线| 日韩影视在线观看| 欧美在线不卡区| 91久久精品国产91性色| 中文字幕亚洲综合久久筱田步美| 亚洲日韩欧美视频一区| 欧美黑人一区二区三区| 色偷偷888欧美精品久久久| www.日本久久久久com.| xvideos亚洲| 91视频国产精品| 欧美色播在线播放| 庆余年2免费日韩剧观看大牛| 97国产suv精品一区二区62| 亚洲精品日韩丝袜精品| 久久久国产在线视频| 国产精品私拍pans大尺度在线| 国产综合福利在线| 日韩在线视频观看正片免费网站| 欧美日韩电影在线观看| 久久久国产影院| 日韩在线精品一区| 亚洲欧美中文在线视频| 成人午夜在线观看| 欧美性生活大片免费观看网址| 欧美激情视频网站| 精品久久久久久国产91| 国产99久久精品一区二区永久免费| 亚洲精品电影网在线观看| 国产91色在线播放| 欧美日韩国产限制| 亚洲qvod图片区电影| 日韩二区三区在线| 国产精品偷伦视频免费观看国产| 久久精品99久久香蕉国产色戒| 亚洲热线99精品视频| 日韩成人av在线| 国产精品日韩欧美大师| 中文字幕亚洲一区二区三区| 亚洲的天堂在线中文字幕| yellow中文字幕久久| 日韩在线视频观看| 国产成人精彩在线视频九色| 国产成人久久久精品一区| 1769国内精品视频在线播放| 欧美日韩激情视频| 国产精品爽爽爽| www国产精品com| 亚洲精品99999| 欧美精品做受xxx性少妇| 久久免费成人精品视频| 久久精品青青大伊人av| 69久久夜色精品国产7777| 欧美激情亚洲视频| 欧美电影院免费观看| 91精品在线看| 欧美成人激情视频免费观看| 国产视频丨精品|在线观看| 国产区精品在线观看| 久久久久久亚洲精品| 81精品国产乱码久久久久久| 亚洲影院色无极综合| 国产精品嫩草视频| 欧美激情亚洲视频| 国产精品免费久久久久久| 中文字幕亚洲综合久久| 免费不卡在线观看av|