草庐IT

current_user_can

全部标签

c++ - opencv: namedWindow() 错误 "can' t 打开显示”!

我将namedWindow与openCV一起使用,但出现错误:(Image1):Gtk-WARNING**:无法打开显示:"代码是:Matimage1=imread("image1.jpg");cv::namedWindow("image1");cv::imshow("image1",image1);waitKey(0);有人说他通过“exportDISPLAY=:0”解决了这个问题。但我真的不明白这个解决方案是什么意思。因为我是opencv和c++的初学者。有人可以详细解释一下吗。例如如何添加代码?在哪里实现? 最佳答案 您似乎缺

c++ - 在 Qt : Can I output to `stdout` , 中,我可以使用 qDebug() 输出到 `stderr` 吗?

到目前为止,我使用qDebug().noquote()输出所有内容.这很容易,因为它只需要一个简单的#import现在我需要将所有内容输出到stdout,但我不知道如何轻松地做到这一点。这是我被教导的方式:QTextStreamcout(stdout,QIODevice::WriteOnly);但是,创建一个新对象比简单的#import要麻烦一点。.什么是好的/最不麻烦的处理方式stdout在qt中? 最佳答案 qDebug()、qInfo()等都通过管道传输到默认消息处理程序。但是您可以轻松地安装自己的,将调试字符串写入不同的流、

c++ - 为什么二进制文件不放在 CMAKE_CURRENT_BINARY_DIR 中?

据我了解,CMAKE_CURRENT_BINARY_DIR应该指向当前CMakeLists.txt文件的二进制文件所在的目录。然而,情况似乎并非如此。考虑这个文件结构:CMakeTest+-CMakeLists.txt+-main.cppCMakeLists.txtcmake_minimum_required(VERSION3.2)add_executable(CMakeTestmain.cpp)message(STATUS"CMAKE_CURRENT_BINARY_DIR=${CMAKE_CURRENT_BINARY_DIR}")main.cpp#includeintmain(){s

c++ - 评估 C++ 字符串中的表达式 : "Hi ${user} from ${host}"

我正在寻找一种干净的C++方法来解析包含用${}包裹的表达式的字符串,并从以编程方式评估的表达式构建结果字符串。示例:如果我实现让“user”评估为“foo”的程序,“Hi${user}from${host}”将评估为“Hifoofrombar”等我正在考虑的当前方法包括一个状态机,该状态机一次从字符串中吃掉一个字符,并在到达“}”后计算表达式。有什么提示或其他建议吗?注意:boost::是最受欢迎的!:-)更新感谢前三个建议!不幸的是我让这个例子太简单了!我需要能够检查${}中的内容,所以这不是简单的搜索和替换。也许它会说${uppercase:foo}然后我必须使用“foo”作为H

c++ - 模板 :Name resolution:Point of instantiation: -->can any one tell some more examples for this statement?

这是来自ISOC++标准14.6.4.1实例化点的声明Forafunctiontemplatespecialization,amemberfunctiontemplatespecialization,oraspecializationforamemberfunctionorstaticdatamemberofaclasstemplate,ifthespecializationisimplicitlyinstantiatedbecauseitisreferencedfromwithinanothertemplatespecializationandthecontextfromwhichi

c++ - "How to impress interviewers with my coding? What practices can I adopt in the code I' 已经为给面试官留下深刻印象的问题而写了吗?

假设有一个整数vector。现在我们想要合并,我们选择2个相邻元素v[I]和v[I+1](对于每个有效的I)并执行v[I]=v[I+1]+v[I]。并删除v[I+1]。继续这样做,直到vector中只剩下一个元素。(注意I=0&I=v.size()-1也被认为是相邻的)。所以我们需要尝试所有这些可能的组合(即我们首先采用哪一对并合并问题,如果需要进一步说明,请在评论中告诉我)每次我们合并时,我们都会做成本+=v[I]+v[I+1]。目标是最小化成本。举个例子说vector是123。合并[123]->[3,3]&cost=3->[6]&cost=9另一种方式[123]->[1,5]&co

c++ - 为什么 Foo::inner Constexpr 不会链接,而 User Literal{Foo::inner Constexpr} 会链接?

考虑以下简单类,这些类是我根据在实际项目中遇到的问题设计的。Triple是一种与内部一起使用的快速样板类型constexprFoo类中的s:#includeclassTriple{public:friendstd::ostream&operator如果我再写一个main()使用公共(public)内部函数constexpr来自Foo,如下,会链接失败(使用g++4.7.0,在Windows7上通过mingw-x86-64):intmain(intargc,char**argv){usingstd::cout;usingstd::endl;cout$g++-otest-O3--std=c

c++ - 标准库predefined 'user-defined' literal "m"是在哪里定义的?

我在浏览C++CoreGuidlines时偶然发现了以下示例文档:Examplechange_speed(doubles);//bad:whatdoesssignify?//...change_speed(2.3);Abetterapproachistobeexplicitaboutthemeaningofthedouble(newspeedordeltaonoldspeed?)andtheunitused:change_speed(Speeds);//better:themeaningofsisspecified//...change_speed(2.3);//error:nouni

c++ - std::current_exception 是否应该从类的析构函数中的 catch block 返回非空

我和我的同事认为我们在VisualC++2012和2013中发现了一个错误,但我们不确定。以下代码中对std::current_exception的调用是否应该返回一个非空的exception_ptr?似乎在我们尝试过的大多数其他编译器上:#include#include#includeclassA{public:~A(){try{throwstd::runtime_error("ohno");}catch(std::exception&){std::clog在VisualC++下运行时,我们得到“0”(假,这意味着返回的exception_ptr为空)。其他编译器,例如g++,打印“

c++ - boost 测试 : catch user defined exceptions

如果我的代码中有用户定义的异常,我将无法进行Boost测试将它们视为失败。例如,BOOST_AUTO_TEST_CASE_EXPECTED_FAILURES(MyTest,1)BOOST_AUTO_TEST_CASE(MyTest){//codewhichthrowsuserdefinedexception,notderivedfromstd::exception.}我收到一条通用消息:Caughtexception:....unknownlocation(0):....它不会将此错误识别为失败,因为它不是std::exception。所以它不遵守expected_failures条款