线程:是进程中某个单一次序的控制流统称为lightweightprocesses)
线程是操作系统才能进行运算调度的最小单位,她被包含在进程之中,是进程中的实际操作单位,一条线程指的是进程中一个单一次序的控制流,一个进程中可以并发多个线程,线程可以操作系统内核调度的内核线程。
同一个进程的多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和讯号处理等等
然而同一进程中的多个线程有各自的调用栈,自己的寄存器环境,自己的线程本地储存。
线程和进程的区别在:一般一个进程中可以包含多个线程linux进程与线程 内核,她们可以借助进程所拥有的资源,操作系统中,一般把进程作为分配资源的基本单位,把线程作为独立运行和独立调度的基本单位,迟疑线程比进程更小,基本不用有系统资源。
一个进程起码须要一个线程作为它的指令执行体,进程管理着资源(例如CPU,显存,文件描述符等),线程即将分配到CPU上执行。
线程模型分为,核心级线程和用户级线程两种线程模型,分类的标准主要是线程的调度者是在内核内还是在外,后者更有利于并发使用多处理器的资源,前者更多考虑的是上下文切换开支。
linux内核只提供了轻量进程的支持,限制了更高效的线程模型的实现linux进程与线程 内核,并且linux注重
虽然linux支持轻量级进程,但并不能说,他就支持核心级进程,由于linux的线程和进程实际上处于一个调度层次,共享一个进程标示符空间,这些限制不可能在linux下实现完全意义上的POSIX线程机制。
linux内核并不支持真正意义上的线程,linuxthreads使用和普通进程具有同样内核调度视图的轻量级进程来实现线程支持的。这种轻量级进程拥有独立的进程ID,在进程调度,讯号处理,IO等方面享有与普通进程一样的能力。
linux下的线程就是轻量级进程。
每位linuxthread线程都同时具有线程id和进程id,其中进程id就是内核所维护的进程号
,而线程id则由linuxthreads分配和维护
__pthread_initial_thread的线程id为PTHREAD_THREADS_MAX,__pthread_manager_thread的是2*PTHREAD_THREADS_MAX+1linux格式化命令,第一个用户线程的线程id为PTHREAD_THREADS_MAX+2,随后第n个用户线程的线程id遵守以下公式:
tid=n*PTHREAD_THREADS_MAX+n+1
这些分配形式保证了进程中所有的线程(包括早已退出)都不会有相同的线程id,而线程id的类型pthread_t定义为无符号长整型(unsignedlongint),也保证了有理由的运行时间内线程id不会重复。
从线程id查找线程数据结构是在pthread_handle()函数中完成的,实际上只是将线程号按PTHREAD_THREADS_MAX取模,得到的就是该线程在__pthread_handles中的索引。
5.线程的创建
在pthread_create()向管理线程发送REQ_CREATE恳求以后,管理线程即调用pthread_handle_create()创建新线程。分配栈、设置thread属性后马哥linux,以pthread_start_thread()为函数入口调用__clone()创建并启动新线程。pthread_start_thread()读取自身的进程id号存入线程描述结构中,并按照其中记录的调度方式配置调度。一切打算就绪后,再调用真正的线程执行函数,并在此函数返回后调用pthread_exit()清除现场。
linux下查看线程数的三种方式:
1.cat/proc/pid/status
2.pstree-ppid
3.top-H-ppid
4.psxH,查看所有存在的线程
5.ps-mppid
6.ps-eLf|grep
里面命令查询结果的第二列为PID,第三列为PPID,第四列为LWP,第六列为NLWP。
jstack30420|less,之后查找nid=0x44bf,哦,找到了
Shell代码
"main"prio=10tid=0x11400nid=0x44bfrunnable[0x0000000040f5c000..0x0000000040f5ced0]
java.lang.Thread.State:RUNNABLE
at.SocketInputStream.socketRead0(NativeMethod)
at.SocketInputStream.read(SocketInputStream.java:129)
at.SocketInputStream.read(SocketInputStream.java:182)
atcom.caucho.server.resin.Resin.waitForExit(Resin.java:524)
atcom.caucho.server.resin.Resin.main(Resin.java:614)
jstack命令告一段落,先不研究了
以上就是线程与进程的区别:进程是分配资源的基本单位,线程是独立运行的控制流的详细内容,更多请关注CTO智库其它相关文章!