美文网首页Web
java 易用框架和插件集合(持续更新)

java 易用框架和插件集合(持续更新)

作者: 飞盏 | 来源:发表于2018-07-28 23:31 被阅读367次
    java的路线比较广阔,我个人是从事java后端开发的。因此着重后端技术的演进和聚焦后端框架的发展。
    
    站在个人的角度,我认为java,或者说任何一门语言的把玩,都需要从几个大的维度去把控和衡量。
    
    题外话,如果你觉得你对文章有兴趣可以关注我哦,
    如果想要内推请带简历私我邮箱(still-fantasy-jay@qq.com)
    

    主流大框架和衍生品

    从事java后端开发的攻城狮,总是离不开几个业界主流的框架:

    java著名脚手架——spring全家桶

    主流的java脚手架,继承了AOP,IOC(控制反转),依赖注入等基础能力;
    spring像后勤部队,提供了作战所需的各种基础物资和能力;
    并且,各大主流插件都适配了spring,可以进行无缝结合,强强联合。


    spring 各大模块

    著名ORM框架———mybatis

    Mybatis可以说是非常著名的”物流公司"了(DB与业务代码的桥梁和搬运工)
    mybatis 简化了db与业务代码之间的交互逻辑,将繁琐的db交互封装成mapper接口,将db的业务表映射成bean实体,使得工程师能更加聚焦于业务实现,面向对象编程~~(没错,编程效率高的才会有对象,否则你这个时候还在加班,哪有时间去约电影泡温泉然后……)

    非主流ORM拓展包——tk.mybatis.mapper

    通用mapper包,# abel533大神新作,基于mybatis开发,青出于蓝而胜于蓝。通常我们的mybatis需要bean,mapper映射,但是mapper的xml中有非常复杂的标签,看起来令人头晕目眩。而tk.mybatis的出现正好解决了这个问题,它封装了一个通用mapper接口,生成bean时带有db中table对应的标签,单表简单地CRUD操作可以省去mapper-xxx.xml。通用mapper带来的好处也是显而易见的,比如当你的table有所改变是,只需要重新用generator生成下对应的实体bean即可,二不用焦头烂额地去挨个修改mapper中的关联标签,省时省力。

    非主流mybaits分页拓展包——tk.mybatis.pagehelper

    此拓展包同样出自 abel533大神之手,其原理是在拦截mybatis生成sql的过程,并向其注入分页代码“limit m,n”;
    同时,于分页查询前实现count(*)获取总数量;
    此举简化了分页的操作,释放了攻城狮的攻城时间;

    RPC框架:Dubbo(DubboX)

    dubbo是阿里出的一个rpc框架,主要用于中大规模的RPC和服务治理;
    dubbox是当当基于dubbo眼花的一个版本;
    dubbo 3.0中目前对dubbox一些功能进行了合并;

    分布式任务调度框架:Elastic-Job

    ej是当当的亮哥(张亮)主导开发的一款基于zookeeper,quartZ的分布式任务调度框架,区别于传统的quartZ无法进行高并发任务执行,ej可在同一时间基于分片进行并发任务调度。其中任务又分为简单任务,流式任务(可以一直执行某一逻辑,直到db中的数据被消费完)。
    之所以给3.5分的原因呢,是因为有一些坑!!!
    比如,某些版本的业务失效转移存在bug(当集群中的某台机器重启,但任务并没有执行,会被其他机器误执行失效转移)

    Google的java工具箱——Guava

    Guava想必很多开发者都不陌生,其封装了对Collection集合类,String等常用java数据结构的处理能力Joiner和Splitter。使用的时候简洁高效。
    另外其提供的缓存,重试器也比较实用,可以说是Google的良心出品了。以至于java的后续版本的改进也参考了Guava框架。
    Guava简介传送门:https://juejin.im/entry/58a29c3b8d6d81005889b394

    java 自带的易用框架

    各种map及其线程安全版本:

    比如常见的Hashmap(基于hash分布),TreeMap(基于红黑树)等;
    多线程下的ConcurrentHashMap等;
    要了解各种情况下时候用什么集合类,比如只要求map做缓存而不考虑读取顺序,就可以采用hashmap,
    而treemap是带有顺序的,默认会按照ASCII码顺序排列元素。

    各种List及其线程安全版本:

    比如ArrayList(基于索引),LikedArrayList(链表结构),HashSet,TreeSet等;
    若是在顺序插入的情况下,适合用基于索引的ArrayList;
    若存在大量的随机插入,则适合通LickedArrayList;
    HashSet不保证迭代顺序,内部元素不重复,因此set适合做一些去重操作;
    TreeSet与HashSet大同小异,顾名思义,TreeSet保证了内部元素的迭代顺序;

    java8的新能力——函数式编程

    lambda:

    比如创建一个新线程可以写作 new Runable(() ->{doSomeThings()}).start();
    简单明了;

    集合类的steam()操作

    Steam流式处理的出现大大提高了对集合类的处理能力,不仅简单易懂更是五花八门变化万千。可以说是非常的耐玩了。

    stream 流水线示意图

    steam提供许多的操作:
    map() -> 将集合部分字段按照要求映射;
    collect() -> 将集合按要求归并,归并的方法还有很多种玩法;
    filter() ->过滤不符合要求的元素;
    limit() ->限制元素数量;
    sorted()->排序;
    传送门:http://www.runoob.com/java/java8-streams.html

    相关文章

      网友评论

        本文标题:java 易用框架和插件集合(持续更新)

        本文链接:https://www.haomeiwen.com/subject/wtbamftx.html