线程: ps aux 查进程ID (3500) ps -Lf 3500 查本进程下面有多少线程号(线程号 :cpu 分配时间轮片的依据) (线程ID : 进程区分线程的)
进程:独立地址空间,拥有pcb
线程:也有pcb,但没有独立的地址空间(共享)
线程共享全集变量,进程不共享全局变量 需要mmap
区别:在于是否共享地址空间
进程创建 0-4G的独立地址空间,线程创建只有pcb,没有0-4G的地址空间
linux 线程:最小的执行单位(cpu 分配时间轮片,进程线程都有pcb)
进程:最小分配资源单位,可看成是只有一个线程的进程。(0-4G)
轻量级进程,也有pcb,创建线程使用的底层函数和进程一样,都是clone
从内核里看进程和线程是一样的,都有各自不同的pcb,但是pcb中指向内存资源的三级页表是相同的
进程可以脱变成线程
线程可以看做寄存器和栈的集合
线程共享资源
1.文件描述符表
2.每种信号的处理方式
3.当前工作目录
4.用户ID和组ID
5.内存地址空间(.text .data .bss heap 共享库)
线程非共享资源
1.线程id
2.处理器现场和栈指针(内核栈)
3.独立的栈空间(用户空间栈)
4.erron变量
5.信号屏蔽字
6.调度优先级
线程 进程
id pthread_self() getpid()
创建 pthread_create() fork()
退出 phread_join() wait()
pthread_deteach() waitpid()
取消线程 pthread_cancel()(需要取消点) kill()
线程属性:
线程同步:
互斥量
读写锁
条件变量
信号量
文件锁 fcntl
退出
exit() 退出整个进程
pthreat_exit(NULL) 退出线程
return() 返回到调用着那里