内容简介:在递归处理的调用中,在具体的工程实践中一般会引入递归深度检测,防止因为错误的数据造成系统的资源极大的消耗,本方法定义了一种通用简单的递归检查方法。
背景
在递归处理的调用中,在具体的工程实践中一般会引入递归深度检测,防止因为错误的数据造成系统的资源极大的消耗,本方法定义了一种通用简单的递归检查方法。
步骤
实现函数 RecursiveDepthChecker
func RecursiveDepthChecker(max int) bool {
//注意,这里我们跳过了本函数自己的栈,找到父调用的函数名
caller, _, _, _ := runtime.Caller(1)
currentFuncName := runtime.FuncForPC(caller).Name()
stack := make([]byte, 65535*1) //max 1MB stack traceback
//由于Golang Runtime中很多关于栈的函数未导出,无法使用。因此使用最肮脏的字符串检测方法
runtime.Stack(stack, false)
start := 0
depth := 0
for {
count := strings.Index(string(stack[start:]), currentFuncName)
if count >= 0 {
start += count + len(currentFuncName)
depth++
} else {
break
}
}
if depth > max {
return false
}
return true
}
在需要进行检测的函数用引入检查即可
func TFunc() {
fmt.Println("Start Caller...")
if !RecursiveDepthChecker(5) {
fmt.Println("Stack Overflow")
return
}
TFunc()
}
以上所述就是小编给大家介绍的《一种通用递归深度检测技术 - 基于栈帧内容的检测 - Golang语言描述》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 无线干扰及检测技术
- 自然场景人脸检测技术实践
- 基于全流量权限漏洞检测技术
- 浅析恶意Office文档检测技术
- Biofourmis旗下心律失常检测软件获FDA批准,利用深度学习技术提高检测准确率
- 初探Powershell与AMSI检测对抗技术
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
程序员面试笔试宝典
何昊、叶向阳、窦浩 / 2012-10 / 59.80元
《程序员面试笔试宝典》除了对传统的计算机相关知识(C/C++、数据结构与算法、操作系统、计算机网络与通信、软件工程、数据库、智力题、英语面试等)进行介绍外,还根据当前计算机技术的发展潮流,对面试笔试中常见的海量数据处理进行了详细的分析。同时,为了更具说服力,《程序员面试笔试宝典》特邀多位IT名企面试官现身说法,对面试过程中求职者存在的问题进行了深度剖析,同时《程序员面试笔试宝典》引入了一批来自于名......一起来看看 《程序员面试笔试宝典》 这本书的介绍吧!