这篇文章主要介绍“Java开发人员的常用类库有哪些”,在日常操作中,相信很多人在Java开发人员的常用类库有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java开发人员的常用类库有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!应用开发脚手架1.Spring FrameworkSpring框架为现代基于Java的企业应用程序提供了一个全面的编程和配置模型,使用开发基于Java语言的应用更加简单、便捷。github:https://github.com/spring-projects/spring-framework/官网:https://spring.io/projects/spring-framework2.Spring BootSpring Boot使创建独立的、基于Spring的产品级应用程序变得非常容易。官网:https://spring.io/projects/spring-boot3.Spring Cloud Spring Cloud为开发人员提供了丰富的使用工具,开发人员基于这些工具可以快速构建分布式系统中的一些常见功能(例如,配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁,领导选举,分布式会话等)。官网:https://spring.io/projects/spring-cloudWeb服务接口1.JerseyJersey是一个REST框架,它提供JAX-RS参考实现等。Jersey提供了自己的api,这些api通过附加的特性和实用程序扩展了JAX-RS工具包,从而进一步简化了RESTful服务和客户端开发。Jersey还公开了许多扩展spi,以便开发人员可以扩展Jersey以最适合他们的需求。github:https://github.com/eclipse-ee4j/jersey2.Spring Web MVCSpring Web MVC是基于Servlet API构建的原始Web框架,从一开始就已包含在Spring框架中。正式名称“ Spring Web MVC”来自其源模块的名称(spring-webmvc),但通常称为“Spring MVC”。官网:https://docs.spring.io/spring-framework/docs/current/spring-framework-reference/web.html数据持久化框架1.MyBatisMyBatis是一个一流的持久性框架,支持自定义SQL、存储过程和高级映射,它几乎消除了JDBC代码、参数手动设置和结果检索。MyBatis可以使用简单的XML或注释进行配置,并将原语、接口和javapojo(普通的旧Java对象)映射到数据库记录。官网:https://mybatis.org/mybatis-3/github:https://github.com/mybatis/mybatis-32.HibernateHibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。官网:http://hibernate.org/Excel读写1.Alibaba EasyExcelJava解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,能够原本一个3M的excel用POI sax依然需要100M左右内存降低到几M,并且再大的excel不会出现内存溢出,03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便。github:https://github.com/alibaba/easyexcel2.Apache POI一个用于读写Microsoft Office二进制和OOXML文件格式的Java库,可用于读写Excel 97-2008。github:https://github.com/apache/poiCSV读写1.Apache Commons CSVApache Commons CSV库提供了用于读取和写入各种类型CSV文件的接口。github:https://github.com/apache/commons-csv2.Java CSVJava CSV是一个小型、快速且开源Java库,用于读、写各种CSV文件。官网:https://www.csvreader.com/java_csv.phpAPI:http://javacsv.sourceforge.net/3.Super CSVSuper CSV是一个快速、免费跨平台的CSV格式数据的读写库,可以方便的处理对象、Map、列表的读写操作,以及自动化的类型转换和数据检查功能。官网:http://super-csv.github.io/super-csv/index.htmlgithub:https://github.com/super-csv/super-csvJSON读写1.JacksonJackson被称为Java的标准JSON库,号称“Java的最佳JSON解析器”。github:https://github.com/FasterXML/jackson2.GsonGson是谷歌开源的一个Java库,可用于将Java对象转换为其JSON表示形式。它还可以用于将JSON字符串转换为等效的Java对象。Gson可以处理任意Java对象,包括您没有源代码的现有对象。github:https://github.com/google/gson3.fastjsonfastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,支持将Java Bean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBean。github:https://github.com/alibaba/fastjsonXML读写1.dom4jdom4j是用于处理XML的开源框架,该框架与XPath集成在一起,并完全支持DOM、SAX、JAXP和Java平台。github:https://github.com/dom4j/dom4j官网:https://dom4j.github.io/2.StAXStAX全称Streaming API for XML,一种全新的、基于流的Java XML解析标准类库。3.jaxb-apijaxb-api用于执行XML文档和Java对象之间的映射。文档:https://docs.oracle.com/javase/8/docs/api/javax/xml/bind/JAXB.html4.XStreamXStream是一个可以轻易的将Java对象和xml文档相互转换的类库。官网:http://x-stream.github.io/IO读写1.Apache Commons IO Apache Commons IO是一个实用程序库,可协助开发IO功能。官网:https://commons.apache.org/proper/commons-io/2.OkioOkio是对java.io和java.nio的补充,使访问、存储和处理数据变得更加容易。github:https://github.com/square/okioHTTP客户端1.OkHttpOkHttp是一个HTTP客户端,使用OkHttp很容易,它的请求/响应API具有流畅的构建器和不变性。它支持同步阻塞调用和带有回调的异步调用。github:https://github.com/square/okhttp官网:https://square.github.io/okhttp/2.Apache HttpClientApache HttpClient提供了对基本HTTP协议的强大支持,用于构建基于HTTP的客户端。官网:http://hc.apache.org/index.htmlgithub:https://github.com/apache/httpcomponents-clientJava Bean复制1.Cglib BeanCopierCglib库内的BeanCopier提供了ava Bean到Java Bean的复制功能,性能优于Spring BeanUtils。2.Spring BeanUtilsSpring框架的Spring Beans库中的BeanUtils也实现了Java Bean到Java Bean的复制。3.DozerDozer是Java Bean到Java Bean映射器,它以递归方式将数据从一个对象复制到另一个对象。Dozer支持简单属性映射、复杂类型映射、双向映射、隐式显式映射以及递归映射。Dozer不仅支持属性名称之间的映射,而且还可以在类型之间自动转换。开箱即用地支持大多数转换方案,同时也允许您通过XML或基于代码的配置指定自定义转换。github:https://github.com/DozerMapper/dozer文档:https://dozermapper.github.io/gitbook/Redis客户端1.RedissionRedis推荐的Java客户端Redisson是一个在Redis的基础上实现的Java驻内存数据网格(In-Memory Data Grid),它充分利用了Redis键值数据库提供的一系列优势,基于Java实用工具包中常用接口,为使用者提供了一系列具有分布式特性的常用工具类,让使用Redis更加简单、便捷,从而让使用者能够将更多精力集中到业务逻辑处理上。github:https://github.com/redisson/redisson/2.JedisRedis推荐的Java客户端。github:https://github.com/xetorthio/jedis数据库连接池数据库连接池提供了一套高效的连接分配、使用策略, 最终实现连接的高效管理。1.HikariCP快速、简单、可靠。HikariCP是“零开销”生产就绪的JDBC连接池。github:https://github.com/brettwooldridge/HikariCP2.DruidDruid是Java语言中最好的数据库连接池之一,Druid能够提供强大的监控和扩展功能。github:https://github.com/alibaba/druid/3.Tomcat JDBCJDBC连接池是Apache Commons DBCP连接池的替代品。官网:http://tomcat.apache.org/tomcat-7.0-doc/jdbc-pool.html网络编程1.NettyNetty是一个广泛使用的Java网络编程框架。github:https://github.com/netty/netty官网:https://netty.io/文件上传1.Apache Commons FileUploadApache Commons FileUpload使高性能的文件上传功能变得容易。官网:http://commons.apache.org/proper/commons-fileupload/发送邮件1.Apache Commons EmailApache commons Email旨在提供用于发送电子邮件的API,它建立在Java Mail API之上,它的目标就是简便。官网:http://commons.apache.org/proper/commons-email/编码和解码1.Apache Commons CodecApache Commons Codec提供了常见编码器和解码器的实现,例如Base64,Hex,Phonetic和URL。官网:http://commons.apache.org/proper/commons-codec/IO操作1.Apache Commons IO简单、快捷的IO操作。官网:http://commons.apache.org/proper/commons-io/index.html对象池1.Apache Commons Pool提供了通用对象池。官网:http://commons.apache.org/proper/commons-pool/java.lang包工具类1.Apache Commons Lang为java.lang中的类提供额外的功能,例如StringUtils、DateUtils、RandomUtils、FastDateFormat(线程安全版本的SimpleDateFormat)。官网:http://commons.apache.org/proper/commons-lang/index.html集合操作1.Apache Commons Collections集合相关操作工具类。官网:http://commons.apache.org/proper/commons-collections/2.GuavaGuava是Google的一组核心Java库,除了可以操作我们常用的集合类型之外,还可以操作新的集合类型(例如多图和多集)和不可变的集合。github:https://github.com/google/guava全能型工具类1.GuavaGuava是Google的一组核心Java库,其中包括新免费云主机、域名的集合类型(例如多图和多集),不可变的集合,图形库以及用于并发,I / O,哈希,缓存,基元,字符串等的实用程序!它广泛用于Google的大多数Java项目中,也被许多其他公司广泛使用。github:https://github.com/google/guava2.HutoolHutool是一个Java工具包,也只是一个工具包,它帮助我们简化每一行代码,减少每一个方法,让Java语言也可以“甜甜的”。github:https://github.com/looly/hutool日期和时间操作1.Joda-TimeJoda-Time提供了Java日期和时间类的质量替代。官网:https://www.joda.org/joda-time/单元测试1.JUnit官网:https://junit.org/junit5/2.MockitoMockito是一个Java单元测试模拟框架。官网:https://site.mockito.org/3.PowerMockPowerMock也是一个Java单元测试模拟框架,它可以模拟静态方法、构造函数、最终类和方法、私有方法、删除静态初始化器等。官网:http://powermock.github.io/4.moco在日常接口测试的工作中,经常需要依赖其他系统的API,但是联调不常有,只能自己通过mock完成数据依赖。Moco是一个模拟服务器端服务的项目,可以用于测试打桩。github:https://github.com/dreamhead/moco安全框架1.Apache ShiroApache Shiro是一个功能强大且易于使用的Java安全框架,它用于身份验证、授权、加密和会话管理。使用Shiro易于理解的API,可以快速轻松地保护任何应用程序,从最小的移动应用程序到最大的Web和企业应用程序。官网:http://shiro.apache.org/日志1.SLF4J + LogbackSLF4J是为各种loging APIs提供一个简单统一的接口,从而使得最终用户能够在部署的时候配置自己希望的loging APIs实现,它是一个日志接口。Logback是由log4j创始人设计的又一个开源日志组件,它是一个日志的实现。SLF4J官网:http://www.slf4j.org/Logback官网:https://logback.qos.ch/对象池1.Apache Commons PoolApache Commons Pool提供了对象池API和一系列对象池实现。官网:https://commons.apache.org/proper/commons-pool/基本网络通讯1.Apache Commons NetApache Commons Net库实现了许多基本互联网协议的客户端。该库的目的是提供基本协议访问,而不是更高级别的抽象。官网:http://commons.apache.org/proper/commons-net/index.html作业调度框架(定时任务)1.QuartzQuartz是一个开源的作业调度框架,它完全由Java编写,能够用它来为执行一个作业而创建简单的或复杂的调度。官网:http://www.quartz-scheduler.org/github:https://github.com/quartz-scheduler/quartz2.ElasticJobElasticJob是一种分布式调度解决方案,解决了Quartz不支持分布式的弊端。Elastic job主要的功能有支持弹性扩容,通过Zookepper集中管理和监控job,支持失效转移等。github:https://github.com/apache/shardingsphere-elasticjob配置中心1.NacosNacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。Nacos的动态配置服务让您能够以中心化、外部化和动态化的方式管理所有环境的配置。动态配置消除了配置变更时重新部署应用和服务的需要。配置中心化管理让实现无状态服务更简单,也让按需弹性扩展服务更容易。官网:https://nacos.io/github:https://github.com/alibaba/nacos2.Spring Cloud ConfigSpring Cloud Config为分布式系统中的外部化配置提供服务器端和客户端支持。使用Config Server,您可以在中心位置管理所有环境中应用程序的外部属性。文档:https://cloud.spring.io/spring-cloud-config/reference/html/3.ApolloApollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性,适用于微服务配置管理场景。github:https://github.com/ctripcorp/apollo限流1.Guava RateLimiterRateLimiter基于令牌桶算法,即以用户设定的恒定速率向令牌桶内放置令牌,用户来执行任务时,只有拿到令牌才能执行。2.SentinelSentinel是面向分布式服务架构的高可用防护组件,主要以流量为切入点,从流量控制、熔断降级、系统自适应保护等多个维度来帮助用户保障微服务的稳定性。官网:https://sentinelguard.io/github:https://github.com/alibaba/Sentinel熔断降级当调用链路中某个资源出现不稳定,例如,表现为timeout,异常比例升高的时候,则对这个资源的调用进行限制,并让请求快速失败,避免影响到其它的资源,最终产生雪崩的效果。1.SentinelSentinel通过并发线程数进行限制和通过响应时间对资源进行降级两种手段对资源调用进行限制,让请求快速失败,避免影响到其它的资源。官网:https://sentinelguard.io/github:https://github.com/alibaba/Sentinel2.HystrixHystrix 通过线程池的方式,来对资源进行了隔离。这样做的好处是资源和资源之间做到了最彻底的隔离。缺点是除了增加了线程切换的成本,还需要预先给各个资源做线程池大小的分配。Hystrix不再处于主动开发中,并且当前处于维护模式,官方推荐使用Resilience4j替代。github:https://github.com/Netflix/Hystrix3.Resilience4jResilience4j是受Netflix Hystrix启发的轻量级容错库,但专为Java 8和函数式编程而设计。轻巧,因为该库仅使用Vavr,而Vavr没有任何其他外部库依赖项。github:https://github.com/resilience4j/resilience4j分库分表1.Apache ShardingSphereApache ShardingSphere定位为关系型数据库中间件,旨在充分合理地在分布式的场景下利用关系型数据库的计算和存储能力,而并非实现一个全新的关系型数据库。支持数据分片、读写分离、多数据副本、数据加密、影子库压测等功能。官网:https://shardingsphere.apache.org/github:https://github.com/apache/shardingsphere2.MycatMycat是数据库分库分表中间件。官网:http://www.mycat.org.cn/github:https://github.com/MyCATApache序列化1.KryoKryo是用于Java的快速高效的二进制对象图序列化框架。该项目的目标是高速,小尺寸和易于使用的API。每当需要将对象持久保存到文件,数据库还是通过网络时,该项目都是有用的。github:https://github.com/EsotericSoftware/kryo2.HessianHessian是一款支持多种语言进行序列化操作的框架技术,同时在进行序列化之后产生的码流也较小,处理数据的性能方面远超于java内置的jdk序列化方式。官网:http://hessian.caucho.com/3.ProtobufProtobuf是谷歌开源的一个灵活的、高效的用于序列化数据的协议。相比较XML和JSON格式,protobuf更小、更快、更便捷。github:https://github.com/protocolbuffers/protobuf官网:https://developers.google.com/protocol-buffers/RPC框架1.Dubbo Apache Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。官网:http://dubbo.apache.org/zh-cn/github:https://github.com/apache/dubbo2.Thrift Thrift是一个软件框架(远程过程调用框架),用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml这些编程语言间无缝结合的、高效的服务。Thrift最初由facebook开发,07年四月开放源码,08年5月进入apache孵化器,现在是 Apache 基金会的顶级项目。Thrift允许你定义一个简单的定义文件中的数据类型和服务接口,以作为输入文件,编译器生成代码用来方便地生成RPC客户端和服务器通信的无缝跨编程语言。官网:http://thrift.apache.org/3.gRPC gRPC是一个现代的、开源的、高性能的远程过程调用(RPC)框架,可以在任何地方运行。gRPC使客户机和服务器应用程序能够透明地通信,并简化了连接系统的构建。目前提供C、Java和Go语言版本,分别是:grpc, grpc-java, grpc-go. 其中C版本支持C, C++, Node.js, Python, Ruby, Objective-C, PHP和C#支持。官网:https://www.grpc.io/github:https://github.com/grpc/grpc到此,关于“Java开发人员的常用类库有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!
本篇内容主要讲解“为什么类的职责要单一化”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“为什么类的职责要单一化”吧!单一职责原则一个类应该只有一个发生变化的原因开闭原则软件实体应该是可扩展,而不可修改的。也就是说,对…