分享
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
在实时性要求高的工程项目中,对于方法执行的时间有较高的要求,本示例程序,实现了一种安全的传入任意参数的方法限时调用工具类,能执行方法的最大容忍运行时间,保证服务不超时。
//@description 超时运行方法,限制方法的运行时间
// 需要实现抽象接口AppRuning的Run方法
// 调用时TimeOutRun(timeout, fun, args...)
// timeout超时时间(ms),fun实现Run()的回调方法,args...为方法调用参数列表
//@author chenbintao
//@data 2017年03月20日 19:00 初稿
// 2017年03月20日 19:30 调试通过
package main
import (
"log"
"runtime/debug"
"time"
)
const (
TIME_OUT_RUN_OK int = 1 //运行完成
TIME_OUT_RUN_OUT int = 0 //超时退出
)
var (
_TIME_OUT_RUN_DEBUG = false
)
func SetDebug(debug_mode bool) {
//设置调试模式:true调试模式
_TIME_OUT_RUN_DEBUG = debug_mode
return
}
func TimeOutRunApp(timeout uint64, callback func(v ...interface{}), v ...interface{}) {
var single chan int = make(chan int, 1)
//开启线程运行(参数必须采用v...,这样才是全参数传递,否则会出现[]interface{}问题)
go timeOutRunApp(single, safeFunction(callback), v...)
//阻塞等待运行结果或超时
select {
case <-single:
//运行完成退出
if _TIME_OUT_RUN_DEBUG {
log.Println("run ok!")
}
close(single)
return
case <-time.After(time.Millisecond /*ms*/ * time.Duration(timeout)):
//超时退出
if _TIME_OUT_RUN_DEBUG {
log.Println("run timeout!")
}
close(single)
return
}
}
func timeOutRunApp(single chan int, callback func(v ...interface{}), v ...interface{}) {
//调用执行回调方法,执行完成后,写入chan
callback(v...)
single <- TIME_OUT_RUN_OK
return
}
func safeFunction(fn func(v ...interface{})) func(v ...interface{}) {
//闭包方法安全运行
return func(v ...interface{}) {
defer func() {
if e, ok := recover().(error); ok {
log.Println("WARN: panic in %v - %v", fn, e)
log.Println(string(debug.Stack()))
}
}()
fn(v...)
}
}
//=================测试样例
func Run(v ...interface{}) {
//用于变量类型转换
var convert interface{}
//第一个参数
convert = v[0]
var args0 string = convert.(string)
//第二个参数
convert = v[1]
var args1 string = convert.(string)
//循环执行,flag=false:演示超时的情况,flag=true:演示非超时的情况
var count uint32
var flag bool = false
for {
time.Sleep(time.Millisecond * 1000)
log.Println(args0, args1, count)
count++
if flag {
return
}
}
return
}
func main() {
//设置调用超时5s,传入回调方法类App,及相关参数
TimeOutRunApp(5000, Run, "利用interface实现超时执行某方法:", "count=")
}
运行可参见http://studygolang.com/topics/2569
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1550 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
在实时性要求高的工程项目中,对于方法执行的时间有较高的要求,本示例程序,实现了一种安全的传入任意参数的方法限时调用工具类,能执行方法的最大容忍运行时间,保证服务不超时。
//@description 超时运行方法,限制方法的运行时间
// 需要实现抽象接口AppRuning的Run方法
// 调用时TimeOutRun(timeout, fun, args...)
// timeout超时时间(ms),fun实现Run()的回调方法,args...为方法调用参数列表
//@author chenbintao
//@data 2017年03月20日 19:00 初稿
// 2017年03月20日 19:30 调试通过
package main
import (
"log"
"runtime/debug"
"time"
)
const (
TIME_OUT_RUN_OK int = 1 //运行完成
TIME_OUT_RUN_OUT int = 0 //超时退出
)
var (
_TIME_OUT_RUN_DEBUG = false
)
func SetDebug(debug_mode bool) {
//设置调试模式:true调试模式
_TIME_OUT_RUN_DEBUG = debug_mode
return
}
func TimeOutRunApp(timeout uint64, callback func(v ...interface{}), v ...interface{}) {
var single chan int = make(chan int, 1)
//开启线程运行(参数必须采用v...,这样才是全参数传递,否则会出现[]interface{}问题)
go timeOutRunApp(single, safeFunction(callback), v...)
//阻塞等待运行结果或超时
select {
case <-single:
//运行完成退出
if _TIME_OUT_RUN_DEBUG {
log.Println("run ok!")
}
close(single)
return
case <-time.After(time.Millisecond /*ms*/ * time.Duration(timeout)):
//超时退出
if _TIME_OUT_RUN_DEBUG {
log.Println("run timeout!")
}
close(single)
return
}
}
func timeOutRunApp(single chan int, callback func(v ...interface{}), v ...interface{}) {
//调用执行回调方法,执行完成后,写入chan
callback(v...)
single <- TIME_OUT_RUN_OK
return
}
func safeFunction(fn func(v ...interface{})) func(v ...interface{}) {
//闭包方法安全运行
return func(v ...interface{}) {
defer func() {
if e, ok := recover().(error); ok {
log.Println("WARN: panic in %v - %v", fn, e)
log.Println(string(debug.Stack()))
}
}()
fn(v...)
}
}
//=================测试样例
func Run(v ...interface{}) {
//用于变量类型转换
var convert interface{}
//第一个参数
convert = v[0]
var args0 string = convert.(string)
//第二个参数
convert = v[1]
var args1 string = convert.(string)
//循环执行,flag=false:演示超时的情况,flag=true:演示非超时的情况
var count uint32
var flag bool = false
for {
time.Sleep(time.Millisecond * 1000)
log.Println(args0, args1, count)
count++
if flag {
return
}
}
return
}
func main() {
//设置调用超时5s,传入回调方法类App,及相关参数
TimeOutRunApp(5000, Run, "利用interface实现超时执行某方法:", "count=")
}