开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 265|回复: 9
收起左侧

[已解决] 鱼刺多线程队列问题

 关闭 [复制链接]
结帖率:100% (39/39)
发表于 7 天前 | 显示全部楼层 |阅读模式   广东省深圳市
100精币
这个是模拟双层线程池处理数据的方法,在下面的多线程队列中

第一次点击 按钮 执行时 线程池2获取不到数据:
队列.弹出文本 (局_分配到的任务) #错误地方
----------
第2次之后多次测试中,也有几率在弹出的文本次数跟 orderArr 数组中的次数对不上(orderArr 模拟的10个成员数据,几率弹出文本只有9个)
--------
有好的解决方法吗?

  
数据类型名公开备 注
单号数据类型 
成员名类 型传址数组备 注
文本1文本型  
文本2文本型  
时间文本型  
id整数型  


  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
队列鱼刺类_队列  
线程池1鱼刺类_线程池  
线程池2鱼刺类_线程池  
线程鱼刺类_线程操作  
orderArr单号数据类型0 

子程序名返回值类型公开备 注
__启动窗口_创建完毕  
UPS数据库连接.执行SQL (sql_insert, )
子程序名返回值类型公开备 注
_按钮1_被单击  
线程.创建 (&主线程, , )
子程序名返回值类型公开备 注
主线程  
变量名类 型静态数组备 注
temp_记录数量整数型 
n整数型 
i逻辑型 
m整数型 
按钮1.禁止 = 真
' //模拟数据
重定义数组 (orderArr, 假, 10)
计次循环首 (取数组成员数 (orderArr), n)
置随机数种子 ()
orderArr [n].id = n
orderArr [n].文本1 = 到文本 (取随机数 (10000000, 999999999))
orderArr [n].文本2 = 到文本 (取随机数 (10000000, 999999999))
orderArr [n].时间 = 到文本 (取现行时间 ())
计次循环尾 ()
temp_记录数量 = 取数组成员数 (orderArr)
' //创建压入多线程
线程池1.创建 (10, , , )
计次循环首 (temp_记录数量, n)
线程池1.投递任务 (&子线程1, n, )
计次循环尾 ()
' //创建弹出多线程
线程池2.创建 (1, , , )
计次循环首 (temp_记录数量, m)
线程池2.投递任务 (&子线程2, , )
计次循环尾 ()
判断循环首 (线程池1.取_是否完全空闲 ())  ' 等待任务全部执行完
_延时 (300)
判断循环尾 ()
判断循环首 (线程池2.取_是否完全空闲 ())  ' 等待任务全部执行完
_延时 (300)
判断循环尾 ()
线程池1.销毁 ()
线程池2.销毁 ()
调试输出 (“线程已销毁”)
按钮1.禁止 = 假
子程序名返回值类型公开备 注
子线程1  
参数名类 型参考可空数组备 注
参数1整数型
参数2整数型
变量名类 型静态数组备 注
局_分配到的任务文本型 
文本文本型 
文本 = 压入JSON (“长文本测试中ABCDZDSSSSSSSSSSSSS长文本测试中ABCDZDSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS...”, orderArr [参数1].文本1, orderArr [参数1].文本2, orderArr [参数1].时间, 到文本 (参数1))
队列.压入文本 (文本)
子程序名返回值类型公开备 注
子线程2  
参数名类 型参考可空数组备 注
参数1整数型
参数2整数型
变量名类 型静态数组备 注
局_分配到的任务文本型 
如果真 (队列.弹出文本 (局_分配到的任务))
返回 ()

调试输出 (局_分配到的任务)
子程序名返回值类型公开备 注
压入JSON文本型 将数据转换成json格式,并返回
参数名类 型参考可空数组备 注
文本1文本型
文本2文本型
文本3文本型
时间戳文本型
ID文本型
变量名类 型静态数组备 注
json类_json 
json.置属性 (“['ups_track_info']”, 文本1, )
json.置属性 (“['master_tracking_number']”, 文本2, )
json.置属性 (“['sub_tracking_number']”, 文本3, )
json.置属性 (“['timestamp']”, 时间戳, )
json.置属性 (“['ID']”, ID, )
返回 (json.取数据文本 ())


i支持库列表   支持库注释   
eDB数据库操作支持库
spec特殊功能支持库



队列.e (1.39 MB, 下载次数: 1)

最佳答案

查看完整内容

.版本 2 .局部变量 堆句柄, 整数型 .局部变量 内存数据大小, 整数型 内存数据大小 = 20 × 1024 × 1024 ' 20M 堆句柄 = _堆取默认 () 集_队列.置缓冲区阀值 (内存数据大小) 集_队列.重新初始化 (堆句柄) 他这个队列本来就提供这些功能的。你感觉数据大了就自己提供内存尺寸。程序窗口启动后设置一次就可以了(队列是程序集或全局变量) ...

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:97% (29/30)
发表于 7 天前 | 显示全部楼层   贵州省遵义市
adoue00 发表于 2025-7-15 01:18
明白了,还有一个小问题,请求API压入的速度快过弹出的速度,比如循环处理10000个文本,在5秒的时候压入 ...
  
变量名类 型静态数组备 注
堆句柄整数型 
内存数据大小整数型 
内存数据大小 = 20 × 1024 × 1024  ' 20M
堆句柄 = _堆取默认 ()
集_队列.置缓冲区阀值 (内存数据大小)
集_队列.重新初始化 (堆句柄)


他这个队列本来就提供这些功能的。你感觉数据大了就自己提供内存尺寸。程序窗口启动后设置一次就可以了(队列是程序集或全局变量)
回复

使用道具 举报

结帖率:97% (29/30)
发表于 7 天前 | 显示全部楼层   贵州省遵义市
逻辑问题,你在生成得到orderArr数据那一步后、把orderArr组装好、压入到队列中去(如果你有下标这些都可以一起拼接后压进去,自己用特定的分隔符拼接);再创建线程池、控制好线程池来投递执行你的任务。如你压入到队列中的orderArr数据有2000、线程池创建10。你要循环复用这10个线程来投递你这2000个任务。任务内部才是真正:弹出队列的数据----分割数据(你怎么压入就怎么分割)----执行。
回复

使用道具 举报

结帖率:100% (39/39)

签到天数: 10 天

 楼主| 发表于 7 天前 | 显示全部楼层   广东省深圳市
右手胜过左手 发表于 2025-7-13 21:01
逻辑问题,你在生成得到orderArr数据那一步后、把orderArr组装好、压入到队列中去(如果你有下标这些都可以 ...

流程是这样没错,实际应用场景是通过访问API,将API的数据写到数据库中,这里就会涉及到速度的问题,因为访问API会有延迟,等数据返回才能处理,等写入SQL又是浪费了些时间。所以我开了两个线程池,第一个线程池负责访问API,第二个线程池负责将得到的数据,写入SQL。
回复

使用道具 举报

结帖率:89% (39/44)

签到天数: 20 天

发表于 7 天前 | 显示全部楼层   福建省宁德市
这样写很麻烦,绕来绕去的
回复

使用道具 举报

结帖率:97% (29/30)
发表于 7 天前 | 显示全部楼层   贵州省遵义市
adoue00 发表于 2025-7-13 21:39
流程是这样没错,实际应用场景是通过访问API,将API的数据写到数据库中,这里就会涉及到速度的问题,因为 ...

没有那么复杂,你二个线程池改成一个单独的死循环线程就可以了;让它死循环检查新队列、有数据就写到数据库中(这里可以累计数据、比如100条、1000条再写一次,不要频繁的每次都写).

流程:创建线程池、启动一个死循环的线程、线程池投递任务----得到数据(访问API)----压入数据到新队列;这里新队列会被启动死循环的线程检查----累计组合数据----写到数据库。


ps:死循环的控制由你的线程池来决定、线程池完全空闲了用程序集变量控制。
     本地写数据库没必要用多线程、一个线程就够了,你线程池没有访问完成,它都已经操作完了!

回复

使用道具 举报

结帖率:100% (39/39)

签到天数: 10 天

 楼主| 发表于 5 天前 | 显示全部楼层   广东省深圳市
右手胜过左手 发表于 2025-7-13 23:14
没有那么复杂,你二个线程池改成一个单独的死循环线程就可以了;让它死循环检查新队列、有数据就写到数据 ...

明白了,还有一个小问题,请求API压入的速度快过弹出的速度,比如循环处理10000个文本,在5秒的时候压入了5000个文本,但在弹出文本时,只弹到了2000个(SQL处理过慢),还有3000文本数量在队列中,这种情况就会导致压入的文本过多,导致崩溃。要咋处理呢?
回复

使用道具 举报

结帖率:100% (39/39)

签到天数: 10 天

 楼主| 发表于 5 天前 | 显示全部楼层   广东省深圳市
右手胜过左手 发表于 2025-7-15 09:34
[e=0].版本 2

.局部变量 堆句柄, 整数型

非常感谢,这里的内存数据大小是指整个堆吗?我压入10000个文本,是压入10000文本*2的大小吗?
回复

使用道具 举报

签到天数: 9 天

发表于 5 天前 | 显示全部楼层   浙江省台州市
66666666666666666666666666666666666666
回复

使用道具 举报

结帖率:97% (29/30)
发表于 5 天前 | 显示全部楼层   贵州省遵义市
adoue00 发表于 2025-7-15 11:39
非常感谢,这里的内存数据大小是指整个堆吗?我压入10000个文本,是压入10000文本*2的大小吗? ...

内存数据大小=字节大小;你压入的所有数据保存在这个大小的内存地址上。它默认是256个字节大小。自己提供20M(20971520个字节);不用精确提供。20M随便够,内部还会自动增加。
堆是堆,一句话解释不清楚。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表