的构成Linux进程中:线程的组成与构建(linux进程中线程)
Linux进程中,线程是一种核心概念,它极大增强了程序的执行效率,使一个程序可以同时处理多个任务。在Linux进程中,线程可以分为用户态线程和内核态线程。用户态线程由用户级的线程库,如pthread库或kthread库,产生,运行在用户态,它由包含寄存器、PC、SP等寄存器的寄存器集组成,可以理解为程序的一条隐形流水线,减少中断的发生,提高效率;而内核态线程是内核态既定的,当调度cpu时,内核会使用内核态线程来处理任务,所以一个内核态线程会集成了运行环境、文件描述符等项,也就是说,一个内核态线程就是一个轻量级进程。
对于Linux进程中的线程,其构建其实是由内核所支持,应用程序只需要通过调用内核提供的函数接口,就可以创建线程,比如Linux下的pthread_create,它的基础实现是通过arch/x86/kernel/process.c中的clone系统调用,其主要构建如下:
1.分配栈内存,使用mm_alloc函数来获取一个空闲指针:
struct mm_struct *mm_alloc(){/* Get a free_link from the dynamic memory allocator. */}
2.开始构建新线程,使用do_clone函数来u声明复制函数:
int do_clone(int(*fn)(void* arg),void* arg,unsigned long flags){/* Declare do_exit() the thread-exit mechanism. */}
3.将新线程添加到调度器的就绪队列:
int schedule_add_thread(struct thread_struct *thread){/* Add the thread to the scheduler’s ready-queue. */}
4.创建新的地址空间,使用mm_alloc函数来创建:
struct mm_struct *mm_alloc_area(struct mm_struct *mm,unsigned long start,unsigned long size){/* Allocate new address spaces for the process. */}
以上几步就是Linux进程中的线程构建的基本流程,当然,同时还有其它的操作,如文件描述符的管理、中断处理、调度等,为了使程序更充分利用多核特性,来提高运行效率,我们只要在应用层调用上述API,就可以构建出一个完整的多线程应用程序。