草庐IT

try-except-block

全部标签

c++ - 如何查看Code::Blocks中的反汇编?

我读了thisarticle关于C/C++的一些底层基础,作者基本上是通过编译器生成的汇编代码逐行向我们展示。他用的是VS2010,我不用,我用的是Code::Blocks。我如何查看那里的反汇编?当我转到调试器并单击反汇编时,它会显示一个空白窗口...这是我编译的C++(.cpp)代码(完整代码):intmain(){intx=1;inty=2;intz=0;z=x+y;return0;} 最佳答案 作者在文章中展示的反汇编称为inter-leaveddisassembly(C和反汇编交错),VisualStudio等一些IDE支

c++ - 如何使用 Code::Blocks 创建 GUI 程序

以前,我使用VisualStudio进行C++编程。但是一些成本影响我不得不改变我的IDE,所以我选择了Code::Clocks(12.11)。但是我找不到用C::B开发GUI应用程序的方法。有什么方法可以用C::B开发GUI吗? 最佳答案 是的,如果你有GTK,你可以用CodeBlocks开发GUI+或wxWidget图书馆。您可以根据自己的选择使用其中之一。在您下载并安装它们之前,CodeBlocks无法使用它们,因此您必须执行一些操作才能使它们在CodeBlocks中可用。有关GTK+配置步骤,请参阅this对于wxWidge

c++ - future 、 promise 和异常(exception)

std::promisep1;autof=p1.get_future();{std::promisep2(std::move(pr));}boolvalid=f.valid();//truef.wait();//doesnotthrow,orfail,butreturnsimmediatelyf.get();//throwsanexception有什么方法可以在调用get之前检查future是否会抛出异常?我希望valid会检查...我不太确定如何让valid返回false。在不设置值的情况下销毁promise不会这样做。 最佳答案

c++ - 为什么 std::timed_mutex::try_lock_for 不起作用?

我在Ubuntu12.04中使用gcc-4.8.1(configure:./configure--prefix=/usr/local)编译了以下代码,但是当我运行它时,它没有工作。它没有停下来等待互斥量。它返回false,并输出“Helloworld!”命令:g++-std=c++11main.cpp-omain-pthread当我用gcc-4.6(apt-getinstallg++)编译时,效果很好。程序等了大概十秒,输出了“Helloworld!”#include#include#include#includestd::timed_mutextest_mutex;voidf(){t

C++ 代码:: block 自动完成不工作

我最近才开始使用Code::Blocks学习C++。当我第一次开始使用它时,自动完成功能运行良好,但现在由于某种原因它不起作用了。我所说的自动完成是这样的:#includeusingnamespacestd;intmain(){inttest;}如果我输入“te”(不带引号),我不会得到一个包含我的变量名称的框。任何帮助将不胜感激。 最佳答案 禁用SmartSense(设置/编辑器/代码完成)可以解决问题。在启用SmartSense(默认)的情况下,代码完成部分工作。 关于C++代码::

c++ - LLVM 是避免动态转换规则的异常(exception)吗?

LLVM有自己的RTTI替代方案,它比内置RTTI的速度有所提高,并允许动态转换为没有vtable的类(dyn_cast)。但是,它仍然可以完全按照dynamic_cast的方式使用。尽管它确实允许它与更多类一起使用,但已被使用。dyn_casttemplatedocumentationLLVM是一个享有盛誉的C++项目,所以这似乎与俗语背道而驰,即过多的动态转换是糟糕设计的标志,也称为代码异味。当然,与标准dynamic_cast相比,性能更好的动态转换并不能改善其在设计中的使用。.那么谁在这里?在C++代码中是否存在大规模使用动态转换是一个好的设计选择的情况?Google在LLVM

c++ - 如何在 Code::Blocks 中使用 wmain() 入口点?

我全新安装了Code::Blocks(我安装了theoneforWindows7whichcomeswithGCCcompiler(codeblocks-10.05mingw-setup.exe))。然后我尝试编译这个非常简单的代码:intwmain(intargc,wchar_t*argv[]){return0;}我收到此错误消息:c:\development\ide\codeblocks\mingw\bin..\lib\gcc\mingw32\4.4.1......\libmingw32.a(main.o):main.c||undefinedreferenceto`WinMain@

c++ - 由于缺乏反射,在 C++ 中不可避免地会有一个大的 switch block 吗?

这个问题在这里已经有了答案:Isthereawaytoinstantiateobjectsfromastringholdingtheirclassname?(12个答案)关闭9年前。假设我有一个类层次结构:classShape{};classCircle:publicShape{}classSquare:publicShape{}...hundredsofothershapescontinueon...当给定形状类的名称作为字符串时,我需要实例化该类的对象。在java中,我可以做这样的事情(伪代码!)ShapecreateShape(Stringname){returnnewClass

c++ - 从库中的 std::exception 派生:Does a headers-only solution work for catching exceptions?

在我们的跨平台开源库中,我们派生自std::exception以定义可以在库代码和用户代码中捕获的自定义异常。我看到这实际上是一个推荐的过程,但在VisualStudio2015(或者更确切地说,伴随的新MSVC版本?)中,在实现类(warningC4275)中抛出警告-另请参见此处:Howtodllexportaclassderivedfromstd::runtime_error?当然我们可以忽略这个错误,但这对我来说似乎是错误的。与旧的VisualStudio版本相比,出现警告的原因似乎是std::exception曾经在旧的MSVC版本中导出,但同时不再导出。无论哪种情况,我都觉

C++ catch(std::exception & e) 与 catch(...)

我知道处理这两个捕获的不同之处,但是椭圆捕获std::exceptioncatch无法捕获的东西需要什么?例如:try{throwstd::runtime("runtimeerror!");}catch(conststd::exception&e){std::cout我看过结合使用这两种方法的代码示例,但我没有看到您同时使用这两种方法的原因。 最佳答案 catch(conststd::exception&e)只会捕获标准异常。catch(...)之后会捕获那里的所有内容。您可以处理整数和其他类型(http://www.cpluspl