[wizs] 利用 heart_beat 執行多排程工作

看板mud_sanc (Sanctuary - 聖殿)作者 (小太保)時間14年前 (2011/08/12 10:54), 編輯推噓0(000)
留言0則, 0人參與, 最新討論串1/1
這個 norr 及各位 wizs 們可參考。 最直覺的設法如下.. mapping schd = ([ "時間標記":({要做什麼事}), . . ]); 比方使用者A下了某指令後,該物件會替它做三件事,這三件事 的間隔時間為 1 秒,模擬如下... 00:00 下了指令 00:01 該物件替A做了第一件事 00:02 該物件替A做了第二件事 00:03 該物件替A做了第三件事 簡易的設定如下.. t=time(); t=t+1; schd[""+t]=({"good morning!\n"}); t=t+1; schd[""+t]=({"good evening!\n"}); t=t+1; schd[""+t]=({"good night!\n"}); 但是如果該物件『可同時接收其它玩家下指令時』,判斷就要改 成如下.. t=time(); t=t+1; if(delay_calls=(mixed)schd[""+t]) delay_calls+=({"good morning!\n"}); else delay_calls=({"good morning!\n"}); schd[""+t]=delay_calls; 也就是說,比方使用者A先下了指令,1 秒後使用者B也下了指 令,那 schd 的資料就會如下... schd = ([ "100000001":({"good morning!\n"}), "100000002":({"good evening!\n","good morning!\n"}), "100000003":({"good night!\n","good evening!\n"}), "100000004":({"good night!\n"}), ]); 使用者A更動了 100000001~100000003 的部份,而使用者B則 更動了 100000002~100000004 的部份。 接下來就是重點,在該物件的 heart_beat 中可以這樣寫.. keys_schd = keys(schd); // 對時間標記做排序, 由小到大 keys_schd = sort_array(keys_schd,"sort_by_time",this_object()); t=time(); // 讀取現在的時間, 假設是 100000002 foreach(tmp in keys_schd) { if(t>=atoi(tmp)) // 某些排程已經到了該執行的時間了 { // 在同一個時間處理該時間的所有排程工作 foreach(tmp2 in schd[tmp]) tell_room(env,tmp2); // 假設排程的工作是做 tell_room map_delete(schd,tmp); // 做完排程就把該時間標記資料自 schd 移除 } } 這樣每隔一個心跳時間,heart_beat 就會去做上述的判斷, 看哪些排程的執行時間已經到了,就執行它,而且把該排程 (因為已執行完了)移除。 而且遇到不明原因的 delay,使得應執行的排程沒被執行時 ,該排程的資料還是會在,於下一個心跳時間時,透過 if(t>=atoi(tmp)) 的判斷就會被執行(而且優先執行,因為有 sort_by_time) 以上的直覺式寫法供各位參考,實際上應該有更佳的寫法, 不過我懶得想了:p Laechan -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 117.19.98.233
文章代碼(AID): #1EH9NYH_ (mud_sanc)
文章代碼(AID): #1EH9NYH_ (mud_sanc)