怎样才能让程序10秒后运行下一语句?

qdaijchf 2011-05-20 03:23:17
不使用Timer控件,运行messagebox.show("你好")后,间隔10秒,再运行messagebox.show("大家好")。


...全文
295 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
kxyzjm 2011-07-13
  • 打赏
  • 举报
回复
刚学.net,向大家学习
jk0144 2011-06-16
  • 打赏
  • 举报
回复
我来学习
wqs12ec056 2011-06-16
  • 打赏
  • 举报
回复
dim i as integer
Private Sub Timer1_Timer()
select case i
case 0:messagebox.show("你好")
case 1:messagebox.show("大家好")
case 2:messagebox.show("我很好")
......
end select
i=i+1
End Sub

Timer1的间隔时间设置成10秒
赫克托尔 2011-06-15
  • 打赏
  • 举报
回复
System.Threading.Thread.Sleep(10*1000);
nice_L 2011-06-15
  • 打赏
  • 举报
回复
System.Threading.Thread.Sleep(10000)
huzengzeng1 2011-06-13
  • 打赏
  • 举报
回复
if MessageBox.Show("你好") then
t = VB.Timer() '获取当前时间
Do
System.Windows.Forms.Application.DoEvents()
Loop Until VB.Timer() > t + 10.0#
'延迟10秒
MessageBox.Show("大家好")
end if
SP12345678902 2011-06-12
  • 打赏
  • 举报
回复
'********************************************************************************
'延迟函数,使程序延迟若干秒
'@date 2011/03/30
'@param delaytime 延迟的秒数
'@return 无
'********************************************************************************
Public Sub delaySeconds(delaytime As Single)
Dim start As Single
start = Timer
While delaytime > Timer - start
DoEvents
Wend
End Sub
123工艺品 2011-06-01
  • 打赏
  • 举报
回复
为什么不用TIMER控件?
控件不就是让我们用的吗
。。。。
cosmo_sei 2011-06-01
  • 打赏
  • 举报
回复
如果要求界面不锁死,必须使用多线程

new System.Threading.Thread(
() => {
MessageBox.Show("你好");
System.Threading.Thread.Sleep(3000);
MessageBox.Show("大家好");
}
).Start();
killeruser 2011-05-23
  • 打赏
  • 举报
回复
System.Threading.Thread.Sleep(10000)
gooodiuck 2011-05-23
  • 打赏
  • 举报
回复
用这个试试,
Private Declare Function GetTickCount Lib "kernel32" () As Integer
'获取系统开机到现在所过去的时间,ms级
dim a as integer=GetTickCount
Do : My.Application.DoEvents()
Loop Until GetTickCount - a >= 1000'1000毫秒
继续执行你要执行的语句
rmini 2011-05-23
  • 打赏
  • 举报
回复
继续关注
tk600158 2011-05-22
  • 打赏
  • 举报
回复
修改
If i > 5 Then Exit Do
可以更改延时的秒数
tk600158 2011-05-22
  • 打赏
  • 举报
回复
用最简单的
    Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
Dim RunTime As Date = Now()
MsgBox("你好")
Do
My.Application.DoEvents() '释放控制权给程序的其他事件
Dim i As Integer = DateDiff("s", RunTime, Now)
If i > 5 Then Exit Do
Loop
MsgBox("大家好")
End Sub
dengfeiling 2011-05-21
  • 打赏
  • 举报
回复

messagebox.show("你好");
System.Threading.Thread.Sleep(10*1000);
messagebox.show("大家好")
shiyuabc 2011-05-21
  • 打赏
  • 举报
回复
以上代码刚不久前才用过,VB6.0测试是可用的。虽然看起来代码很多,其实就一个模块,改下模块名,然后在需调用窗口中加两句定义就可以调用了。
shiyuabc 2011-05-21
  • 打赏
  • 举报
回复
VB无卡死延时(非sleep)
2009-11-12 18:05
首先添加类模块。

内容如下:

'''''''''''''''''''''''''''''''''''''''''

Option Explicit

Private Type FILETIME
dwLowDateTime As Long
dwHighDateTime As Long
End Type

Private Const WAIT_ABANDONED& = &H80&
Private Const WAIT_ABANDONED_0& = &H80&
Private Const WAIT_FAILED& = -1&
Private Const WAIT_IO_COMPLETION& = &HC0&
Private Const WAIT_OBJECT_0& = 0
Private Const WAIT_OBJECT_1& = 1
Private Const WAIT_TIMEOUT& = &H102&
Private Const INFINITE = &HFFFF
Private Const ERROR_ALREADY_EXISTS = 183&
Private Const QS_HOTKEY& = &H80
Private Const QS_KEY& = &H1
Private Const QS_MOUSEBUTTON& = &H4
Private Const QS_MOUSEMOVE& = &H2
Private Const QS_PAINT& = &H20
Private Const QS_POSTMESSAGE& = &H8
Private Const QS_SENDMESSAGE& = &H40
Private Const QS_TIMER& = &H10
Private Const QS_MOUSE& = (QS_MOUSEMOVE Or QS_MOUSEBUTTON)
Private Const QS_INPUT& = (QS_MOUSE Or QS_KEY)
Private Const QS_ALLEVENTS& = (QS_INPUT Or QS_POSTMESSAGE Or QS_TIMER Or QS_PAINT Or QS_HOTKEY)
Private Const QS_ALLINPUT& = (QS_SENDMESSAGE Or QS_PAINT Or QS_TIMER Or QS_POSTMESSAGE Or QS_MOUSEBUTTON Or QS_MOUSEMOVE Or QS_HOTKEY Or QS_KEY)

Private Const UNITS = 4294967296#
Private Const MAX_LONG = -2147483648#

Private Declare Function CreateWaitableTimer Lib "kernel32" Alias "CreateWaitableTimerA" (ByVal lpSemaphoreAttributes As Long, ByVal bManualReset As Long, ByVal lpName As String) As Long
Private Declare Function OpenWaitableTimer Lib "kernel32" Alias "OpenWaitableTimerA" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal lpName As String) As Long
Private Declare Function SetWaitableTimer Lib "kernel32" (ByVal hTimer As Long, lpDueTime As FILETIME, ByVal lPeriod As Long, ByVal pfnCompletionRoutine As Long, ByVal lpArgToCompletionRoutine As Long, ByVal fResume As Long) As Long
Private Declare Function CancelWaitableTimer Lib "kernel32" (ByVal hTimer As Long)
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function MsgWaitForMultipleObjects Lib "user32" (ByVal nCount As Long, pHandles As Long, ByVal fWaitAll As Long, ByVal dwMilliseconds As Long, ByVal dwWakeMask As Long) As Long

Private mlTimer As Long

Private Sub Class_Terminate()
On Error Resume Next
If mlTimer <> 0 Then CloseHandle mlTimer
End Sub

Public Sub Wait(MilliSeconds As Long)
On Error GoTo ErrHandler
Dim ft As FILETIME
Dim lBusy As Long
Dim lRet As Long
Dim dblDelay As Double
Dim dblDelayLow As Double

mlTimer = CreateWaitableTimer(0, True, App.EXEName & "Timer" & Format$(Now(), "NNSS"))

If Err.LastDllError <> ERROR_ALREADY_EXISTS Then
ft.dwLowDateTime = -1
ft.dwHighDateTime = -1
lRet = SetWaitableTimer(mlTimer, ft, 0, 0, 0, 0)
End If

' Convert the Units to nanoseconds.
dblDelay = CDbl(MilliSeconds) * 10000#

' By setting the high/low time to a negative number, it tells
' the Wait (in SetWaitableTimer) to use an offset time as
' opposed to a hardcoded time. If it were positive, it would
' try to convert the value to GMT.
ft.dwHighDateTime = -CLng(dblDelay / UNITS) - 1
dblDelayLow = -UNITS * (dblDelay / UNITS - Fix(CStr(dblDelay / UNITS)))

If dblDelayLow < MAX_LONG Then dblDelayLow = UNITS + dblDelayLow

ft.dwLowDateTime = CLng(dblDelayLow)
lRet = SetWaitableTimer(mlTimer, ft, 0, 0, 0, False)

Do
' QS_ALLINPUT means that MsgWaitForMultipleObjects will
' return every time the thread in which it is running gets
' a message. If you wanted to handle messages in here you could,
' but by calling Doevents you are letting DefWindowProc
' do its normal windows message handling---Like DDE, etc.
lBusy = MsgWaitForMultipleObjects(1, mlTimer, False, INFINITE, QS_ALLINPUT&)
DoEvents
Loop Until lBusy = WAIT_OBJECT_0

' Close the handles when you are done with them.
CloseHandle mlTimer
mlTimer = 0
Exit Sub

ErrHandler:
Err.Raise Err.Number, Err.Source, "[clsWaitableTimer.Wait]" & Err.Description
End Sub

'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

'以上保存名字为:clsWaitableTimer

'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

把这个放到程序里:

Private mobjWaitTimer As clsWaitableTimer

Set objTimer = New clsWaitableTimer

使用方法:

mobjWaitTimer.Wait(5000) '延时5秒。



很不错,不过调用方法不对。
正确的应该是
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Private mobjWaitTimer As clsWaitableTimer
Dim objTimer As clsWaitableTimer

Private Sub Command1_Click()
Set objTimer = New clsWaitableTimer
objTimer.Wait (5000) '延时5秒。
Print "test"
End Sub

qq37724861 2011-05-21
  • 打赏
  • 举报
回复

Private Declare Sub Sleep Lib "Kernel32" (ByVal dwMilliseconds As Long)

Private Sub Form_click()
MsgBox "你好1"
DoEvents
Sleep 1000 * 10
MsgBox "你好2"
End Sub
  • 打赏
  • 举报
回复
Thread.Sleep(10*1000);
//开启新线程
zhao38322684 2011-05-20
  • 打赏
  • 举报
回复
哦。。是10秒。
加载更多回复(2)
更优更快 人工智能自动SQL优化----------http://www.sina.com.cn 2001/12/12 17:48 中国电脑教育报文/SQL爱好者  所谓SQL,就是指Structured Query Language(结构化查询语言),它是目前使用最广泛的数据库语言,用来和数据库打交道,从数据库中得到用户需要的数据。但是要想熟练使用SQL语句,也不是一件简单的事,有些语句使用起来也比较麻烦。如果我们对SQL语句进行优化,那么用户使用起来 就会方便许多。  简单来说,SQL语句的优化就是将性能低下的SQL语句转换成达到同样目的的性能优异的SQL语句。人工智能自动SQL优化就是使用人工智能技术,自动对SQL语句进行重写,找到性能最好的等效SQL语句。  人工智能自动SQL 优化  随着人工智能技术的发展和在数据库优化领域应用的深入,在20世纪90年代末终于出现了突破性的进展——人工智能自动SQL优化。目前在商用数据库领域LECCO TechnologyLimited(灵高公司)拥有该技术并提供使用该技术的自动优化产品——LECCO SQL Expert,其支持Oracle、Sybase、MS SQLServer和IBMDB2数据库平台。该产品针对数据库应用的开发和维护阶段提供了几个特别的模块:SQL语法优化器、PL/SQL集成化开发调试环境(IDE)、扫描器、数据库监视器等。图1 人工智能自动SQL优化示意图  其核心模块之一“SQL语法优化器”的工作原理大致如下(如图1):  一条源SQL语句输入→“人工智能反馈式搜索引擎”对输入的SQL语句结合检测到的数据库结构和索引进行重写,产生N条等效的SQL语句输出→产生的N条等效SQL语句再送入“人工智能反馈式搜索引擎”进行重写,直至无法产生新的输出或搜索限额满→对 输出的SQL语句进行过滤,选出具有不同执行计划的SQL语句(即不同的执行效率)→对得到的SQL语句进行批量测试,找出性能最好的SQL语句。图2 优化前的SQL语句  自动优化实例  假设我们从源代码中抽取出这条SQL语句(如图2):  SELECTCOUNT(*)FROMEMPLOY-EE WHEREEXISTS(SELECT'X'FROM DEPARTMENTswheresEMP_DEPT=DPT_IDAND DPT_NAME LIKE'AC%')AND EMP_IDIN(SELECT SAL_EMP_IDFROM EMP_SAL_HISTB WHERESAL_SALARY>70000)   按“优化”按钮后,经过十几,SQL Expert就完成了优化的过程,从优化细节中可以看到,它在十几的时间内重写产生了2267条等价的SQL语句,其中136条SQL语句有不同的执行计划(如图3)。图3 优化结果  接下来我们可以对自动重写产生的136条具有不同执行计划的SQL语句进行批运行测试,以选出性能最佳的等效SQL语句。按下“批运行”按钮,在“终止条件”页选择“最佳运行时间SQL语句”(如图4),按“确定”。图4 测试条件  经过几分钟的测试运行后,我们可以发现SQL124的运行时间和反应时间最短。运行速度约有22.75倍的提升(源SQL语句运行时间为2.73,SQL124运行时间为0.12,如图5)。图5 测试结果  我们把SQL124放入源代码中,结束一条SQL语句的优化工作。从上例可以看到,LECCO SQL Expert的自动重写技术使原来需要几小时才能完成的SQL语句的优化工作,缩减到几分钟之内就可以完成。数据库管理员和开发人员可以从繁重的SQL语句优化工作中解脱出来。  边做边学式训练  LECCO SQL Expert不仅能够找到最佳的SQL语句,而且提供的“边做边学式训练”还能够教会开发人员和数据库管理员如何写出性能最好的SQL语句。LECCO SQL Expert的“SQL比较器”可以标明源SQL和待选SQL之间的不同之处。LECCO SQL Expert详尽的上下文敏感帮助系统可以指出执行计划的深层含义。图6 源语句与SQL124的比较  以上面优化的结果为例,为了查看源SQL语句和SQL124在写法上的不同,我们可以按下“比较器”按钮,对SQL124和源SQL语句进行比较。如果选择“双向比较”复选框,“SQL比较器”可以将两条互相间的不同之处以蓝色表示。当然,你也可以从 源语句和重写后的SQL语句中任选两条进行比较(如图6)。  从比较的结果可以看到,重写得到的SQL124把第一个Exists改写成了In;在字段DPT_ID上进行了合并空字符串的操作以诱导数据库先执行子查询中的(SELECTDPT_ID||'FROMDEPART-MENTWH

16,718

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧