本篇文章為大家展示了如何理解queue隊列,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
今天有一個需求需要隨時更新數(shù)據(jù)需要及時刪除過期數(shù)據(jù),就用到隊列了。每執(zhí)行一次定時任務(wù)就往queue中加一次數(shù)據(jù),所以需要在一個獨立于定時任務(wù)的類中加靜態(tài)屬性:
public static Queue<CB_SingleDolaryToday> queue = new LinkedList<>()
因為需要求元素和所以加靜態(tài)屬性 public static double sumDolary = 0.0;
在定時任務(wù)中需要更新隊列并刪除過期元素
/**
* 循環(huán)檢測隊列頭元素,如果超期則移除該元素 并繼續(xù)進(jìn)行檢測,直到檢測出未超期
*/
//以頭元素是否超期為條件,頭元素沒超期其他就不再超期
while (isDelay(DolaryTodayMark.queue.peek())) {
CB_SingleDolaryToday dt = DolaryTodayMark.queue.poll();
if (dt == null) {
break;
}
//并減去刪除的元素
DolaryTodayMark.sumDolary = DolaryTodayMark.sumDolary - Double.parseDouble(dt.getDolary());
}
private boolean isDelay(CB_SingleDolaryToday dolaryToday) {
// 如果隊列頭元素為空,則返回false,說明沒有元素超期
if (dolaryToday == null) {
return false;
} else if (System.currentTimeMillis() - dolaryToday.getTime() > delayTime) {
return true;
} else {
return false;
}
}
上述內(nèi)容就是如何理解queue隊列,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。