重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
第一个for完成对delay_time参数的控制,即共循环多少次内部循环
成都创新互联成都网站建设按需求定制网站,是成都网站建设公司,为成都电动窗帘提供网站建设服务,有成熟的网站定制合作流程,提供网站定制设计服务:原型图制作、网站创意设计、前端HTML5制作、后台程序开发等。成都网站营销推广热线:18982081108
第二个for(内部循环),完成对j从0到199的控制,共循环200次。
翻译成汇编就是:
(R0为传递参数)
DELAY:
MOV R1,#200
DJNZ R1,$
DJNZ R0,DELAY
RET
Imports System.Threading
Thread.Sleep(1000)’延迟1秒
2.PauseWait(1000)’延迟1秒
Public Sub PauseWait(ByVal HowLong As Long)
Dim tick As Long
tick = My.Computer.Clock.TickCount
Do
My.Application.DoEvents()
Loop Until tick + HowLong My.Computer.Clock.TickCount
End Sub
Threading.Thread.Sleep(500)这句是线程停止等待的,在这500毫秒的时间里你的任何动作都是不响应的,理论上再SendKeys.Send(TextBox2.Text)这段时间内你可以动作,但是send是毫秒级完成的,你还没有来得及响应就进入了下一次的循环,所以跟卡死类似
解决方法:通过timer定时器延时
接收单片机的数据没有事件响应 我在While循环中不停的判断单片机所收到的数据是否等于我所发的数据,若不相等,则我再发一次,然后再收,程序如下: Private Sub Write_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Write.Click '以下CWSerial是串口通信控件,Read和Write方法分别是收数据和发数据 CWSerial1.Write(TextOut.Text) '发数据 While (CWSerial1.Read() TextOut.Text) 'TextOut.Text是我要发的数据 MsgBox( "未能正确收到! ") CWSerial1.Write(TextOut.Text) '再发一次 End While MsgBox( "已正确收到! ") End Sub 关键是在发和收之间有个延迟(TimeOut),不可能我刚发完数据后就可以马上收到数据,必须等待1s后才有可能收到数据(我设的TimeOut为1000ms),我想要做的就是让程序等待1s 希望大哥能提供让程序等待的代码,例子也行