开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 297|回复: 4
收起左侧

[已解决] 请教鱼刺 队列 和精益队列 压入和弹出错误问题

 关闭 [复制链接]
结帖率:50% (1/2)
发表于 2024-11-23 19:51:29 | 显示全部楼层 |阅读模式   江苏省宿迁市
11精币
.版本 2
.支持库 EThread

.子程序 _按钮_测试_被单击

启动线程 (&队列测试, , )

.子程序 队列测试
.局部变量 临时数据, 整数型
.局部变量 队列, 类_队列, , , 精益
.局部变量 yc队列, 鱼刺类_队列
.局部变量 o, 整数型

.计次循环首 (10000000, o)
    系统时间 = 取启动时间 ()
    .如果 (yc队列.压入整数 (系统时间))

    .否则
        编辑框1.加入文本 (“失败yc_队列.压入整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束
    .如果 (yc队列.弹出整数 (临时数据))
        .如果真 (临时数据 ≠ 系统时间)
            编辑框1.加入文本 (到文本 (o) + “|” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + #换行符)
        .如果真结束

    .否则
        编辑框1.加入文本 (“失败yc_队列.弹出整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束

.计次循环尾 ()
编辑框1.加入文本 (“完成” + 到文本 (队列.取数量 ()) + #换行符)
.计次循环首 (10000000, o)
    系统时间 = 取启动时间 ()
    .如果 (队列.压入整数 (系统时间))

    .否则
        编辑框1.加入文本 (“失败精益_队列.压入整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束
    .如果 (队列.弹出整数 (临时数据))
        .如果真 (临时数据 ≠ 系统时间)
            编辑框1.加入文本 (到文本 (o) + “|” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + #换行符)
        .如果真结束

    .否则
        编辑框1.加入文本 (“失败精益_队列.弹出整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束

.计次循环尾 ()
编辑框1.加入文本 (“完成” + 到文本 (队列.取数量 ()) + #换行符)


输出如下:
267168|724012818|724012656
1006271|724012875|724012718
1774356|724012932|724012781
2498197|724012996|724012843
3243769|724013065|724012906
3958575|724013121|724012968
4715043|724013190|724013031
5442227|724013249|724013093
6956969|724013371|724013218
7691033|724013431|724013281
8409968|724013494|724013343
9149629|724013549|724013406
9916252|724013607|724013468
完成0
433025|724013677|724013515
888293|724013742|724013593
1413037|724013798|724013640
1933026|724013862|724013703
2462745|724013925|724013765
2990768|724013985|724013828
3500503|724014043|724013890
4036841|724014108|724013953
4516626|724014166|724014015
5020648|724014229|724014078
5526926|724014286|724014140
6043478|724014343|724014203
6586852|724014412|724014265
7122182|724014467|724014328
7654009|724014537|724014375
8161836|724014594|724014437
8671472|724014653|724014500
9175110|724014716|724014562
9700775|724014776|724014625
完成0

为什么压入和弹出的会出现不一致的情况?


如果我将压入的数改成 o 也就是 计次循环变量
就完全没问题

.版本 2
.支持库 EThread

.子程序 _按钮_测试_被单击

启动线程 (&队列测试, , )

.子程序 队列测试
.局部变量 临时数据, 整数型
.局部变量 队列, 类_队列, , , 精益
.局部变量 yc队列, 鱼刺类_队列
.局部变量 o, 整数型

.计次循环首 (10000000, o)
    系统时间 = 取启动时间 ()
    .如果 (yc队列.压入整数 (o))

    .否则
        编辑框1.加入文本 (“失败yc_队列.压入整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束
    .如果 (yc队列.弹出整数 (临时数据))
        .如果真 (临时数据 ≠ o)
            编辑框1.加入文本 (到文本 (o) + “|” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + #换行符)
        .如果真结束

    .否则
        编辑框1.加入文本 (“失败yc_队列.弹出整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束

.计次循环尾 ()
编辑框1.加入文本 (“完成” + 到文本 (队列.取数量 ()) + #换行符)
.计次循环首 (10000000, o)
    系统时间 = 取启动时间 ()
    .如果 (队列.压入整数 (o))

    .否则
        编辑框1.加入文本 (“失败精益_队列.压入整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束
    .如果 (队列.弹出整数 (临时数据))
        .如果真 (临时数据 ≠ o)
            编辑框1.加入文本 (到文本 (o) + “|” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + #换行符)
        .如果真结束

    .否则
        编辑框1.加入文本 (“失败精益_队列.弹出整数 (物品指针)” + 到文本 (系统时间) + “|” + 到文本 (临时数据) + “|” + #换行符)
    .如果结束

.计次循环尾 ()
编辑框1.加入文本 (“完成” + 到文本 (队列.取数量 ()) + #换行符)



输出:
完成0
完成0

是我写错了还是队列有BUG


最佳答案

查看完整内容

没有问题啊,你的 系统时间 不是局部变量,可能在其他什么地方 被改变了

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

结帖率:98% (39/40)

签到天数: 21 天

发表于 2024-11-23 19:51:30 | 显示全部楼层   重庆市重庆市
没有问题啊,你的 系统时间  不是局部变量,可能在其他什么地方 被改变了

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:50% (1/2)

签到天数: 9 天

 楼主| 发表于 2024-11-23 19:54:24 | 显示全部楼层   江苏省宿迁市
  
子程序名返回值类型公开备 注
_按钮_测试_被单击  
启动线程 (&队列测试, , )
子程序名返回值类型公开备 注
队列测试  
变量名类 型静态数组备 注
临时数据整数型 
队列类_队列精益
yc队列鱼刺类_队列 
o整数型 
计次循环首 (10000000, o)
系统时间 = 取启动时间 ()
如果 (yc队列.压入整数 (系统时间))

编辑框1.加入文本 (“失败yc_队列.压入整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )
如果 (yc队列.弹出整数 (临时数据))
如果真 (临时数据 ≠ 系统时间)
编辑框1.加入文本 (到文本 (o)“|”到文本 (系统时间)“|”到文本 (临时数据)#换行符 )
编辑框1.加入文本 (“失败yc_队列.弹出整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )

计次循环尾 ()
编辑框1.加入文本 (“完成”到文本 (队列.取数量 ()) + #换行符 )
计次循环首 (10000000, o)
系统时间 = 取启动时间 ()
如果 (队列.压入整数 (系统时间))

编辑框1.加入文本 (“失败精益_队列.压入整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )
如果 (队列.弹出整数 (临时数据))
如果真 (临时数据 ≠ 系统时间)
编辑框1.加入文本 (到文本 (o)“|”到文本 (系统时间)“|”到文本 (临时数据)#换行符 )
编辑框1.加入文本 (“失败精益_队列.弹出整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )

计次循环尾 ()
编辑框1.加入文本 (“完成”到文本 (队列.取数量 ()) + #换行符 )
输出如下:
267168|724012818|724012656
1006271|724012875|724012718
1774356|724012932|724012781
2498197|724012996|724012843
3243769|724013065|724012906
3958575|724013121|724012968
4715043|724013190|724013031
5442227|724013249|724013093
6956969|724013371|724013218
7691033|724013431|724013281
8409968|724013494|724013343
9149629|724013549|724013406
9916252|724013607|724013468
完成0
433025|724013677|724013515
888293|724013742|724013593
1413037|724013798|724013640
1933026|724013862|724013703
2462745|724013925|724013765
2990768|724013985|724013828
3500503|724014043|724013890
4036841|724014108|724013953
4516626|724014166|724014015
5020648|724014229|724014078
5526926|724014286|724014140
6043478|724014343|724014203
6586852|724014412|724014265
7122182|724014467|724014328
7654009|724014537|724014375
8161836|724014594|724014437
8671472|724014653|724014500
9175110|724014716|724014562
9700775|724014776|724014625
完成0
为什么压入和弹出的会出现不一致的情况?
如果我将压入的数改成 o 也就是 计次循环变量
就完全没问题
子程序名返回值类型公开备 注
_按钮_测试_被单击  
启动线程 (&队列测试, , )
子程序名返回值类型公开备 注
队列测试  
变量名类 型静态数组备 注
临时数据整数型 
队列类_队列精益
yc队列鱼刺类_队列 
o整数型 
计次循环首 (10000000, o)
系统时间 = 取启动时间 ()
如果 (yc队列.压入整数 (o))

编辑框1.加入文本 (“失败yc_队列.压入整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )
如果 (yc队列.弹出整数 (临时数据))
如果真 (临时数据 ≠ o)
编辑框1.加入文本 (到文本 (o)“|”到文本 (系统时间)“|”到文本 (临时数据)#换行符 )
编辑框1.加入文本 (“失败yc_队列.弹出整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )

计次循环尾 ()
编辑框1.加入文本 (“完成”到文本 (队列.取数量 ()) + #换行符 )
计次循环首 (10000000, o)
系统时间 = 取启动时间 ()
如果 (队列.压入整数 (o))

编辑框1.加入文本 (“失败精益_队列.压入整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )
如果 (队列.弹出整数 (临时数据))
如果真 (临时数据 ≠ o)
编辑框1.加入文本 (到文本 (o)“|”到文本 (系统时间)“|”到文本 (临时数据)#换行符 )
编辑框1.加入文本 (“失败精益_队列.弹出整数 (物品指针)”到文本 (系统时间)“|”到文本 (临时数据)“|”#换行符 )

计次循环尾 ()
编辑框1.加入文本 (“完成”到文本 (队列.取数量 ()) + #换行符 )
输出:
完成0
完成0
是我写错了还是队列有BUG


i支持库列表   支持库注释   
EThread多线程支持库

回复

使用道具 举报

结帖率:100% (11/11)

签到天数: 18 天

发表于 2024-11-23 19:55:33 | 显示全部楼层   福建省福州市
压入后弹出就没有了
回复

使用道具 举报

结帖率:50% (1/2)

签到天数: 9 天

 楼主| 发表于 2024-11-23 19:59:59 | 显示全部楼层   江苏省宿迁市
观音 发表于 2024-11-23 19:55
压入后弹出就没有了

关键是  压入和弹出 为什么会不一样
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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