kar*_*thi 46 java linux multithreading posix jvm
如何区分正在运行的Java线程和本机线程?
在Linux中,每个子进程都会有Parent进程,并且他们说0是所有进程的父进程,是否会有所有分叉Java线程的Parent线程?
我如何知道哪个Java线程与OS线程相关(如果Java线程支持本机进程线程).
是否存在Java线程和OS线程的命名约定?
可以从其他Java代码中挂起或终止正在运行的Java线程吗?
Wyz*_*a-- 70
在Linux上,Java线程是使用本机线程实现的,因此使用线程的Java程序与使用线程的本机程序没有什么不同."Java线程"只是属于JVM进程的线程.
在现代Linux系统(使用NPTL的系统)上,属于进程的所有线程具有相同的进程ID和父进程ID,但具有不同的线程ID.您可以通过运行查看这些ID ps -eLf.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.
没有标准; 这完全取决于您正在使用的Java实现.另外,不要混淆"本机线程"和"本机进程".进程是一个孤立的实体,无法看到其他进程的地址空间.线程是在本机进程的地址空间中运行的东西,它可以看到同一进程的其他线程的内存.
您在Linux上看到的是其他东西:某些版本的Linux在进程表中为父进程的每个线程创建一个条目.这些"过程"不是真正的过程(在隔离意义上).它们是可以使用ps命令列出的线程.您可以使用父PID(PPID)找到创建它们的过程.
可以从其他Java代码中挂起或终止正在运行的Java线程吗?
理论上是的.在实践中,不推荐使用Thread.kill()和Thread.suspend()方法,因为除非在非常有限的情况下它们是不安全的.基本问题是,杀死或挂起Java线程可能会破坏依赖它的其他线程,以及可能在更新过程中的共享数据结构.
如果"另一个Java代码"意味着另一个JVM,那么它的工作机会就更少了.即使你弄清楚如何发送相关的线程信号,结果也完全不可预测.我敢打赌,"目标"JVM会崩溃.
| 归档时间: |
|
| 查看次数: |
27025 次 |
| 最近记录: |