int parseInt(const char* data,unsigned int* ind) { int i; std::copy(&data[*ind],&data[*ind+sizeof(int)],&i); // i) STD::copY // memcpy(&i,&data[*ind],sizeof(int)); // ii) MEMcpy std::cout << "--> " << i << std::endl; *ind += sizeof(int); std::cout << "OK" << std::endl; return i;}
在debian上,这段代码可以正常工作i)STD :: copY.
然后,我编译并运行嵌入式Arm上的代码(sizeof(int)也是4).带有i)的代码似乎也在运行,在函数内打印预期.
但是,从函数返回时会导致问题.
我试过也回1;而不是我,但相同.它没有抛出异常,也没有给出任何线索.我无法调试,因为我无法添加调试器,因为我有限制.
它只是在这个功能之后才会继续,即:
std::cout << "PARSING..." << std::endl;parseInt(data,&ind);std::cout << "PARSED!" << std::endl;...
给出这个(值11是正确的):
PARSING...--> 11OK
然后这个过程冻结了.
但是,当我使用ii)MEMcpy而不是std :: copy时,代码可以工作.因此,由于std :: copy,我似乎出现了这个问题.
有谁知道这里可以发生什么?
我是否错误地使用std :: copy?但那么为什么它适用于debian桌面而不是arm on embedded?
解决方法std::copy(&data[*ind],&i);
这将sizeof(int)字节复制到从& i开始的int数组的连续元素,不用说这导致未定义的行为,因为在& i处没有数组.
你可能意味着
std::copy(&data[*ind],reinterpret_cast<char*>(&i));
memcpy工作的原因是因为它显式地复制了字节,std :: copy比它在抽象迭代器上运行的其他标准算法更通用,由你决定是否正确调用它.
总结以上是内存溢出为你收集整理的c – std :: copy导致错误,无异常全部内容,希望文章能够帮你解决c – std :: copy导致错误,无异常所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)