js/jsfun/fnQueue.js 队列操作
//队列遵循的是先进先出(FIFO)的原则,即最先进入队列的元素将是最先被移除的。队列的操作主要限定在队头和队尾进行,包括入队(enqueue)操作在队尾添加元素,出队(dequeue)操作在队头移除元素。队列中没有元素时,称为空队列。
//构造队列
let qKey = "q_1"
let qKey2 = "q_2"
//初始化队列,默认元素ID为当前http请求ID值,也可以自定义
fnQueue_init(qKey, 10, 20000)
let elementID0 = "elementID_0"
let elementID1 = "elementID_1"
let elementID2 = "elementID_2"
let elementID3 = "elementID_3"
let elementID4 = "elementID_4"
let elementID5 = "elementID_5"
for (let i = 0; i < 6; i++) {
fnQueue_push(qKey, "elementID_" + i)
}
for (let i = 0; i < 6; i++) {
fnQueue_push(qKey2, "elementID_" + i)
}
console.log("队列全部元素:", fnQueue_list(qKey))
console.log("队列长度:", fnQueue_len(qKey))
console.log("是否首个元素:0:", fnQueue_isFirst(qKey, elementID0))
console.log("是否首个元素:1:", fnQueue_isFirst(qKey, elementID1))
console.log("弹出首个元素:", fnQueue_pop(qKey))
console.log("是否首个元素:0:", fnQueue_isFirst(qKey, elementID0))
console.log("是否首个元素:1:", fnQueue_isFirst(qKey, elementID1))
console.log("队列长度:", fnQueue_len(qKey))
console.log("队列全部元素:", fnQueue_list(qKey))
console.log("队列2全部元素:", fnQueue_list(qKey2))
console.log("全部队列", fnQueue_allList())
console.log("删除队列元素", fnQueue_delete(qKey,elementID4))
console.log("队列长度:", fnQueue_len(qKey))
console.log("队列全部元素:", fnQueue_list(qKey))
console.log("队列首元素:", fnQueue_first(qKey))
console.log("队列当前元素默认ID", fnQueue_defaultID())
console.log("队列当前元素索引位置", fnQueue_index(qKey,elementID4))
console.log("队列信息:", fnQueue_info(qKey))
//判断队列元素是否是首元素,如果是,则进入业务
if (fnQueue_isFirst(qKey, elementID1)) {
console.log("queue_run_business 执行业务:", qKey, elementID1)
} else {
console.log("queue_run_business 非法进入业务:",qKey, elementID1)
}
//判断队列元素是否是首元素,如果还不是首元素,可以for也可以一直选项等待队列的首元素弹出
for (let i = 0; i < 100; i++) {
if (fnQueue_isFirst(qKey, elementID1)) {
console.log("我已经是队列首元素了,开始执行业务");
console.log("我的业务执行完了,记得将首元素移出,可以弹出首元素,也可以删除指定元素ID")
//如果已经知道首元素ID,建议用fnQueue_delete,删除指定元素比较靠谱,防止当前使用首元素已经被弹出
//弹出首元素
fnQueue_pop(qKey)
//删除执行元素
//fnQueue_delete(qKey,elementID1)
} else {
console.log("我还没进入队列首元素,只能耐心等待");
//休眠时间最好是执行业务的时间,或者1/2,太长了就会浪费大家等待时间,太短会造成CPU的资源浪费,适合最好
fnTime_sleep(20)
}
}
let bln= fnQueue_waitToFirst(qKey,elementID1,5000)
if(bln){
console.log("我已经是队列首元素了,开始执行业务");
console.log("我的业务执行完了,记得将首元素移出,可以弹出首元素,也可以删除指定元素ID")
//如果已经知道首元素ID,建议用fnQueue_delete,删除指定元素比较靠谱,防止当前使用首元素已经被弹出
//弹出首元素
fnQueue_pop(qKey)
//删除执行元素
//fnQueue_delete(qKey,elementID1)
}else {
console.log("我已经被删除了");
}
console.log("清除队列元素", fnQueue_clear(qKey));
console.log("清除全部队列元素", fnQueue_clearAll());