<legend id='h2X83'><style id='h2X83'><dir id='h2X83'><q id='h2X83'></q></dir></style></legend>
<tfoot id='h2X83'></tfoot>

      <small id='h2X83'></small><noframes id='h2X83'>

      1. <i id='h2X83'><tr id='h2X83'><dt id='h2X83'><q id='h2X83'><span id='h2X83'><b id='h2X83'><form id='h2X83'><ins id='h2X83'></ins><ul id='h2X83'></ul><sub id='h2X83'></sub></form><legend id='h2X83'></legend><bdo id='h2X83'><pre id='h2X83'><center id='h2X83'></center></pre></bdo></b><th id='h2X83'></th></span></q></dt></tr></i><div id='h2X83'><tfoot id='h2X83'></tfoot><dl id='h2X83'><fieldset id='h2X83'></fieldset></dl></div>
          <bdo id='h2X83'></bdo><ul id='h2X83'></ul>

        从构造函数捕获异常意味着我的实例之后超出范围

        Catching exceptions from a constructor means that my instance is out of scope afterward(从构造函数捕获异常意味着我的实例之后超出范围)

        <small id='zufZj'></small><noframes id='zufZj'>

          <tbody id='zufZj'></tbody>
        <tfoot id='zufZj'></tfoot>
          <legend id='zufZj'><style id='zufZj'><dir id='zufZj'><q id='zufZj'></q></dir></style></legend>

              <i id='zufZj'><tr id='zufZj'><dt id='zufZj'><q id='zufZj'><span id='zufZj'><b id='zufZj'><form id='zufZj'><ins id='zufZj'></ins><ul id='zufZj'></ul><sub id='zufZj'></sub></form><legend id='zufZj'></legend><bdo id='zufZj'><pre id='zufZj'><center id='zufZj'></center></pre></bdo></b><th id='zufZj'></th></span></q></dt></tr></i><div id='zufZj'><tfoot id='zufZj'></tfoot><dl id='zufZj'><fieldset id='zufZj'></fieldset></dl></div>
                • <bdo id='zufZj'></bdo><ul id='zufZj'></ul>
                  本文介绍了从构造函数捕获异常意味着我的实例之后超出范围的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我有一个类,它的构造函数可能会抛出异常.下面是一些可以捕获异常的代码:

                  I have a class whose constructor may throw an exception. Here’s some code that will catch the exception:

                  try {
                      MyClass instance(3, 4, 5);
                  }
                  catch (MyClassException& ex) {
                      cerr << "There was an error creating the MyClass." << endl;
                      return 1;
                  }
                  

                  但是当然在 try/catch 之后没有代码可以看到 instance 因为它现在超出了范围.解决此问题的一种方法是分别声明和定义 instance:

                  But of course no code after the try/catch can see instance because it’s now out of scope. One way to resolve this would be to declare and define instance separately:

                  MyClass instance;
                  try {
                      MyClass instance(3, 4, 5);
                  }
                  ...
                  

                  除了我的类没有合适的零参数构造函数.事实上,这里的这种情况是唯一一个这样的构造函数甚至有意义的情况:MyClass 对象旨在是不可变的,从某种意义上说,它的数据成员在构造后都不会改变.如果我要添加一个零参数构造函数,我需要引入一些实例变量,例如 is_initialized_ 然后检查每个方法以确保该变量之前是 true进行.对于这样一个简单的模式来说,这似乎太过冗长了.

                  except that my class doesn’t have the appropriate zero-argument constructor. In fact, this case right here is the only one in which such a constructor would even make sense: the MyClass object is intended to be immutable, in the sense that none of its data members change after construction. If I were to add a zero-argument constructor I’d need to introduce some instance variable like is_initialized_ and then have every method check to make sure that that variable is true before proceeding. That seems like far too much verbosity for such a simple pattern.

                  处理这种事情的惯用方式是什么?我是否需要接受它并允许在初始化之前声明我的类的实例?

                  What is the idiomatic way to deal with this kind of thing? Do I need to suck it up and allow instances of my class to be declared before they’re initialized?

                  推荐答案

                  您应该在 try 块中做您需要做的一切:

                  You should be doing everything you need to do inside the try block:

                  try {
                      MyClass instance(3, 4, 5);
                  
                      // Use instance here
                  }
                  catch (MyClassException& ex) {
                      cerr << "There was an error creating the MyClass." << endl;
                      return 1;
                  }
                  

                  毕竟只有在try块内,instance才被成功创建,可以使用.

                  After all, it is only within the try block that instance has been successfully created and so can be used.

                  我确实想知道您的 catch 块是否真的在处理异常.如果你不能做任何事情来解决这种情况,你应该让它传播.

                  I do wonder whether your catch block is really handling the exception. If you can't do anything to resolve the situation, you should be letting it propagate.

                  这篇关于从构造函数捕获异常意味着我的实例之后超出范围的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Is Type(::x); valid?(是类型(::x);有效的?)
                  Difference between an inline function and static inline function(内联函数和静态内联函数的区别)
                  Compilation fails randomly: quot;cannot open program databasequot;(编译随机失败:“无法打开程序数据库)
                  Too many initializers error for a simple array in bcc32(bcc32 中的简单数组的初始值设定项过多错误)
                  No Member named stoi in namespace std(命名空间 std 中没有名为 stoi 的成员)
                  Error using a constexpr as a template parameter within the same class(在同一个类中使用 constexpr 作为模板参数时出错)

                • <i id='bg3lS'><tr id='bg3lS'><dt id='bg3lS'><q id='bg3lS'><span id='bg3lS'><b id='bg3lS'><form id='bg3lS'><ins id='bg3lS'></ins><ul id='bg3lS'></ul><sub id='bg3lS'></sub></form><legend id='bg3lS'></legend><bdo id='bg3lS'><pre id='bg3lS'><center id='bg3lS'></center></pre></bdo></b><th id='bg3lS'></th></span></q></dt></tr></i><div id='bg3lS'><tfoot id='bg3lS'></tfoot><dl id='bg3lS'><fieldset id='bg3lS'></fieldset></dl></div>

                        <tbody id='bg3lS'></tbody>
                      • <bdo id='bg3lS'></bdo><ul id='bg3lS'></ul>
                        <tfoot id='bg3lS'></tfoot>

                      • <small id='bg3lS'></small><noframes id='bg3lS'>

                            <legend id='bg3lS'><style id='bg3lS'><dir id='bg3lS'><q id='bg3lS'></q></dir></style></legend>