我用tesseract ocr得到了一个奇怪的探测器。一切正常,就像ocr部分一样。字符被正确识别。但它在完成所有计算后崩溃了 这只发生在我在一个线程中运行代码时。
void server(boost::asio::io_service & io_service, unsigned short port)
{
tcp::acceptor a(io_service, tcp::endpoint(tcp::v4(), port));
for (;;)
{
a.accept(sock);
//boost::thread t(session, boost::ref(sock));
//t.detach();
std::thread(session, std::move(sock)).detach();
}
}
void session(tcp::socket & sock)
{
tesseract::TessBaseAPI api;
if (api.Init("", "eng"))
{
fprintf(stderr, "Could not initialize tesseract.\n");
exit(1);
}
for (int i = 0; i < 81; i++)
{
if (!sudokuDatainside[i].empty())
{
api.SetImage((uchar*)sudokuDatainside[i].data, sudokuDatainside[i].size().width, sudokuDatainside[i].size().height, sudokuDatainside[i].channels(), sudokuDatainside[i].step1());
// Get OCR result
outText = api.GetUTF8Text();
std::cout << outText << std::endl;
}
else
{
std::cout << "Nothing - " << i << std::endl;
}
}
api.End();
}
编辑:似乎它不是api.End()的问题。即使我没有调用这个方法,当线程结束时程序崩溃...确实支持线程吗?
答案 0 :(得分:0)
经过几个小时的努力寻找解决方案。我在构建调试库时遇到了一个错误。 所以重建tesseract调试库解决了这个问题。 以下是我使用的说明: https://github.com/charlesw/tesseract-vs2012