go 语言 goroutine 与 主 goroutine 的代码的先行性问题。

demon_li · · 3393 次点击
<a href="/user/zzustu" title="@zzustu">@zzustu</a> 问题已知晓。我本地调试了很多遍,没有出现乱序,让其他人调试,出现了乱序,是预期的,所以go routine 也是不能保证顺序。我本意也是go 应该出现乱序。
#6
更多评论
我觉得你啊可能对线程有一些误解.java的线程也不是你想的那样.你得到这个结果一点都不奇怪. 当前执行的线程或者协程是不会马上放弃CPU给其他线程和线程的除非使用了相关的语句和遇到了可以放弃CPU的情况, 你的例子就是这种情况.
#1
package demon.research; public class BefortTest { public static Object lock = new Object(); public static void main(String[] args) { try{ Thread t = new Thread(new Runnable() { @Override public void run() { System.out.println(&#34;start&#34;); synchronized (lock) { lock.notifyAll(); } System.out.println(&#34;end&#34;); } }); t.start(); System.out.println(&#34;wait&#34;); synchronized (lock) { lock.wait(); } System.out.println(&#34;end all&#34;); } catch (Exception ex) { } } } 打印结果出现以下结果: wait start end all end 所以Java 代码一定有先行性的考虑,你的解释是不正确的。
#2