try-catch-finally对返回值的影响

catch 和 finally 一起使用的常见方式是:在 try 块中获取并使用资源,在 catch 块中处理异常情况,并在 finally 块中释放资源。

finally 块用于清理try块分配的任何资源,无论try中是否异常或者终止(return),finally块都会执行。

如果在finally块中修改了返回值,会对最终返回的结果有何影响呢?

1,如果返回值是值类型

//finally执行,i值是2013,但是最终返回2015
static int test()
        {
            int i = 2016;
            try
            {
               i=2015;
               return i;
            }
            catch
            {
               //有异常才会到这里
               i=2014;               return i;
            }
            finally
            {
                i=2013;
            }

        }

2,返回string类型,是否会影响呢,答案是不会影响。

//finally块执行,s值是“tiger”,但是最终返回dog
static string test()
        {
            string s = "cat";
            try
            {
               s="dog";
               return s;
            }
            catch
            {

//有异常才会到这里
            s="duck";
             return s;

            }
            finally
            {
                s="tiger";
            }

        }

3,返回数组又会如何呢?

//finally块执行,影响了最终返回结果,返回{ "e", "b", "c" };
static string[] test()
        {
            string[] arr = { "a", "b", "c" };
            try
            {
               arr[0]="d";
               return arr;
            }
            catch
            {
               //有异常才会到这里
               arr[0]="f";               return arr;
            }
            finally
            {
                arr[0]="e";;
            }

        }

4,对象跟数组一样,finally修改对象后,最终返回的是finally修改后的对象。

注意:

1,finally块中不能有 return语句,当然vs会报错。

2,如果finally块之后还有return语句,该如何返回呢?即 try{ }catch(){} finally{} return x;

finally块肯定执行,这里主要看try和catch是否执行了return语句,如果执行了,finally块后面的语句就不执行了。

当然,如果try和catch块都含有return语句,那么肯定会执行其中一个,finally块后面的的语句就不会执行了,这是vs会提示“检测到无法访问的代码”,

示例

//返回“dog”,加入有异常会返回“duck”,
static string test()
        {
            string s = "cat";
            try
            {
               s="dog";
               return s;
            }
            catch
            {
           //有异常才会到这里
            s="duck";

            }
            finally
            {
                s="tiger";
            }

            return s;//假如try正确返回了,就不会执行。
        }
时间: 2024-08-12 02:45:59

try-catch-finally对返回值的影响的相关文章

字节码分析finally块对return返回值的影响

直接进入主题.看如下代码: public int test(){ int i=0; try { i=1; return i; } catch (Exception e) { i=2; return i; }finally{ i=3; } } 相信有点经验的程序员一眼就能说出返回的结果为1,但是您真的知道返回的结果为什么为1吗?下面我们通过分析下当前方法的字节码,来说明为什么. 查看字节码命令:javap -verbose class文件 ? 知识点简单概要:看如下字节码需要简单了解下栈的结构.栈

关于finally对返回值的影响

1.finally对返回值的影响 我们知道finally在try中return语句执行之后 返回之前 执行的. 如果try中最后return一个变量 ,那finally也对这个变量修改后 到底会返回什么? 直接上测试代码看例子: class YfModel{ private String name; public YfModel(String name) { this.name = name; } public String getName() { return name; } public v

ExecuteNonQuery()返回值

查询某个表中是否有数据的时候,我用了ExecuteNonQuery(),并通过判断值是否大于0来判断数据的存在与否.结果与我所设想的很不一致,调试时才发现,其执行后返回的结果是-1,对此我很是不理解,回头查了下资料,如下显示:SqlCommand.ExecuteNonQuery 方法对连接执行 Transact-SQL 语句并返回受影响的行数.备注:可以使用 ExecuteNonQuery 来执行目录操作(例如查询数据库的结构或创建诸如表等的数据库对象),或通过执行 UPDATE.INSERT

【转】ThinkPHP中数据库操作返回值总结

Thinkphp中的Think\Model类提供了数据库的基本CURD(Create.Update.Read及Delete),通过该类可以很便捷的进行操作.Model类及扩展类主要的方法有: Create操作:create()(非链式) .add().addAll()支持的链式操作有:table .data.field .relation .validate.auto .filter.scope .bind .token .comment Update操作save().setField().se

ExecuteNonQuery()返回值注意点

查询某个表中是否有数据的时候,我用了ExecuteNonQuery(),并通过判断值是否大于0来判断数据的存在与否.结果与我所设想的很不一致,调试时才发现,其执行后返回的结果是-1,对此我很是不理解,回头查了下资料,如下显示: SqlCommand.ExecuteNonQuery 方法对连接执行 Transact-SQL 语句并返回受影响的行数. 备注:可以使用 ExecuteNonQuery 来执行目录操作(例如查询数据库的结构或创建诸如表等的数据库对象),或通过执行 UPDATE.INSER

ThinkPHP中数据库操作返回值总结

转自:http://www.baiwar.com/post/thinkphp-database-operations-in-the-return-value.html Thinkphp中的Think\Model类提供了数据库的基本CURD(Create.Update.Read及Delete),通过该类可以很便捷的进行操作.Model类及扩展类主要的方法有: Create操作:create()(非链式) .add().addAll()支持的链式操作有:table .data.field .rela

mybatis 中的 update 返回值

摘自:https://www.jianshu.com/p/80270b93082a 如果定义一个如下的update函数,那么这个函数的返回值到底是啥意思呢?是受影响的行数吗? 验证之前我们先看看数据库中的数据记录.总共两条数据记录! 数据库链接配置为: jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/ssm jdbc.username=root jdbc.password=123456 下面看看我们的单

js onclick="return test()"事件返回值,对有些事件,会影响默认动作的执行。如:onclick和onsubmit

onclick="return test()"事件返回值,对有些事件,会影响默认动作的执行.如:onclick和onsubmit <body> <!--事件返回值,对有些事件,会影响默认动作的执行.如:onclick和onsubmit--> <!--多用于表单提交--> <a href="http://www.baidu.com" onclick="return test()">baidu</

EF5中 执行 sql语句使用Database.ExecuteSqlCommand 返回影响的行数 ; EF5执行sql查询语句 Database.SqlQuery 带返回值

一: 执行sql语句,返回受影响的行数 在mysql里面,如果没有影响,那么返回行数为  -1 ,sqlserver 里面  还没有测试过 using (var ctx = new MyDbContext()) { ctx.Database.ExecuteSqlCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1"); } 二 : Database.SqlQuery<T>   EF5执行sql查询语句