前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从 Spring 开始,谈谈如何自学 Java 常用框架

从 Spring 开始,谈谈如何自学 Java 常用框架

作者头像
阿凯
发布2018-06-29 12:34:45
1.2K0
发布2018-06-29 12:34:45
举报
文章被收录于专栏:程序员阿凯程序员阿凯

我记得,我刚找工作时简历上写的是精通 java,工作后写的是熟悉 java,现在写的是了解 java。

你学的越多,就会知道自己不懂的越多,那时的我们找工作,学过就叫精通,用过就写熟悉,听过就写了解。

今天想说说自己,自学 Spring 的学习路程,分享给大家。

Why

学习一种框架,首先需要知道,为什么需要使用这个框架。

任何一个框架的发明都是为了解决编程中的一些痛点。

要理解这些理念和优势,那么你就需要知道,没有使用这个框架之前是怎么处理的,才能彻底了解框架做了一些什么事情。

针对 Spring 的学习,第一步就是理解 IoC 和 AOP,这是基础;然后学习 SpringMVC

What

很多新的技术 只不过是引入了新的编程元素 对原来技术进行了封装。

Web开发,首先需要理解的是 HTTP 协议,这部分一定要深入理解。

理解http请求,其实就是要知道下面这张图的含义。

接下来,学习 Servlet 和 JSP

这个步骤是不可以跳过的,现在流行的框架 Spring MVC 和 Struts2 其实都是基于 Servlet 的,只有深入理解了 Servlet 才能理解后面的新技术。

下面几个知识点可以检测你是否理解了 Servlet:

  • 1、什么是 ServletContext,和 tomcat 等 web 容器的关系时什么?
  • 2、什么是 Session?Session 在实际工程中的应用场景。
  • 3、JSP的常用对象和指令。(JSP 是面向服务器的,JSP就是一个Servlet。)
  • 4、JSP的中文编码乱码有几种情况?各自的解决方法? 提示: JSP文件的编码,浏览器的解析编码,GET请求的编码,POST的编码。
  • 5、Servlet是一种接口规范,其中请求和响应是 Servlet 容器通过向方法的参数赋值 HttpServletRequest 或者 HttpServletResponse 传递的。

在Struts1里面,将doGet()方法里的响应移到返回值里。

在Struts2里则: 在Controller中彻底杜绝引入HttpServletRequest或者HttpServletResponse这样的原生Servlet对象。

同时将请求参数和响应数据都从响应方法中剥离到了Controller中的属性变量。

这是一个很大的技术改造,也造成了Struts2的盛行。

Spring MVC走的是中间路线, Spring的2.0.8之前的版本甚至直接使用Servlet的doGet的。

Spring MVC现在开始流行主要还是因为Schema xml 的精简和基于注解的配置。

所以这里出现了新的知识点:Schema Based XML的相关知识和 Java5 引入的注解原理。

推荐:计文柯的《深入理解spring技术内幕》

How

查看源码是比较快的学习方法,在一个项目里直接利用 debug 的方式追踪变量查看源码,而不是去阅读源码。

这里提供非常有用的几个 eclipse 使用技巧:

1.在面向接口编程中,我们很多时候看到一个方法返回的的是静态类型是接口的变量,并且实际类型被方法隐藏了。其实一般来说,一个接口,会有一个抽象类,然后会有一个 default 类,一般想要知道接口的具体实现,去看 default 类就可以。

2. 看一个类在哪些地方被引用,选中类名,Ctrl+Shift+G,

3. 看一个方法在哪些地方被调用,选中方法名,Ctrl+Alt+H。

4. 学会看eclipse右侧的 outline 窗口。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员阿凯 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档