《Linux多线程编程 多核编程》由会员分享,可在线阅读,更多相关《Linux多线程编程 多核编程(28页珍藏版)》请在人人文库网上搜索。
1、Linux多线程编程,IEEE POSIX 标准 p1003.1c (Pthreads) 定义了处理线程的一系列C 语言类型的API。 在Linux中,线程一般被认为是“轻量级的进程”。 Linux 创建进程所使用的函数是fork() 或者vfork()。而对线程的创建和管理Linux 可以使用POSIX的线程库pthreads提供的APIs。 使用fork()创建进程和使用POSIX线程库差别: 使用fork() 创建进程的特点: 代价昂贵,通常子进程需要拷贝父进程的整个上下文,比如数据等。 进程间的通信方式比较复杂,比如使用管道、消息、共享内存等方法。 操作系统在实现进程间的切换比线程切换。
2、更费时。 使用POSIX pthreads库创建线程的特点: 线程可使用存在于进程中的资源。 线程间的通信方式更容易,比如通过进程中的变量,可以让多个线程共享数据。 操作系统对线程的切换比对进程的切换更容易和快速。,Linux多线程编程,线程的创建 pthreads 线程库中提供的创建线程的函数是pthread_create() #include int pthread_create(pthread_t * thread, pthread_attr_t * attr, void *(*start_routine)(void *), void * arg); 线程的退出 在线程的处理函数中,可以。
3、显示的调用pthread_exit()结束线程执行,也可以不调用pthread_exit(),而只是让线程处理程序返回。 void pthread_exit (void* retval); 除了pthread_exit() 函数,可以让当前调用pthread_exit() 的线程显示地退出外,线程也可以使