搞懂了这些java框架离高薪就不远了
来源 :中华考试网 2020-11-03
中自从java程序入市以来,Java仍是就业人数最多的编程语言,作为数万程序员的选择,Java就业前景好,岗位多,从业面广,要知道在变幻莫测的编程界,Java独领风骚已有二十多载,23年的独立开发历史,83次荣获Tiobe排行榜首位,90%服务器用Java开发,45.5%开源项目用Java开发……如果你学习Java,这些框架是万万不能少的,掌握了这些java框架想不挣钱都难!
01 Spring
Spring作为开源框架,是由Rod Johnson创建,它是为解决企业应用开发的复杂性而创建的。作为轻量级控制反转(IoC)和面向切面(AOP)的容器框架,它能编写更干净、更可管理且易于测试的代码。
目的:解决企业应用开发的复杂性。
功能:使用基本的JavaBean代替EJB,并提供更多企业应用功能。
范围:任何Java应用。
构成:最完善的轻量级核心框架;通用的事物管理抽象层;JDBC抽象层;集成了Toplink, Hibernate, JDO, and iBATIS SQL Maps;AOP功能;灵活的MVC Web应用框架。
必须了解的优点,JAVA EE应该更容易使用;面向对象的设计比任何实现技术(比如JAVA EE)都重要;面向接口编程,而不是针对类编程。Spring将使用接口的复杂度降低到零;代码应该易于测试。Spring框架会帮助你,使代码的测试更加简单;JavaBean提供了应用程序配置的最好方法;在Java中,已检查异常(Checked exception)被过度使用。框架不应该迫使你捕获不能恢复的异常。
02 Spring Boot
Spring Boot是由Pivotal团队在2013年开始研发、2014年4月发布第一个版本的全新开源的轻量级框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。它基于Spring4.0设计,不仅继承了Spring框架原有的优秀特性,而且还通过简化配置进一步简化了Spring应用的整个搭建和开发过程。另外Spring Boot通过集成大量的框架使得依赖包的版本冲突,以及引用的不稳定性等问题得到了很好的解决。
Spring Boot特征:
• 可以创建独立的Spring应用程序,并且基于其Maven或Gradle插件,可以创建可执行的JARs和WARs;
• 内嵌Tomcat或Jetty等Servlet容器;
• 提供自动配置的“starter”项目对象模型(POMS)以简化Maven配置;
填写下面表单即可预约申请免费试听java课程!害怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!
预约申请免费听java课程
- 地区:
- 北京
- 天津
- 上海
- 江苏
- 浙江
- 山东
- 江西
- 安徽
- 广东
- 广西
- 海南
- 辽宁
- 吉林
- 黑龙江
- 内蒙古
- 山西
- 福建
- 河南
- 河北
- 湖南
- 湖北
- 四川
- 重庆
- 云南
- 贵州
- 新疆
- 西藏
- 陕西
- 青海
- 宁夏
- 甘肃
- 姓名:
- 手机:
• 尽可能自动配置Spring容器;
• 提供准备好的特性,如指标、健康检查和外部化配置;
• 绝对没有代码生成,不需要XML配置。
必须了解Spring Boot框架中的两个重要策略,开箱即用和约定优于配置。开箱即用“Outofbox”,指在开发过程中,通过在MAVEN项目的pom文件中添加相关依赖包,然后使用对应注解来代替繁琐的XML配置文件以管理对象的生命周期。这个特点使得开发人员摆脱了复杂的配置工作以及依赖的管理工作,更加专注于业务逻辑。约定优于配置“Convention over configuration”,是一种由SpringBoot本身来配置目标结构,由开发者在结构中添加信息的软件设计范式。这一特点虽降低了部分灵活性,增加了BUG定位的复杂性,但减少了开发人员需要做出决定的数量,同时减少了大量的XML配置,并且可以将代码编译、测试和打包等工作自动化。
03 Spring MVC
Spring MVC旨在解决V-C的交互问题,即视图与控制器的交互问题。在原生的Java EE技术中,使用Servlet作为项目中的控制器,用于接收用户的请求,并给予响应结果。
核心组件:
• Controller 实际处理请求的组件,例如接收请求参数,决定最终是转发或重定向的方式来响应。
• DispatcherServlet 前端控制器,主要职责是接收所有请求(根据配置文件来决定),并将请求转发给对应的控制器,接收控制器的处理结果,确定最终由哪个视图完成响应。
• HandlerMapping 处理请求路径与控制器的映射关系。
• ModelAndView 控制器的处理结果,其中的Model表示转发的数据(如果是重定向,Model没有意义),而View表示最终负责响应的视图组件的名称。
• ViewResolver 根据视图组件的名称,确定具体使用哪个视图组件。
04 Spring Cloud
Spring Cloud为开发人员提供了一些工具来快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导层选举,分布式会话,群集状态)。Spring Cloud致力于为典型用例提供良好的开箱即用体验,并提供覆盖其他用例的扩展机制。
Feature
• Distributed/versioned configuration
• Service registration and discovery
• Routing
• Service-to-service calls
• Load balancing
• Circuit Breakers
• Global locks
• Leadership election and cluster state
• Distributed messaging
05 Dubbo
Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和Spring框架无缝集成。作为一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。
核心部件:
• Remoting: 网络通信框架,实现了sync-over-async和request-response 消息机制。
• RPC: 一个远程过程调用的抽象,支持负载均衡、容灾和集群功能。
• Registry: 服务目录框架用于服务的注册和服务事件发布和订阅。
你需要了解的Dubbo特性,面向接口代理的高性能RPC调用(提供高性能的基于代理的远程调用能力,服务以接口为粒度,为开发者屏蔽远程调用底层细节);智能负载均衡(内置多种负载均衡策略,智能感知下游节点健康状况,显著减少调用延迟,提高系统吞吐量);服务自动注册与发现(支持多种注册中心服务,服务实例上下线实时感知);高度可扩展能力(遵循微内核+插件的设计原则,所有核心能力如ProtocolTransport、Serialization被设计为扩展点,平等对待内置实现和第三方实现);运行期流量调度(内置条件、脚本等路由策略,通过配置不同的路由规则,轻松实现灰度发布,同机房优先等功能);可视化的服务治理与运维(提供丰富服务治理、运维工具:随时查询服务元数据、服务健康状态及调用统计,实时下发路由策略、调整配置参数)。
06 Ehcache
EhCache 是一个纯Java的进程内缓存框架,主要面向通用缓存、JavaEE和轻量级容器,具有快速、精干等特点,是Hibernate中默认的CacheProvider。Ehcache最初是由Greg Luck于2003年开始开发。2009年,该项目被Terracotta购买。软件仍然是开源,但一些新的主要功能(eg.快速可重启性之间的一致性的)只能在商业产品中使用。
特性:快速,简单,多种缓存策略;缓存数据有两级(内存和磁盘,无需担心容量);缓存数据会在虚拟机重启的过程中写入磁盘;可以通过RMI、可插入API等方式进行分布式缓存;具有缓存和缓存管理器的侦听接口;支持多缓存管理器实例,以及一个实例的多个缓存区域;提供Hibernate的缓存实现。