協(xié)程和多線程下的線程類似:有自己的堆棧,自己的局部變量,有自己的指令指針,但是和其他協(xié)程程序共享全局變量等信息。線程和協(xié)程的主要不同在于:多處理器的情況下,概念上來說多線程是同時運行多個線程,而協(xié)程是通過協(xié)作來完成,任何時刻只有一個協(xié)程程序在運行。并且這個在運行的協(xié)程只有明確被要求掛起時才會被掛起
你可以使用coroutine.create來創(chuàng)建協(xié)程:
協(xié)程有三種狀態(tài):掛起,運行,停止。創(chuàng)建后是掛起狀態(tài),即不自動運行。status函數(shù)可以查看當前狀態(tài)。協(xié)程真正強大的地方在于他可以通過yield函數(shù)將一段正在運行的代碼掛起。
lua的resume-yield可以互相交換數(shù)據(jù)
如果沒有對應(yīng)的yield,傳遞給resume的額外參數(shù)將作為參數(shù)傳遞給協(xié)程主函數(shù):
如果沒有錯誤的話,resume將返回true和yield的參數(shù):
同樣地,yield也將返回由對應(yīng)的resume傳遞而來的參數(shù):
最后,協(xié)程主函數(shù)返回值將作為與之對應(yīng)的resume的返回值(第一個參數(shù)是true)。
新聞熱點
疑難解答
圖片精選