首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于线程和进程的一个问题

关于线程和进程的一个问题
EN

Stack Overflow用户
提问于 2011-04-30 22:46:34
回答 3查看 246关注 0票数 2

我读过一些关于线程和进程的教程,据说进程是由操作系统内核调度的,线程可以在用户模式下管理和调度。

我不理解“线程可以在用户模式下管理和调度”的说法,例如:生产者和消费者的问题?这是“在用户模式下调度”的一个例子吗?或者有人能给我解释一下?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-04-30 23:01:03

不确定你正在看的是什么教程,但是有两种方法可以调度线程。

第一种是用户模式调度,这基本上意味着一个进程使用Green threadsfibers来调度不同的线程运行,而不需要操作系统参与它的决策。这可以跨操作系统更好地移植,但通常不允许您利用多处理器的优势。

第二种是内核调度,这意味着各种线程对内核是可见的,并由内核调度,可能是同时在不同的处理器上进行调度。然而,这可能会使创建和调度线程的成本更高。

因此,它实际上并不依赖于您试图解决的问题。User-mode只是指在不涉及操作系统的情况下调度线程。一些早期的Java版本使用绿色/用户模式线程,但我相信大多数现在都使用本机/内核线程。

编辑: Coding Horror具有用户和内核模式之间差异的a nice overview

票数 4
EN

Stack Overflow用户

发布于 2011-04-30 22:58:03

获得更好的教程?官方的Java教程相当不错,并且包含了一个lesson on concurrency,它也包含了defines进程和线程的含义。

PS:线程是否在用户模式下管理/调度是Java虚拟机的实现细节,通常不需要应用程序编程人员关心。

票数 1
EN

Stack Overflow用户

发布于 2011-04-30 22:58:10

以用户模式调度意味着您可以控制软件的线程,但它们是由操作系统内核管理的。是的,生产者消费者问题是一个通常由你自己处理的例子(但它与用户模式调度没有直接关系),它有两个线程,一个生产者线程和一个消费者线程。两个线程访问相同的共享资源。这个资源必须是线程安全的,这意味着你必须确保共享资源不会因为两个线程同时访问它而被破坏。线程安全可以通过使用线程安全的数据类型或通过手动锁定或同步资源来保证。

然而,即使你对你的线程有一些控制,比如启动线程,停止线程,让线程休眠等,你也不能完全控制。操作系统仍在管理允许哪些线程占用cpu时间等。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5842483

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档