Foxtable(狐表)用户栏目专家坐堂 → 异步等待执行


  共有3127人关注过本帖树形打印复制链接

主题:异步等待执行

美女呀,离线,留言给我吧!
漂亮美眉vszh
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
异步等待执行  发帖心情 Post By:2019/2/13 21:55:00 [只看该作者]

老师:比如我要执行一个异步函数,传入一个参数执行,想执行完成以后再传入参数执行,这个异步如何等待?第一个完成之后再执行下一个?

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/2/13 23:02:00 [只看该作者]

 

那你把代码写到函数里面,在里面继续调用自己。

 

 


 回到顶部
美女呀,离线,留言给我吧!
漂亮美眉vszh
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
  发帖心情 Post By:2019/2/18 15:41:00 [只看该作者]

1.

定义一个名为AddTotal的函数,其代码为:***省略
2.
异步函数

然后定义一个名为AddSubtotal的函数,这个函数将在主线程中被异步调用,其代码为:

Functions .BeginSyncExecute("AddTotal"

3.实际前台调用执行

Functions.AsyncExecute("AddSubtotal")

---老师这样对吗?



 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105965 积分:538900 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/2/18 16:29:00 [只看该作者]

差不多了。这种问题先测试,然后有什么具体问题再提出来。不要问行不行,对不对,这种问题基本没有什么意义

 回到顶部
美女呀,离线,留言给我吧!
漂亮美眉vszh
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
  发帖心情 Post By:2019/2/20 16:14:00 [只看该作者]

老师,经过两天的测试,在主线程Functions.AsyncExecute("AddSubtotal")开多个异步来调用Functions .BeginSyncExecute("AddTotal") ,但要等很久,与普通的函数执行时间相同,问题点应该出在哪里?

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105965 积分:538900 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/2/20 16:19:00 [只看该作者]

请上传具体实例测试

 回到顶部
美女呀,离线,留言给我吧!
漂亮美眉vszh
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
  发帖心情 Post By:2019/2/20 21:49:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1多线程例子.foxdb


 回到顶部
美女呀,离线,留言给我吧!
漂亮美眉vszh
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
  发帖心情 Post By:2019/2/20 21:50:00 [只看该作者]

命令窗口执行的代码,注意函数Text_1那个主键的值:

Dim Products As List(Of String)
Dim Products2 As List(Of String)
Products = DataTables("表A").SQLGetValues("过程编号")
For Each Product As String In Products
    If Product <> "" Then
        Products2 = DataTables("表B").SQLGetValues("特性编号")
        For Each Product2 As String In Products2
            If Product2 <> "" Then
                ' st = st & ";" & Product & "|" & Product2
                Functions.AsyncExecute("Text_2",Product & "|" & Product2)
            End If
        Next
    End If
Next


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105965 积分:538900 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/2/20 21:57:00 [只看该作者]

没看懂,请使用文字详细描述一下您的逻辑。哪些功能是需要异步处理的?

 回到顶部
美女呀,离线,留言给我吧!
漂亮美眉vszh
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:869 积分:7854 威望:0 精华:0 注册:2013/5/30 11:27:00
  发帖心情 Post By:2019/2/21 9:10:00 [只看该作者]

函数Text_1,执行时Args(0)= 编号|特性编号,然后异步每次上传不同的Args(0)信息。可能开很多条异步:

第一步:定义函数Text_1

第二步:定义同步函数"Text_2", Functions.BeginSyncExecute("Text_1", "编号|特性编号")
第三步:命令窗口执行:

for循环条件

  Functions.AsyncExecute("Text_2","编号|特性编号")
next

 

以上是我的处理思路,使用时前台操作卡,而且所用时长与普通函数时长一样,不知道问题点出在哪步上。命令窗口执行我上面的代码,执行时注意主键噢,


 回到顶部
总数 17 1 2 下一页