【Tcl】多线程并行提交任务

本文介绍了一个简化版的多线程任务处理函数,通过`procmulti_thread_job`,将任务列表分成多个工作线程,每个线程异步执行,展示了如何使用`tpool`进行任务提交和等待,无需互斥锁等复杂同步机制。
摘要由CSDN通过智能技术生成
package require Thread

proc multi_thread_job {job_cmds job_thread} {
	set tpool [tpool::create -maxworkers $job_thread]
	set job_idx 1
	set tjobs ""
	foreach job_cmd $job_cmds {
		puts "=== job $job_idx start! ==="
		lappend tjobs [tpool::post $tpool $job_cmd]
	}

	foreach tjob $tjobs {
		tpool::wait $tpool $tjob
	}
	
	tpool::release $tpool
}

set jobs {
	{puts 1;exec sleep 1}
	{puts 2;exec sleep 2}
	{puts 3;exec sleep 3}
	{puts 4;exec sleep 4}
	{puts 5;exec sleep 5}
	{puts 6;exec sleep 6}
	{puts 7;exec sleep 7}
	{puts 8;exec sleep 8}
	{puts 9;exec sleep 9}
	{puts 10;exec sleep 10}
}

multi_thread_job $jobs 5

参考 https://zhuanlan.zhihu.com/p/27762788?utm_id=0 中的内容,删除了互锁等复杂内容,仅保留多线程任务提交

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这本教程花费了我足足两个月的时间写的,每个章节以例子为核心讲解知识点,最大的好处是要用的时候把代码粘贴一下,修改修改就可以上手用了,绝对原创,光是调试这些例子就够我折腾了。知识点覆盖比较全面,要个20分不过分吧,有几本书认真讲过那些常用模块: socket, 数据库操作,xml解析,多线程,最具体的做法多半是一带而过,我可是一个例子一个例子做出来的。 把目录发给大家看看: 2.1 第1课:简单文本输出 5 2.2 第2课:给变量赋值 5 2.3 第3课:命令的赋值与置换一 6 2.4 第4课:命令的赋值与置换二 7 2.5 第5课:命令的赋值与置换三 7 2.6 第6课:算数运算 8 2.7 第7课:文本比较-SWITCH应用 9 2.8 第8课:数值比较-IF应用 10 2.9 第9课:WHILE 循环 11 2.10 第10课:FOR循环和INCR 11 2.11 第11课:过程PROC 12 2.12 第12课:过程PROC的参数定义 13 2.13 第13课:变量的作用域 13 2.14 第14课:LIST结构 14 2.15 第15课:LIST项的增删改 15 2.16 第16课:更多LIST相关 16 2.17 第17课:字符串函数 17 2.18 第18课:更多字符串函数 17 2.19 第19课:修改字符串函数 20 2.20 第20课:正则表达式 21 2.21 第21课:更多正则表达式 22 2.22 第22课:数组 24 2.23 第23课:更多数组相关 25 2.24 第24课:文件存取 28 2.25 第25课:文件信息 30 2.26 第26课:TCL中的子进程调用-OPEN & EXEC 33 2.27 第27课:命令或者变量是否存在-INFO 34 2.28 第28课:解释器状态-INFO 35 2.29 第29课:过程信息-INFO 36 2.30 第30课:模块化-SOURCE 37 2.31 第31课:建库-UNKNOWN & INFO LIBRARY 38 2.32 第32课:创建命令-EVAL 40 2.33 第33课:在EVAL中应用FORMAT & LIST 40 2.34 第34课:不使用EVAL替换-FORMAT & SUBST 42 2.35 第35课:改变工作目录- CD & PWD 43 2.36 第36课:调试和错误-ERRORINFO & ERRORCODE & CATCH 44 2.37 第37课:调试-TRACE 45 2.38 第38课:命令行参数和环境串 46 2.39 第39课:TIME & UNSET 47 2.40 第40课:SOCKET & FILEEVENT & VWAIT 49 2.41 第41课:日期时间-CLOCK 51 2.42 第42课:I/O通道-FBLOCKED & FCONFIG 53 2.43 第43课:子解释器 56 2.44 第44课:数据库操作 57 2.45 第45课:函数或过程数组的输入和输出方法 59 2.46 第46课:INFO的用法 60 2.47 第47课:多线程 61 2.48 第48课:解析XML 72
Vivado中的多线程编译是通过tcl脚本进行设置的。目前Vivado最大可使用的线程数是8个\[1\]。使用多个线程可以加快编译速度,但效果并不是非常明显\[2\]。对于单个design run,jobs的数量不会影响编译速度\[2\]。在多个design runs时,jobs的数量是当前可以同时运行的design run的个数\[2\]。在Windows中,默认的线程数是2,可以通过tcl脚本来改变线程数,但每次打开工程后都需要重新设置\[2\]。在Windows开发中,可以使用tcl指令将最大线程数改为8,但每次在执行编译之前都需要输入一次\[3\]。因此,使用多线程编译可以提高编译速度,但具体效果取决于具体的设计和系统环境。 #### 引用[.reference_title] - *1* *2* [vivado多线程编译设置,加快编译速度](https://blog.csdn.net/weixin_43668420/article/details/127203157)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [vivado中设置多线程编译](https://blog.csdn.net/wordwarwordwar/article/details/78245352)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值