为什么我在 Visual Studio 和 Qt 上编译相同的代码,却得到不同的结果?
Why do I compile the same code on the Visual Studio and Qt, but get different results?
事情是这样的。这些天我在 Qt 框架上重写我的 OpenCV 代码,代码 运行 在 Visual Studio 2013 上很好,但是当我 运行 它在 Qt 上时,发生了一些奇怪的事情。
为了简化问题,我又写了一段代码做实验,果然问题依旧。
这是代码,
#include <iostream>
#include <highgui.hpp>
#include <core.hpp>
#include <cv.hpp>
using namespace std;
using namespace cv;
int main()
{
Mat view, viewGray;
vector<Point2f> pointBuf;
Size boardSize;
boardSize.width = 7; boardSize.height = 9;
view = imread("G:\C++\OpenCV\OpenCV\left1.jpg", 1);
cout << pointBuf.size() << endl;
cout << boardSize << endl;
cvtColor(view, viewGray, COLOR_BGR2GRAY);
bool found = findChessboardCorners(view, boardSize, pointBuf, \
CV_CALIB_CB_ADAPTIVE_THRESH | \
CV_CALIB_CB_FAST_CHECK | \
CV_CALIB_CB_NORMALIZE_IMAGE);
cout << pointBuf.size() << endl;
cout << found << endl;
namedWindow("show", CV_WINDOW_NORMAL);
imshow("show", view);
waitKey(0);
return 0;
}
当我 运行 它在 Visual Studio 上时,一切正常。调试结果如下
VS2013 上的调试信息:
bool found = findChessboardCorners(...)
行之前的pointBuf大小为0,在那行之后变为63。
但是当我运行它在Qt上时,调试结果变得非常荒谬,
namedWindow("show", CV_WINDOW_NORMAL);
运行s之前的代码没有任何警告但是得到了不同的结果,bool found = findChessboardCorners(...)
行之前pointBuf的大小也是0,但是变成了一个很该行之后的巨大数字是 4294044375。
但是在namedWindow("show", CV_WINDOW_NORMAL);
之后,又出现了一个问题,
:-1: error: Exception at 0x778a768b, code: 0xc0000005: read access violation at: 0x0, flags=0x0 (first chance)
整个调试信息如下,
关于 Qt 的调试信息:
OS: windows 10 个 64 位
Qt 愿景:Qt5.6.0 与 MSVC 2013
Visual Studio 愿景:Visual Studio 2013.
OpenCV 愿景:OpenCV3.0
更新:初始化了一些变量,问题依旧。
更新 2:@Miki 认为我使用了错误的 OpenCV 库(例如,在发布中使用了调试库),所以我给出了我所有的配置信息如下,希望有人能帮我一个忙。
QT += core
QT -= gui
CONFIG += c++11
TARGET = testApp
CONFIG += console
CONFIG -= app_bundle
TEMPLATE = app
SOURCES += main.cpp
INCLUDEPATH +=F:\opencv\build\include \
F:\opencv\build\include\opencv \
F:\opencv\build\include\opencv2
LIBS +=F:\opencv\build\x86\vc12\lib\opencv_ts300.lib \
F:\opencv\build\x86\vc12\lib\opencv_ts300d.lib \
F:\opencv\build\x86\vc12\lib\opencv_world300.lib \
F:\opencv\build\x86\vc12\lib\opencv_world300d.lib
update3:我重新编译了opencv库,然后做了和上面一样的测试,这次我得到的pointBuf的大小是1638而不是4294044375。所以我确定问题出在OpenCV本身。
update4:嗯,这个问题已经自己解决了。我把opencv vision从3.0改成了2.4.12,然后整个世界都安静了。所以我是对的,问题出在opencv本身。
update5:@Miki 是对的,我确实使用了错误的库。我昨天忘记先清除项目,这就是我按照@Miki 告诉我的去做但没有用的原因。谢谢@Miki
好吧,很抱歉,我有解决方案时没有立即添加答案。
问题出在调试库和发布库之间使用错误
这是正确的配置,
CONFIG(debug, debug|release)
{
LIBS +=F:\opencv30\build\x86\vc12\lib\opencv_ts300d.lib \
F:\opencv30\build\x86\vc12\lib\opencv_world300d.lib
}
CONFIG(release, debug|release)
{
LIBS +=F:\opencv30\build\x86\vc12\lib\opencv_ts300.lib \
F:\opencv30\build\x86\vc12\lib\opencv_world300.lib
}
最后,非常感谢大家的帮助,这里是我去过的最温暖的社区。谢谢大家。
事情是这样的。这些天我在 Qt 框架上重写我的 OpenCV 代码,代码 运行 在 Visual Studio 2013 上很好,但是当我 运行 它在 Qt 上时,发生了一些奇怪的事情。
为了简化问题,我又写了一段代码做实验,果然问题依旧。
这是代码,
#include <iostream>
#include <highgui.hpp>
#include <core.hpp>
#include <cv.hpp>
using namespace std;
using namespace cv;
int main()
{
Mat view, viewGray;
vector<Point2f> pointBuf;
Size boardSize;
boardSize.width = 7; boardSize.height = 9;
view = imread("G:\C++\OpenCV\OpenCV\left1.jpg", 1);
cout << pointBuf.size() << endl;
cout << boardSize << endl;
cvtColor(view, viewGray, COLOR_BGR2GRAY);
bool found = findChessboardCorners(view, boardSize, pointBuf, \
CV_CALIB_CB_ADAPTIVE_THRESH | \
CV_CALIB_CB_FAST_CHECK | \
CV_CALIB_CB_NORMALIZE_IMAGE);
cout << pointBuf.size() << endl;
cout << found << endl;
namedWindow("show", CV_WINDOW_NORMAL);
imshow("show", view);
waitKey(0);
return 0;
}
当我 运行 它在 Visual Studio 上时,一切正常。调试结果如下
VS2013 上的调试信息:
bool found = findChessboardCorners(...)
行之前的pointBuf大小为0,在那行之后变为63。
但是当我运行它在Qt上时,调试结果变得非常荒谬,
namedWindow("show", CV_WINDOW_NORMAL);
运行s之前的代码没有任何警告但是得到了不同的结果,bool found = findChessboardCorners(...)
行之前pointBuf的大小也是0,但是变成了一个很该行之后的巨大数字是 4294044375。
但是在namedWindow("show", CV_WINDOW_NORMAL);
之后,又出现了一个问题,
:-1: error: Exception at 0x778a768b, code: 0xc0000005: read access violation at: 0x0, flags=0x0 (first chance)
整个调试信息如下,
关于 Qt 的调试信息:
OS: windows 10 个 64 位
Qt 愿景:Qt5.6.0 与 MSVC 2013
Visual Studio 愿景:Visual Studio 2013.
OpenCV 愿景:OpenCV3.0
更新:初始化了一些变量,问题依旧。
更新 2:@Miki 认为我使用了错误的 OpenCV 库(例如,在发布中使用了调试库),所以我给出了我所有的配置信息如下,希望有人能帮我一个忙。
QT += core
QT -= gui
CONFIG += c++11
TARGET = testApp
CONFIG += console
CONFIG -= app_bundle
TEMPLATE = app
SOURCES += main.cpp
INCLUDEPATH +=F:\opencv\build\include \
F:\opencv\build\include\opencv \
F:\opencv\build\include\opencv2
LIBS +=F:\opencv\build\x86\vc12\lib\opencv_ts300.lib \
F:\opencv\build\x86\vc12\lib\opencv_ts300d.lib \
F:\opencv\build\x86\vc12\lib\opencv_world300.lib \
F:\opencv\build\x86\vc12\lib\opencv_world300d.lib
update3:我重新编译了opencv库,然后做了和上面一样的测试,这次我得到的pointBuf的大小是1638而不是4294044375。所以我确定问题出在OpenCV本身。
update4:嗯,这个问题已经自己解决了。我把opencv vision从3.0改成了2.4.12,然后整个世界都安静了。所以我是对的,问题出在opencv本身。
update5:@Miki 是对的,我确实使用了错误的库。我昨天忘记先清除项目,这就是我按照@Miki 告诉我的去做但没有用的原因。谢谢@Miki
好吧,很抱歉,我有解决方案时没有立即添加答案。
问题出在调试库和发布库之间使用错误
这是正确的配置,
CONFIG(debug, debug|release)
{
LIBS +=F:\opencv30\build\x86\vc12\lib\opencv_ts300d.lib \
F:\opencv30\build\x86\vc12\lib\opencv_world300d.lib
}
CONFIG(release, debug|release)
{
LIBS +=F:\opencv30\build\x86\vc12\lib\opencv_ts300.lib \
F:\opencv30\build\x86\vc12\lib\opencv_world300.lib
}
最后,非常感谢大家的帮助,这里是我去过的最温暖的社区。谢谢大家。