Task suspending mechanism
The task is executed by walker from state to state till completed or error happened.
In practice, state transition may be triggered by outside event but this kind use case is not supported now.
The purpose of this issue is supporting suspend task at run-time and resume later.
Edited  by Arren Ping