为什么程序打印在调试和发布中浮动不同

Why is the program printing float different in debug and release?

本文关键字:布中浮 程序 打印 调试 为什么      更新时间:2023-10-16

我有一个奇怪的问题,我无法解决。我从微控制器上通过TCP发送了3个浮点值。在我的PC上,我只想打印这些值。当我以发布模式运行代码时,它仅在小数点前面打印数字。但是当我调试程序时,一切都很好。

这是代码:

char laserL_Buffer[32];
char laserR_Buffer[32];
char laserM_Buffer[32];
TCPConnector* connector = new TCPConnector();
TCPStream* stream = connector->connect("10.42.0.2",3333);
//Send l for laserData
char cT = 'l';
stream->send(&cT,1);
//Receive the Data for Left Right and Middle Range from laserScanner
stream->receive(laserL_Buffer,32);
stream->receive(laserR_Buffer,32);
stream->receive(laserM_Buffer,32);
delete stream;
float l = strtof(laserL_Buffer,nullptr);
float m = strtof(laserM_Buffer,nullptr);
float r = strtof(laserR_Buffer,nullptr);
std::cout << std::fixed << std::setprecision(8) << l << std::endl;
std::cout << std::fixed << std::setprecision(8) << m << std::endl;
std::cout << std::fixed << std::setprecision(8) << r << std::endl;

好吧,谢谢您的所有答案,我只是弄清楚了这个问题。我将strtof更改为boost :: lexical_cast。然后工作正常。

发布模式可能具有不同的FP策略集。根据您想要的优化水平,有不同的浮点算术模式。例如,MSVC具有严格,快速和精确的模式。

从您的代码中,我猜您为每个浮子发送了32个字符,并且您的缓冲区具有Lenght 32,因此它们不是零。使它们长33个字节,并将最后一个字节设置为零,因此Strtof将知道何时结束解析并查看其是否有效。我希望我能告诉您为什么它在调试中与发行版的工作完全不同,但是基本上,您有一些障碍,并且编译器可能已将您的本地变量放置在零存储空间中。在发布中,它们很可能是对优化的对齐。

char laserL_Buffer[33];
char laserR_Buffer[33];
char laserM_Buffer[33];
TCPConnector* connector = new TCPConnector();
TCPStream* stream = connector->connect("10.42.0.2",3333);
//Send l for laserData
char cT = 'l';
stream->send(&cT,1);
//Receive the Data for Left Right and Middle Range from laserScanner
stream->receive(laserL_Buffer,32);
stream->receive(laserR_Buffer,32);
stream->receive(laserM_Buffer,32);
laserL_Buffer[32] = laserR_Buffer[32] = laserM_Buffer[32] = 0;
delete stream;
float l = strtof(laserL_Buffer,nullptr);
float m = strtof(laserM_Buffer,nullptr);
float r = strtof(laserR_Buffer,nullptr);
std::cout << std::fixed << std::setprecision(8) << l << std::endl;
std::cout << std::fixed << std::setprecision(8) << m << std::endl;
std::cout << std::fixed << std::setprecision(8) << r << std::endl;

我将其更改为以下内容,然后使用。

char laserL_Buffer[8];
char laserR_Buffer[8];
char laserM_Buffer[8];
LaserData l_data;
TCPConnector* connector = new TCPConnector();
TCPStream* stream = connector->connect("10.42.0.2",3333);
//Send p for position
char cT = 'l';
stream->send(&cT,1);
//Receive the Data for Left Right and Middle Range from laserScanner
stream->receive(laserL_Buffer,8);
stream->receive(laserR_Buffer,8);
stream->receive(laserM_Buffer,8);
delete stream;
delete connector;
l_data.laserLeftRange = boost::lexical_cast<float>(laserL_Buffer);
l_data.laserRightRange = boost::lexical_cast<float>(laserR_Buffer);
l_data.laserMidRange = boost::lexical_cast<float>(laserM_Buffer);