草庐IT

try-convert

全部标签

c++ - 使用 try-Catch 异常处理程序和 if else 条件检查之间的区别?

这个问题在这里已经有了答案:IsthereageneralconsensusintheC++communityonwhenexceptionsshouldbeused?[closed](11个答案)关闭9年前。我在很多地方都使用过if...else语句,但是我对异常处理还是陌生的。这两者的主要区别是什么?例如:int*ptr=new(nothrow)int[1000];if(ptr==NULL){//Handleerrorcaseshere...}或try{int*myarray=newint[1000];}catch(exception&e){cout所以我们在这里使用标准异常类,它

c++ - libc++ 与 VC++ : Can non-UTF conversions be done with wstring_convert?

C++11的std::wstring_convert效果很好*用于标准UTF-8UTF-16/UCS2/UCS4转换。但是,当我尝试使用不是来自的构面实例化wstring_convert或wbuffer_convert时,它没有按预期工作://worksasexpectedstd::wstring_convert>ucs4conv;//Now,byanalogy,Iwanttotrythis:std::wstring_convert>gbconv(newstd::codecvt_byname("zh_CN.gb18030"));Clang++错误提示“在~wstring_convert

c++ - 为什么 try...catch 需要抛出 EXACT 类型

我可以做到,没问题:longlngval=3L;inti=lngval;但如果我尝试这样做:try{throw3L;}catch(inti){cout我得到一个未处理的异常。这似乎不一致。这种情况下没有类型转换的原因是什么? 最佳答案 在第一种情况下,编译器可以准确地告诉您要做什么:将long转换为int。在第二种情况下,编译器必须假设您可能有这样的构造:try{try{throw3L;}catch(inti){/*P*/}}catch(longl){/*Q*/}这个想法是编译器永远不知道是否有一个catch(longl)潜伏在当前

c++ - try block 限制 const 变量的范围

当包装一个常量的初始化时,我经常遇到范围问题try{constintvalue=might_throw();}std::cout目前我使用临时值作为解决方法。有没有更好的方法来处理const-try{}情况?inttmp;/*I'dratherhavetmpconst*/try{tmp=might_throw();}catch(...){/*dosomething*/}constintvalue=tmp; 最佳答案 代替你的inttmp;/*I'dratherhavetmpconst*/try{tmp=might_throw();}

android - 如何解决 : "error: cannot find symbol class ..." after converting Java class to Kotlin?

我正在尝试从Kotlin开始,将我项目的一些Java类转换为Kotlin,并创建一个混合的Java/Kotlin项目。为了配置环境,我做了以下操作:已下载最新版Kotlin插件(1.0.2);在顶层gradle.plugin我添加了:classpath"org.jetbrains.kotlin:kotlin-android-extensions:1.0.2"在依赖项部分;在我的模块的gradle插件中,我在依赖项部分添加了:compile"org.jetbrains.kotlin:kotlin-stdlib:1.0.2";我选择了我想转换为kotlin的POJO类,从菜单Code->C

android - 如何解决 : "error: cannot find symbol class ..." after converting Java class to Kotlin?

我正在尝试从Kotlin开始,将我项目的一些Java类转换为Kotlin,并创建一个混合的Java/Kotlin项目。为了配置环境,我做了以下操作:已下载最新版Kotlin插件(1.0.2);在顶层gradle.plugin我添加了:classpath"org.jetbrains.kotlin:kotlin-android-extensions:1.0.2"在依赖项部分;在我的模块的gradle插件中,我在依赖项部分添加了:compile"org.jetbrains.kotlin:kotlin-stdlib:1.0.2";我选择了我想转换为kotlin的POJO类,从菜单Code->C

c++ - std::is_convertible 的可变参数版本?

是否可以编写std::is_convertible的可变版本?例如are_convertible会返回is_convertible&&is_convertible.我已经考虑了几个小时,但想不出任何合理的想法。澄清一下,我想像这样使用它:templatestructthing{templateenable_if_t::value>foo(Args2&&...args){}} 最佳答案 您不需要连接Args2...和Args1...,你不应该这样做,因为这样做会让人无法分辨Args2...在哪里。结束和Args1...开始。以允许单独

c++ - 函数 try block ,但不在构造函数中

只是一个简单的问题。有什么区别吗voidf(Foox)try{...}catch(exception&e){...}和voidf(Foox){try{...}catch(exception&e){...}}?如果不是,为什么函数tryblock用于(搁置构造函数的初始化列表的情况)?如果Foo的复制构造函数在x传递给f时抛出异常,会发生什么情况? 最佳答案 只有在构造函数中才需要函数tryblock。在所有其他情况下,通过将函数的整个主体包含在普通的try/catchblock中,可以实现完全相同的效果。如果用于初始化参数的复制构造

c++ - 在 try catch block 中断言

我目前正在对一段代码添加处理以使其不会崩溃。目前它有每个步骤,然后是一个ASSERT语句,以确保上一步没有出错。如果这些步骤中的某个步骤出了问题,那确实是出了大问题。该程序应该停止。虽然在Release模式下程序遇到断言,但愉快地继续运行并崩溃。为了解决这个问题,我将方法包装在一个try/catchblock中,并在断言所在的位置抛出错误。这应该捕获我们跟踪的所有错误和我们没有跟踪的其他错误。现在我的问题是,我是否仍应使用断言来通知程序员这不应该发生?或者现在将它们取出,因为它不会因为catchblock(我清理对象的地方)而崩溃?或者我应该只在catchblock中抛出一个断言,而不

c++ - 错误 : cannot convert 'const wchar_t [13]' to 'LPCSTR {aka const char*}' in assignment

//includethebasicwindowsheaderfile#include#include//theWindowProcfunctionprototypeLRESULTCALLBACKWindowProc(HWNDhWnd,UINTmessage,WPARAMwParam,LPARAMlParam);//theentrypointforanyWindowsprogramintWINAPIWinMain(HINSTANCEhInstance,HINSTANCEhPrevInstance,LPSTRlpCmdLine,intnCmdShow){//thehandleforthew