线程

线程:  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() 返回到调用着那里

 

上一篇:C++多线程开发(一)多线程


下一篇:Linux 多线程开发