首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

2022-10-16-整洁代码对象错误处理

继续读《代码整洁之道》。...,模块不应了解它所操作对象的内部情形……方法不应调用由任何函数返回的对象的方法。”...错误处理 有时 catch 异常需要对好多异常匹配判断,但是若明白自己想要的是什么,可能根本不关注到底是哪个异常,一般直接匹配一个 Exception 了,其实不太好,通用的 Exception 无法定位是这里抛出的...还有一个好处,如果是第三方的 API 定义的异常类型,不需要在外部调用时出现这 API 里特有的异常,而是出现自己的异常。 方法不要返回 null 值,这是个好建议。...别将 null 值作为参数传递,和上面一条一样,都是减少检查 null 的代码逻辑,减少漏减少发生异常的概率。

30720

关于是否需要使用获取错误代码接口的思考

常用的编程方式对于错误码的最多方式是通过返回值。通过一系列的示例来引发示例3的返回值接口思考。 常用获取错误代码方式 1. 通过返回 ErrorCode获得错误码。...通过返回一个 string获得错误码字符串。 string exec(); 3. 还有一些方式是通过额外的 getErrorCode和 errorCode这类的名字接口获取错误代码。...使用参数引用/指针获取 void exec(ErrorCode &errorCode); 什么情况下使用额外的接口获取错误代码方式比较好?...一般使用在上面的第三种方式中; 当需要的返回值具有其他功能; 当 list为空时并不能确定是内部返回的结果为空还是由于错误而返回的空值问题; 有人会问,我可以在参数传入来获取。...比如: list exec(ErrorCode &errorCode); 的确这样可以解决问题,但是有些时候我们并不需要知道具体的错误,也就不必传入额外的 errorCode的引用。

92110

OPC服务器比较

1.iFlX 支持双向OPC支持所有类型的ActiveX、OLE,对不健全的控件所引发的错误进行保护,对控件的属性操作完全控制。...内嵌VBA,具有自己的内部函数,又有广泛的VB函数,功能扩展更为有利。...编辑与运行是切换进行的,这有利于对现场生产安全的保障;有独立的报警监视程序,支持在线修改,具有画面分层功能,运行时可以根据程序很方便地更换对象的连接数据源,可以使控制更灵活。...2.Cimplicity 支持OPC服务器,编辑与运行分开,有独立的报警、历史趋势运行管理程序,内嵌VBA,具有自己的内部函数,又有广泛的VB函数,组VBA与通用运行方式不一样,支持ActiveX...OPC服务器端软件iFIX支持三种关系型数据库:MSAccess、MS SQLServer 2000和Oracle数据库。

2.3K10

Excel编程周末速成班第26课:处理运行时错误

学习Excel技术,关注微信公众号: excelperfect 主要内容: 理解运行时错误及其原因 如何在过程中启用错误捕获 使用Err对象 编写错误处理代码 延迟错误处理 使用错误作为编程工具 运行时错误是在程序运行时发生的错误...在程序运行时发生的程序错误称为运行时错误,重要的是要理解运行时错误(或只是错误)与在VBA程序中可能发生的其他两类问题之间的区别: bug是程序逻辑中的缺陷,会导致程序产生不正确的结果。...错误的常见原因是用户输入不正确的数据,例如在需要数字时输入字符串。通过验证输入数据,你可以避免这种错误。 捕获错误 VBA中的错误是通过捕获它们来处理的。...End Sub 关于此示例,有两点需要注意: 错误处理代码的label不必一定是ErrorHandler,它可以是任何合法的VBA标签名称。...ExitSub语句用于防止执行陷入错误处理代码中,这样可以确保仅在发生错误时才执行错误处理代码。 在详细介绍编写错误处理代码之前,你需要了解Err对象,这将在下一部分中介绍。

6.7K30

Excel VBA解读(163):错误处理技术之概述

On Error Resume Next 忽略错误代码继续运行。 On Error Goto [标签] 当发生错误时,跳转到指定的标签处执行。 Err对象 当发生错误时,存储错误信息的对象。...Err.Number 错误编号。可以在需要检查发生指定错误时使用。 Err.Description 描述错误的文本。 Err.Source 在使用Err.Raise时填充。...VBA错误类型 在VBA中,有3类错误: 1.语法错误 2.编译错误 3.运行时错误 使用错误处理来处理运行时错误。...图2 在编写代码时,我们可以经常运行菜单栏中的“调试—编译”命令,及早发现编译错误。如果菜单“调试”下的“编译”命令为灰色,表明代码不存在编译错误运行时错误 程序运行时会发生运行时错误。...这里需要说明的是,有一类错误代码能够正常运行,但结果不符合要求,这是由于编写代码时误输入造成的,例如本来应该是: result= a + b 结果代码输入成了: result= a * b 此外,在使用错误处理过程之前

3.7K10

VBA代码调试

出错是很正常的,我们需要掌握找到出错的原因,去解决错误VBA编辑器里提供了一些方便的方法让我们去发现错误。 程序出错一般会有两种错误,编译错误运行时错误。...VBA虽然不是编译型的语言,但在VBA编辑器的菜单调试下面,有一个编译子菜单,写完了一段代码,可以先点击这个菜单去尝试编译,如果没有任何提示,说明代码没有编译错误。否则会出现编译错误: ?...2、运行时错误 这种错误是在程序运行过程中才会出现的错误,比如数组的下标越界,拼写错了对象的属性或者方法等: ?...3、逻辑错误 编译错误运行时错误,一般随着写代码熟练度的增加,错误的情况也会越来越少,而真正难的另外一种错误是: 对程序运行来说并不能说是错误,但是与设计程序的预期结果不一致,这种错误一般是写代码时的一些逻辑上的出错...这个时候,就需要一步一步的跟踪代码的执行,通过分析每一步的变量变化情况来判断。

1.4K10

错误捕获

VBA中,运行时错误发生的时候,会直接中断程序的运行,如果仅仅是程序的使用者,可能完全不会代码,那么出现这种中断程序的运行的状况,使用者就会不知所措了。...如果能够在代码里捕获错误,并给出提示信息,那么使用者即使不懂代码,也能根据提示信息解决一些问题。...比如用VBA代码激活一个工作表,但这个工作表不存在的情况下: Worksheets("ErrTest").Activate ? 程序被中断了,不懂VBA的人碰上这个肯定就不知道如何去处理了。...,ErrObject对象的Number等于0 If VBA.Information.Err().Number 0 Then HasSht2 = False Else...,给使用者出现运行时错误是不应该的,所以写程序的过程中,一定要非常严谨,尽量在所有的程序中都加上错误捕获的代码

2.7K10

Excel编程周末速成班第24课:调试和发布应用程序

Bug是导致程序无法正常运行的代码错误。可以将bug视为类似于错误(error),尽管这两个术语在编程界具有不同的含义。 错误(有时称为运行时错误)是阻止程序运行的问题。...如果处理不当,将有可能导致程序在其运行时中止。你可以在第26课中了解有关处理运行时错误的信息。 相反,bug不会阻止程序运行。而是,它导致程序产生不正确的结果。...监视表达式可以是任何VBA表达式,例如程序变量、对象属性或函数调用。通过设置监视,你可以关注变量或属性的值以查看其是否以及何时更改。 可以使用多种方法来使用监视表达式: 可以监视其值。...要点回顾 本课程向你展示了如何使用VBA的调试工具,并探讨了发布Excel应用程序时涉及的因素。 程序bug是使程序无法正确运行的代码错误。...当程序在中断模式下暂停时,可以单步执行代码以查找错误VBA的监视可让你在程序执行期间跟踪程序变量的值。 自我测评 1.运行时错误与程序错误有何不同? 2.如何在代码中设置断点?

5.7K10

VBA编程With语句

1).range("b2").font会显著增加代码输入量,不仅容易引发重复输入导致的错误对象的频繁出现会降低代码的执行效率。...VBA 代码运行时间 上面提到with语句可以提高vba代码的执行效率,代码的执行效率是后期编写程序时需要注意的问题。...当程序需要对大量数据和对象进行操作时,excel程序通常运行变慢,甚者如同程序崩溃一样,这就涉及优化代码,后期介绍时会作说明总结。 下面简单说下在程序通过代码中,如何记录程序运行的时间。...以一段繁琐的代码为例,新建10张工作表,并修改工作表中单元格字体,看代码运行时间。...原理很简单,即首先把当前时间赋值给变量,作为初始时间,在程序运行代码的最后,用当前时间减去初始时间得到的时间差,即是vba程序运行时间,代码如下: Sub test() Dim star As Double

2.7K20

答案:Excel VBA编程问答33题,继续……

16.是非题:保护工作簿的密码可防止用户查看你的VBA代码错误。必须使用“项目工程属性”对话框中的“保护”选项卡,将VBA工程与设置给工作簿的任何密码分开锁定。...22.是非题:监视窗口中的值在程序运行时会不断更新。 错误。监视值仅在程序进入中断模式时才更新。 23.VBA如何将bugs报告给程序员? 不会。除了测试程序外,没有其他方法可以找到bugs。...25.自定义VBA类的代码放在哪里? 在一个类模块中。 26.是非题:自定义VBA类可以包含可视化界面。 错。自定义VBA类不能包含视觉化元素。 27.如何创建只读属性?...通过在Property Let过程中放置代码来检查新的属性值,并仅在正确的情况下接受它。 30.如何在代码中引用对象属性? 通过使用标准的ObjectName.PropertyName语法。...31.类方法与常规VBA过程有何不同? 除了在类模块中之外,没有什么不同。 32.什么是辅助方法? 仅应从类内部而不是类外部的代码调用的方法。 33.在销毁对象之前触发了什么事件?

4.2K20

错误记录】Kotlin 代码运行时报错 ( 在 init 初始化块中调用还未初始化的成员属性 )

文章目录 一、报错信息 二、问题分析 三、解决方案 该问题的本质就是 , 成员属性 在 init 初始化代码块中进行初始化 , 但是在初始化之前调用了该 成员属性 , 编译时没有报错信息 , 但是运行时会报异常...; 一、报错信息 ---- 执行如下代码 : class Hello { var name: String fun nameFirstLetter() = name[0] init..., 没有报错 ; 二、问题分析 ---- 从 初始化 角度分析 上述代码的执行顺序 , Kotlin 类 对象在实例化 时会执行一系列的 初始化操作 , 这些操作按照如下顺序执行 : 主构造函数 中属性赋值...类中的属性赋值 init 初始化块 中的代码执行 次构造函数 中的代码执行 首先 , 上述代码中没有主构造 函数 , 因此该项忽略 ; 然后 , 执行属性的赋值 , 代码中定义了 name 属性 ,..., 但是在初始化之前调用了该 成员属性 , 编译时没有报错信息 , 但是运行时会报异常 ; 三、解决方案 ---- 调换 初始化代码块 中的代码顺序 , 先给 name 成员赋值 , 然后再执行 调用

1.7K10

错误记录】Groovy 闭包使用报错 ( 闭包中不能直接使用外部对象的方法 | 需要先设置 delegate 代理 )

文章目录 一、报错信息 二、解决方案 一、报错信息 ---- 在 Groovy 中的 Closure 闭包中 , 直接调用外部对象的方法 , 会报错 ; class Test { def fun...Groovy.run(Groovy.groovy:14) Process finished with exit code 1 二、解决方案 ---- 在 Closure 闭包中 , 如果要调用外部对象的方法..., 需要先设置 Closure 闭包对象的 delegate 成员为指定的外部对象 ; class Test { def fun() { println "fun" }...} // 闭包中不能直接调用 Test 对象中的方法 // 此时可以通过改变闭包代理进行调用 def closure = { fun() } closure.delegate = new...Test() closure() 设置完 Closure 闭包对象的 delegate 之后 , 的执行效果 :

86220

Excel VBA解读(164):错误处理技术之On Error语句

学习Excel技术,关注微信公众号: Excelperfect 好的应用程序应该能够捕获错误并进行相应的处理,而不是VBA弹出的错误消息。正如上文提到的,有两种方法处理运行时错误。...对于可预见的错误,编写特定的代码来处理它们。对于不可预见的意外错误,则使用VBA错误处理语句来处理。 在VBA中,On Error语句用于错误处理。当代码运行时发生错误时,该语句将执行相应操作。...发生错误时,VBA将在出现错误的行上停止运行并显示错误消息。此时,需要用户干预代码才能继续。在这种情况下不会发生错误处理。 让我们看一个例子。...图5 运行上述VBA代码代码执行到以0作为除数这一行时,发生错误代码跳至On Error GoTo 语句指定的标签errH处。 On Error GoTo -1 这个语句用于清除当前发生的错误。...使用On Error Resume Next语句的一个原则是,其所影响的代码应该尽可能的少,当不再需要该语句时应及时关闭它。

7.7K20
领券