我正在研究一些在其业务和数据层中使用模式的代码,这些代码使用事件来发出错误信号,例如
resource = AllocateLotsOfMemory(); if (SomeCondition()) { OnOddError(new OddErrorEventArgs(resource.StatusProperty)); resource.FreeLotsOfMemory(); return; }
这看起来很奇怪,特别是当调用它的代码需要挂钩事件时(有四个或五个不同的!).
开发人员告诉我,这样他们就可以在错误处理代码中引用已分配资源的属性,并且在此层保留错误之后清理的责任.
这有点儿意义.
替代方案可能是这样的
resource = AllocateLotsOfMemory(); if (SomeCondition()) { BigObject temporary = resource.StatusProperty; resource.FreeLotsOfMemory(); throw new OddException(temporary); }
我的问题是:
当BigObject
释放异常对象时释放此" ",我们是否需要这种模式?
有没有其他人体验过这种模式?如果是这样,你发现了什么陷阱?有什么优势?
谢谢!
这对我来说似乎很奇怪.有一些优点 - 例如允许多个"处理程序",但语义与正常的错误处理明显不同.特别是,它不会自动传播到栈中这一事实让我感到担忧 - 除非错误处理程序本身抛出异常,否则逻辑将继续进行,就好像它应该可以中止当前操作一样.
另一种思考方式:假设该方法是为了返回一个值,但是你早就发现了一个错误.你有什么价值?例外沟通的事实,那就是没有合适的值返回...