linux 多线程运行,详解Linux中的多线程都是如何实现的

所谓的多线程就是多个函数同时执行。一般将线程表述为一个api加一个函数。线程函数有特定的格式要求,以便系统自动调用。

Windows进程包含多个线程,进程是分配资源(包括CPU)的最小单位,而线程是调度的最小单位。

Linux中的进程和线程关系应该和Windows一样,而且在Linux中创建多线程程序和Windows一样简单。

下面是一个多线程实例,程序流程是这样的:

进程启动,创建一个线程

线程和主进程都每个一段时间输出一些信息,二者并发执行

下面的代码编译于ubuntu 10.0.4:

thread.cpp源代码:

#include // printf

#include // pthread_create

#include // exit

#include // usleep

void * thread( void * par){// 线程函数

int i;

for( i = 0; i < 30; i ++){

printf( "This is a pthread.\\n");

usleep( 1000);

}

return 0;

}

int main(void){

pthread_t id;

int i,ret;

ret = pthread_create( &id, NULL, thread, NULL);// 创建一个线程

if( ret != 0){

printf( "Create pthread error!\\n");

exit( 1);

}

for( i = 0; i < 30; i ++){// 和创建的线程并发执行

printf( "This is the main process.\\n");

usleep( 330);

}

pthread_join( id, NULL); // 等待tid为id的线程退出执行

return( 0);

}

makefile内容:

thread: thread.cpp

g++ thread.cpp -lpthread -o thread

程序执行截图:

9ff2bdf614d24f832fc8d02a14d9331c.png

笔记:

编译时必须链入 pthread 这个库

usleep参数是毫秒级的,sleep参数是秒级的

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值