- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有几个关于线程的问题。能否请您澄清一下。
假设进程有一个或多个线程。如果进程被抢占/挂起,线程是否也被抢占或线程是否继续运行?
当挂起的进程被重新调度时,进程线程是否也被调度了?如果进程有进程有多个线程,哪些线程将被重新调度,基于什么?
如果进程中的线程正在运行并接收到信号(例如 Cntrl-C),并且信号的默认操作是终止进程,那么正在运行的线程是终止还是父进程也将终止?如果正在运行的进程由于某些信号而终止,线程会发生什么情况?
如果线程确实 fork fallowed exec,exec 的程序是否覆盖父进程或运行线程的地址空间?如果它覆盖父进程,线程、它们的数据、它们持有的锁会发生什么,以及一旦 exec 进程终止后它们如何被调度。
假设进程有多个线程,线程是如何调度的。如果其中一个线程在某些 I/O 上阻塞,其他线程如何被调度。父进程调度的线程是否在运行?
线程运行时当前内核变量指向什么(父进程task_stuct还是线程stack_struct?
如果带有线程的进程正在运行,当线程启动时,父进程是否进程被抢占以及每个线程如何被调度?
如果在 CPU 上运行的进程创建了多个线程,那么在多处理器系统上,父进程创建的线程是否会调度到另一个 CPU 上?
谢谢,象头神
最佳答案
首先,我应该澄清一些您似乎感到困惑的术语。在 POSIX 中,“进程”是一个地址空间加上至少一个控制线程,由进程 ID (PID) 标识。线程是进程中单独调度的执行上下文。
所有进程一开始只有一个线程,并且所有进程都至少有一个线程。现在,进入问题:
- Suppose process with one or multiple threads. If the process is prempted/suspended, does the threads also get preempted or does the threads continue to run?
线程是独立调度的。如果一个线程阻塞在像 connect()
这样的函数上,那么进程中的其他线程仍然可以被调度。
也可以请求挂起进程中的每个线程,例如通过向进程发送 SIGSTOP
。
- When the suspended process rescheduled, does the process threads also gets scheduled? If the process has process has multiple threads, which threads will be rescheduled and on what basis?
这仅在明确请求停止整个过程的情况下才有意义。如果您向进程发送 SIGCONT
以重新启动该进程,那么任何未被阻塞的线程都可以运行。如果可运行的线程多于可用于运行它们的处理器,则未指定哪个(哪些)先运行。
- If the thread in the process is running and recieves a signal(say Cntrl-C) and the default action of the signal is to terminate a process, does the running thread terminates or the parent process will also terminate? What happens to the threads if the running process terminates because of some signal?
如果线程接收到一个信号,如 SIGINT
或 SIGSEGV
,其操作是终止进程,则整个进程将终止。这意味着进程中的每个线程都会被毫不客气地杀死。
- If the thread does fork followed by exec, does the exece'd program overlays the address space of parent process or the running thread? If it overlays the parent process what happens to threads, their data, locks they are holding and how they get scheduled once the exec'd process terminates.
fork()
调用通过复制原始进程的地址空间来创建一个新进程,并且只复制在新进程中调用 fork()
的单个线程地址空间。
如果新进程中的那个线程调用execve()
,它将用执行程序替换新的、重复的地址空间。原始进程及其所有线程继续正常运行。
- Suppose process has multiple threads, how does the threads get scheduled. If one of the thread blocks on some I/O, how other threads gets scheduled. Does the threads scheduled with the parent process is running?
线程是独立调度的。任何未被阻塞的线程都可以运行。
- While the thread is running what the current kernel variable points(parent process task_stuct or threads stack_struct?
每个线程在内核中都有自己的task_struct
。用户空间称为“线程”的东西在内核空间称为“进程”。因此,current
始终指向与当前正在执行的线程对应的 task_struct
(在用户空间的意义上)。
- If the process with [a second] thread is running, when the thread starts does the parent process gets preempted and how each threads gets scheduled?
大概你指的是“进程的主线程”而不是“父进程”。和以前一样,线程是独立调度的。一个是否先于另一个运行是不确定的 - 如果您有多个 CPU,两个 CPU 可能会同时运行。
- If the process running on CPU creates multiple threads, does the threads created by the parent process schedule on another CPU on multiprocessor system?
这确实取决于内核,但肯定允许在其他 CPU 上执行线程。
关于linux - 线程 : some questions,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3754018/
Alexa 技能适用于第一个问题,但不适用于第二个问题。这是一个使用以下数组的困惑字母测验 var arr = [{"Q":"dcha","A":"chad"},{"Q":"goto","A":"to
我正在制作一个小问答 ios 应用程序。我希望第一个问题是随机的。我的代码如下。 let allQuestions = QuestionBank() var pickedAnswer : Bool =
我对 Dialogflow 比较陌生,我正在尝试创建一个医疗保健诊断语音聊天机器人,其工作方式如下。 用户体验 用户调用系统并受到聊天机器人的欢迎。 聊天机器人开始询问与分流相关的问题(例如,“您有慢
我正在尝试将一个表单(包含测试问题)提交到一个名为 Questions 的 mongo 集合中。我已经引用了运行服务器端代码的文件,我认为它应该都可以正常工作。这是我的代码: //add.html
import 'dart:async'; import 'question.dart'; import 'package:http/http.dart' as http; import 'dart:c
我想添加用户输入到列表中的任何字符串 run :- write('How many students you have: '),read(x),nl. enterNameOfStuden
我正在努力提高我的 JAVA 水平。现在我有一个关于线程的问题我不明白。 我尝试的代码是这样的, public class MyThread implements Runnable { pri
我正在为一个项目构建一个 XML 反序列化器,我经常遇到这种类型的代码情况: var myVariable = ParseNDecimal(xml.Element("myElement")) == n
我有一个 JSF 页面,它将创建一个新的 Comment。我将该页面的托管 bean 设为 RequestScoped 托管 bean。 @ManagedBean(name="PostComment"
房间和应用程序之间存在一对一的关系,意味着应用程序必须占用一个房间。如果我想获取未被应用占用的房间,如何写sql查询 最佳答案 select * from room r where not exist
我有一个 css 布局,其中我有一个单页网站 问题是我不想要滚动条所以我确实隐藏了溢出并且它工作正常但是当有不同的屏幕分辨率时,所以底部的内容被切断有没有办法解决这个问题 我的意思是,当内容适合首页时
我做了一个简单的算法,用于将整数转换为二进制,并将二进制作为字符串返回。目前,这些位被添加到列表的前面。在每一步连接字符串而不是附加到列表会更有效(就时间或空间而言)吗?为什么/为什么不? def t
我经常听说 mongodb 可以在一个集合级别执行原子性。您知道为什么以及如何将其与分片联系起来吗? replication 和 replicasets 之间的唯一区别是两者都是主/从(主要/次要),
我有几个关于线程的问题。能否请您澄清一下。 假设进程有一个或多个线程。如果进程被抢占/挂起,线程是否也被抢占或线程是否继续运行? 当挂起的进程被重新调度时,进程线程是否也被调度了?如果进程有进程有多个
我最近接受了一次采访,他问我单例设计模式是如何实现的,我告诉他使用静态变量和静态方法我们可以实现单例设计模式。 他似乎对答案满意但我想知道 我们可以有多少种不同的方式实现单例设计模式在 Java 中?
我以前使用 has_and_belongs_to_many,并已转换为 has_many :through。下面是它如何查找可以有很多用户玩的游戏列表。有了这个,我可以做 game.users 和 u
这是我的代码的骨架: var myArray: (Array | null); if (cnd) { myArray = []; myArray?.push(elt); // Question
使用ORLite时放置sqlite_unicode设置的正确位置在哪里? 最佳答案 不幸的是,没有一个真正好的地方。请参阅bug #61191: Enable sqllite_unicode in t
我承认我已经有一段时间没有使用 Perl 了,但这让我很难过。 这是问题: #!/usr/bin/perl use CGI::Carp qw(fatalsToBrowser); use DBI; pr
我有一个名为 Question 的模型。模型允许用户创建新问题。我正在尝试使用对象查询集填充多个表单。当我尝试使用查询集进行初始化时,会出现问题。我收到此错误 'Question' object i
我是一名优秀的程序员,十分优秀!