《on java》lambda 表达式

一.定义


lambda 表达式和累的定义和匿名内部类实现了同样的效果,但是代码量小很多。

lambda 产生的是函数,而不是可,在编程时理解为函数。


二.使用

lambda 表达式 : 参数->表达式
1.只有哟各参数,可以只写这个参数,不写括号                   static Body bod = h->h+"no parens ";

2.第一种是特殊情况,通常是用括号奖参数包裹起来                static Body bod2 = (h)->h+"More details ";

3.在没有参数的情况下,必须用括号来知识空的参数列表。           static Body dsc = ()->"More details ";

4.有多个参数的情况下,将他们放在使用括号包裹起来的参数列表内。   static Body dsc = (h,n)-> h+n;

5.如果lambda表达式需要多行代码,则必须将这些代码放到花括号中。这种情况下需要使用return从lambda表达式中生成一个值。 


总结 : 所有的功能抽象成函数,函数可以用lambda表示


三.递归 计算阶乘

interface IntCall {
      int call(int arg)
}


public class RecusiveFactorial {
    static IntCall fact; 
    public static void main(String[] arg){
        fact = n -> n==0?1 : n*fact.call(n-1);
        for(int i=0;i<=10;i++)
        System.out.println(fact.call(i))
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,lambda 表达式通常用于函数式编程中的函数式接口,而与数据库相关的操作通常使用 SQL 语句进行处理。如果你想在 Java 中实现类似于 SQL 中的 left join 操作,可以使用一些 ORM 框架(例如 Hibernate、MyBatis 等)来简化这个过程。 下面是一个使用 MyBatis 实现 left join 的示例: 首先,在 MyBatis 的 mapper 文件中定义两个表的查询语句: ``` <select id="selectUsersWithOrders" resultMap="userResultMap"> SELECT u.*, o.order_id, o.order_date FROM user u LEFT JOIN orders o ON u.user_id = o.user_id </select> <resultMap id="userResultMap" type="User"> <id property="userId" column="user_id"/> <result property="username" column="username"/> <collection property="orders" ofType="Order"> <id property="orderId" column="order_id"/> <result property="orderDate" column="order_date"/> </collection> </resultMap> ``` 其中,第一段 SQL 查询语句实现了 left join,将用户表和订单表连接起来,查询出所有用户及其对应的订单信息。第二段 resultMap 定义了 User 实体类和 Order 实体类之间的映射关系。 然后,在 Java 代码中调用 MyBatis 的查询方法,即可获得 left join 后的结果: ``` List<User> users = sqlSession.selectList("selectUsersWithOrders"); ``` 这个查询操作将会返回一个包含所有用户及其对应订单信息的列表。其中,每个用户都有一个 List<Order> 类型的 orders 属性,包含了该用户的所有订单信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值