拿这个简单的比较loopValue == "Firstname",下面的说法是真的吗?
如果检查第一个的内部操作数char与比较字符串不匹配,它将提前中止
所以采取更原始的形式loopValue,"Firstname"两者都是[]byte。它会像回调循环一样遍历数组:
someInspectionFunc(loopValue, "Firstname", func(charA, charB) {
return charA == charB
})
...让它继续运行,直到它碰撞false并检查数量iterations是否等于它们的长度。它也先检查长度吗?
if len(loopValue) != len("Firstname") {
return false
}
我真的无法go在 GitHub 上的源代码中找到解释,因为它比我高一点。
我问这个的原因是因为我正在做大数据处理并且正在做基准测试并做 cpu、内存和分配pprof以从这个过程中挤出更多的汁液。从这个过程中,我开始思考 Go(但也只是一般的 C)将如何在引擎盖下做到这一点。这完全是在汇编级别上,还是已经在本机 Go 代码中进行了比较(有点像上面的片段中所描绘的)?
如果我太模糊或者我错过了什么,请告诉我。谢谢
更新
当我firstCharater在大字符串中进行匹配时json,在真正比较之前,我得到了3.7%100k 重条目的基准增益:
<some irrelevant inspection code>.. v[0] == firstChar && v == lookFor {
// Match found when it reaches here
}
上面的代码(尤其是在长字符串上)比只使用v == lookFor.
守着星空守着你
相关分类