java 选择表达式_Java8可选函数链表达式

您可以使用lambda而不是匿名类 – 并使用map获取所需的结果orElse作为默认值:

Function,ObjectA> sqlRowToObjectA =

entry -> entry.map(e -> new ObjectA(e.getInt("id"),e.getString("name")))

.orElse(ObjectA.EMPTY);

但是,在您的示例中,您根本不需要函数,并且可以重写整个方法,如下所示:

public static ObjectA test1() {

sqlRow row = Ebean.createsqlQuery("select * from table1").findUnique();

return Optional.ofNullable(row)

.map(e -> new ObjectA(e.getInt("id"),e.getString("name")))

.orElse(ObjectA.EMPTY);

}

请注意,因为findUnique可能返回null,所以应该使用Optional.ofNullable()而不是Optional.of():如果行为null,后者将抛出异常.

最后,我想补充一点,写它会更简单,更有效:

public static ObjectA test1() {

sqlRow row = Ebean.createsqlQuery("select * from table1").findUnique();

return row == null ? ObjectA.EMPTY

: new ObjectA(row.getInt("id"),row.getString("name"));

}

或者更改方法签名,让调用者决定在没有结果时该怎么做:

public static Optional test1() {

sqlRow row = Ebean.createsqlQuery("select * from table1").findUnique();

return Optional.ofNullable(row)

.map(e -> new ObjectA(e.getInt("id"),e.getString("name")));

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值