当前位置: 首页 > 面试题库 >

区分Java线程和OS线程?

沈琨
2023-03-14
问题内容

如何区分正在运行的Java线程和本机线程?

在Linux中,每个子进程都有一个父进程,他们说0是所有进程的父进程,所有分叉的Java线程中都会有一个父线程吗?

我如何知道哪个Java线程与OS线程相关(如果Java线程派生了本机进程线程)。

Java线程和OS线程有任何命名约定吗?

可以从另一个Java代码中挂起或杀死正在运行的Java线程吗?


问题答案:

在Linux上,Java线程是使用本机线程实现的,因此使用线程的Java程序与使用线程的本机程序没有什么不同。“ Java线程”只是属于JVM进程的线程。

在现代Linux系统(一个使用NPTL的系统)上,属于某个进程的所有线程都具有相同的进程ID和父进程ID,但是具有不同的线程ID。您可以通过运行来查看这些ID
ps -eLf。PID列是进程ID,PPID列是父进程ID,LWP列是线程(LightWeight进程)ID。“主”线程的线程ID与进程ID相同,其他线程的线程ID值也不同。

较旧的Linux系统可能使用不完全符合POSIX的“
linuxthreads”线程实现,而不是NPTL。在linuxthreads系统上,线程具有不同的进程ID。

您可以通过将系统的C库(libc)作为独立程序运行并查看其输出中的“可用扩展”,来检查系统是否使用NPTL或linuxthreads。应该提到“
Native POSIX Threads
Library”或linuxthreads。C库的路径因系统而异:它可能是/lib/libc.so.6/lib64/libc.so.6(在基于64位RedHat的系统上)或类似的东西/lib/x86_64-linux- gnu/libc.so.6(在现代的基于Debian的系统(如Ubuntu)上)。

在操作系统级别,thead没有名称。这些仅存在于JVM中。

pthread_kill()C函数可用于向特定线程发送信号,您可以使用该函数尝试从JVM外部终止该特定线程,但是我不知道JVM如何响应。它可能会杀死整个JVM。



 类似资料:
  • 问题内容: 看起来我已经搞砸了Java线程/ OS线程和解释性语言。 在开始之前,我确实了解绿色线程是Java线程,其中JVM处理线程,并且整个Java进程仅作为单个OS线程运行。因此,在多处理器系统上是没有用的。 现在我的问题是。我有两个线程A和B。每个线程都有10万行独立代码。我在多处理器系统上的Java程序中运行这些线程。每个线程都将被赋予一个本机OS线程来运行,该线程可以在不同的CPU上运

  • 在Master Hazelcast电子书“17.4.1.分区感知操作”下,它指出: 要执行分区感知操作,需要创建操作线程数组。 单个操作线程对多个分区执行操作; 每个分区只属于1个操作线程。 忽略备份和近缓存,当我创建一个IMap实例时,这是否意味着我只能有一个并发的put/get操作在整个集群的每个map分区上执行?进一步说,如果我附加了一个MapStore,这是否意味着我只能对我的后端数据库运

  • 本文向大家介绍守护线程和用户线程的区别?相关面试题,主要包含被问及守护线程和用户线程的区别?时的应答技巧和注意事项,需要的朋友参考一下 java中线程氛围 守护线程Daemon和用户线程User。可以通过Thread.setDaemon(true)设置为守护线程,但是必须在start之前调用。 Daemon是为其他线程提供服务,如果全部用户线程结束,Daemon没有服务对象,也就没有继续运行程序的

  • 本文向大家介绍Android主线程和子线程区别详解,包括了Android主线程和子线程区别详解的使用技巧和注意事项,需要的朋友参考一下 主线程和子线程的区别 每个线程都有一个唯一标示符,来区分线程中的主次关系的说法。 线程唯一标示符:Thread.CurrentThread.ManagedThreadID; UI界面和Main函数均为主线程。 被Thread包含的“方法体”或者“委托”均为子线程。

  • 本文向大家介绍Java 多线程Synchronized和Lock的区别,包括了Java 多线程Synchronized和Lock的区别的使用技巧和注意事项,需要的朋友参考一下 引言   在多线程中,为了使线程安全,我们经常会使用synchronized和Lock进行代码同步和加锁,但是具体两者有什么区别,什么场景下适合用什么可能还不大清楚,主要的区别大致如下: 区别     1、synchroni

  • 主要内容:一、MySql中的线程,二、主要方式,三、源码流程,四、总结一、MySql中的线程 在mysql中,每一个连接上来,就会分配给一个相关的THD数据类。在前面的分析中可以看到,连接器(Connectors)连接到的直接就是连接池,在连接池的线程处理中分为三部分,即一对一(一个连接对应一个线程),多对一(多个连接对应一个线程)和线程池(多对多)。 线程池和线程可以针对不同的具体场景来处理具体的事务,这样既兼顾了效率又提高了适应性,对于新手来说,这就是设计的一个