区分Java线程和OS线程?

时间:2009-12-11 13:44:14

标签: java linux jvm multithreading posix

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

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

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

是否存在Java线程和操作系统线程的命名约定?

可以从其他Java代码暂停或终止正在运行的Java线程吗?

4 个答案:

答案 0 :(得分:66)

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

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

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

您可以通过将系统的C库(libc)作为独立程序运行并查看其输出中的“Available extensions”来检查您的系统是使用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的系统。

在操作系统级别,theads没有名称;那些只存在于JVM中。

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

答案 1 :(得分:8)

没有标准;这完全取决于您正在使用的Java实现。另外,不要混淆“本机线程”和“本机进程”。进程是一个孤立的实体,无法看到其他进程的地址空间。线程是在本机进程的地址空间中运行的东西,它可以看到同一进程的其他线程的内存。

您在Linux上看到的是其他内容:某些版本的Linux在进程表中为父进程的每个线程创建一个条目。这些“过程”不是真正的过程(在隔离意义上)。它们是可以使用ps命令列出的线程。您可以使用父PI​​D(PPID)找到创建它们的过程。

答案 2 :(得分:5)

如果有的话,Java线程如何映射到OS线程没有通用的解决方案。每个JVM实现都可以以不同的方式实现。

还有一个名为green threads的纯Java线程实现。如果不支持本机线程或系统根本不是多线程的,则将其用作后备。您不会在操作系统上看到任何绿色线程。

  

可以从其他Java代码暂停或终止正在运行的Java线程吗?

如果它们在同一个JVM上运行,是的,使用stop()。但这不是一个好的解决方案,也可能有效。 interrupt()允许线程安全地自行关闭。

没有办法杀死我知道的JVM之外的线程。如果操作系统真的支持杀死线程,那么我不希望Java应用程序在之后正确运行!

答案 3 :(得分:5)

  

正在运行的Java线程是否可以   从另一个Java暂停或杀死   代码?

理论上是的。在实践中,Thread.kill()Thread.suspend()方法已被弃用,因为它们不安全,除非在非常有限的情况下。基本问题是,杀死或挂起Java线程可能会破坏依赖它的其他线程,以及可能在更新过程中共享的共享数据结构。

如果“另一个Java代码”意味着另一个JVM,那么它的工作机会就更少了。即使你弄清楚如何发送相关的线程信号,结果也完全不可预测。我敢打赌,“目标”JVM会崩溃。