我有3个完全相同的PCB容纳ATmega2560 MCU。
我将Atmel Studio 7用于 fuse 并闪烁十六进制。
我将Visual Studio与Visual Micro插件结合使用,将C和Arduino编码混合使用。

我有一个结构体数组定义。我从MCU的串行端口提供的json将数据填充到此结构数组中。 Json解析器是ArduinoJson。

定义:

#define MAX_RECORDS 20 //Max number of records in the struct

typedef struct Record {
    uint8_t id;//unique number to define data sequence
    uint8_t sec;
    uint8_t obj;
    uint16_t xs;
    uint16_t ys;
    uint16_t xe;
    uint16_t ye;
    uint8_t clr;
    uint8_t tsz;
    uint8_t tid;
} tRecord;

struct Record recordsOut[MAX_RECORDS];

主循环:
void loop() {
    if (IsNetworkAlertState == 0) {
        if (setupProg[0].gid == 255 || setupProg[0].bnr == 255 || recordsOut[0].id == 255) {
            if (IsNoSetupAlertState == 0) {
                IsNoSetupAlertState = 1;
            }
        }
        else {
            if (IsNoSetupAlertState == 1) {
                IsNoSetupAlertState = 0; // Nothing to alert
                RefreshScreen(); //Redraw data on screen after the setup is done!
            }
        }
    }
}

从序列号接收的样本数据:
const char* json = "{\"id\":1,\"sec\":1,\"obj\":1,\"xs\":1,\"ys\":0,\"xe\":158,\"ye\":62,\"clr\":0,\"tsz\":0,\"tid\":-1}";

call 者:

为了存储所有数据,这可能被称为20次。
最后,将其写入非 Volatile 存储器。
ApplyDesignSettings(json);

用于存储传入数据的函数:
void ApplyDesignSettings(char buffer[]) {

    const size_t bufferSize = JSON_OBJECT_SIZE(10) + 70;
    DynamicJsonBuffer jsonBuffer(bufferSize);

    if (IsDebugOn == 1) {
        Serial.print("buffer:");
        Serial.println(buffer);
    }

    JsonObject& root = jsonBuffer.parseObject(const_cast<char*>(buffer));
    if (!root.success()) {
        Serial.println("parseObject() failed#1");
        return;
    }

    uint8_t id = root["id"];
    uint8_t sec = root["sec"];
    uint8_t obj = root["obj"];
    uint16_t xs = root["xs"];
    uint16_t ys = root["ys"];
    uint16_t xe = root["xe"];
    uint16_t ye = root["ye"];
    uint8_t clr = root["clr"];
    uint8_t tsz = root["tsz"];
    uint8_t tid = root["tid"];

    int ref = id;
    int idx = ref - 1;
    recordsOut[idx].id = id;
    recordsOut[idx].sec = sec;
    recordsOut[idx].obj = obj;
    recordsOut[idx].xs = xs;
    recordsOut[idx].ys = ys;
    recordsOut[idx].xe = xe;
    recordsOut[idx].ye = ye;
    recordsOut[idx].clr = clr;
    recordsOut[idx].tsz = tsz;
    recordsOut[idx].tid = tid;
}

到现在为止还挺好。到目前为止,我对此感到满意。
这是“”;

有时,在刷新一些ATmega2560并推送上述数据后,它会丢失/覆盖/删除结构数组的第一个索引,而我发现它为空(255)
尽管其余记录都很好。

这是结果:

通过for循环调试,我得到以下信息。这仅在某些ATmega2560上发生。

(请注意:在此给定样本中,ID:8(索引7)之后都为空)
========================================
Design data in non-volatile memory:
========================================
id:255, sec:255, obj:255
id:2, sec:1, obj:2
id:3, sec:1, obj:3
id:4, sec:1, obj:3
id:5, sec:2, obj:1
id:6, sec:2, obj:2
id:7, sec:2, obj:3
id:8, sec:2, obj:3
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
id:255, sec:255, obj:255
========================================

通常,第一个索引应如下所示;
id:1, sec:1, obj:1

我希望我能解释得足够多,以便给您一个提示,出了什么问题?

从现在开始,我感谢您的投入。

最佳答案

最后,在将代码范围缩小到近2000行之后,我可以解决它。也感谢@Andy帮助我继续在这个问题上四处寻找。

ElseLoop内部,RefreshScreen();再次从EEPROM重新加载recordsOut,这将覆盖struct数组recordsOut,下一轮JSON数据将在那里继续。

我已经从RefreshScreen();中删除了EEPROM读取功能,并且开始工作。

08-07 18:31
查看更多