我正在使用Qt Creator开发一个C ++应用程序和调试器来检查代码,我试图理解调试器报告的一些非常奇怪的结果。
if ( intDelimiter == -1
&& (intOpB = strProcessed.indexOf("[")) >= 0
&& (intClB = strProcessed.indexOf("]", ++intOpB) >= 0) ) {
strRef = strProcessed.mid(intOpB, intClB - intOpB);
if ( pobjNode != NULL ) {
strProcessed.replace(strRef, pobjNode->strGetAttr(strRef));
}
我有一个断点:
strRef = strProcessed.mid(intOpB, intClB - intOpB);
在strProcessed上面的代码片段中包含:
"1079-[height]"
当命中断点时,intClB包含1,而intOpB包含6。
intOpB是正确的,因为indexOf返回的值是5然后在搜索“]”之前递增,但intClB不正确,为什么调试器将其报告为1?这对我来说毫无意义。
我正在使用:
Qt Creator 3.6.0
Based on Qt 5.5.1 (GCC 4.9.1 20140922 (Red Hat 4.9.1-10), 64bit)
Built On Dec 15 2015 01:01:12
Revision: b52c2f91f5
正如king_nak所发现的那样,更正后的代码应为:
if ( intDelimiter == -1
&& ((intOpB = strProcessed.indexOf("[")) >= 0
&& (intClB = strProcessed.indexOf("]", ++intOpB)) >= 0) ) {
strRef = strProcessed.mid(intOpB, intClB - intOpB);
if ( pobjNode != NULL ) {
strProcessed.replace(strRef, pobjNode->strGetAttr(strRef));
}
}
答案 0 :(得分:2)
你错放了一个大括号:
(intClB = strProcessed.indexOf("]", ++intOpB) >= 0)
这会将strProcessed.indexOf("]", ++intOpB) >= 0
的结果分配给intClB
,解释为int
。由于此声明为true
,intClB = 1
。
你想:
(intClB = strProcessed.indexOf("]", ++intOpB) ) >= 0
^ Brace here