我下面一直遇到奇怪问题的代码旨在修剪掉整数数组的未使用部分,然后将其转换为字符串。

例如:_ABC__DE______将变为_ABC__DE

当输入使用默认字符填充时,将出现问题。 (示例中为“_”)。
sLength是整数数组chars的长度

有问题的代码:

  int inputLength = sLength - 1;

  while (chars[inputLength] == defaultChar && inputLength >= 0) {
    inputLength--;
  }

  inputLength++;

  Serial.println("input length: " + String(inputLength));
  // (in)sanity check
  Serial.println(inputLength);
  Serial.println(String(inputLength));
  Serial.println(inputLength <= 0);
  Serial.println(0 <= 0);
  Serial.println(inputLength == 0);
  Serial.println(0 == 0);

  if (inputLength <= 0) {
    //reset cursor position
    Serial.println("index set to 0");
    index = 0;
  } else {
    output = "";
    for (int i = 0; i < inputLength; i++) {
      char c = charSet[chars[i]];
      if (c == '_') {
        c = ' ';
      }
      output += c;
    }
    done = true;
  }

给定数组填充defaultChar时的输出:
input length: 0
0
0
0
1
0
1

如果我的解释正确,则输出表示偶数行为0> 0和0 = / = 0,而奇数行为0
我想出的解决方法是替换
  while (chars[inputLength] == defaultChar && inputLength >= 0) {
    inputLength--;
  }

具有以下之一
  while (inputLength >= 0 && chars[inputLength] == defaultChar) {
    inputLength--;
  }


  while (chars[inputLength] == defaultChar) {
    inputLength--;
    if (inputLength < 0) {
      break;
    }
  }

两者都导致输出:
input length: 0
0
0
1
1
1
1
index set to 0

为什么这会改变结果?
据我所知,&&运算符是可交换的。

有什么我想念的东西使
chars[inputLength] == defaultChar && inputLength >= 0
不等于
inputLength >= 0 && chars[inputLength] == defaultChar

如果相关,它将使用旧版 bootstrap 通过IDE 1.8.8在328P Arduino Nano上运行

最佳答案

&&不是可交换的。它首先评估左操作数,然后在左操作数评估为0时停止。

您的原始代码失败,因为在某些时候它会评估chars[-1](如果chars是一个数组,则会导致undefined behaviour)。替代版本没有这个问题,因为它在使用>= 0作为数组索引之前执行了inputLength测试。

09-06 15:14