Java踩坑之路

  陆陆续续学Java也快一年多了,从开始的一窍不通到现在的初窥门径,我努力过,迷茫过,痛过,乐过,反思过,沉淀过。趁着新年,我希望能把这些东西记下来,就当是我一路走来的脚印。

一、初识网站应用

记得第一次接触Java,是写一个小网站,当时用servlet+tomcat做服务端,数据库是mysql。那时我对于网站应用的概念一片空白,之前接触的都是C++和MFC写桌面程序。我花了一周时间看完了《java servlet programming》这本书,然后我就开始写代码了。但是,真的当我写代码的时候,我却发现无从下手,因为那本书讲的很细,对于系统学习servlet很有帮助,但要想迅速建立一个demo,却并不是太适合。于是,我去找了本国人写的书,前面是理论,后面有一些小小的项目。我就照着某个小例子的代码写了一遍。代码写完了,tomcat也运行起来了(运行起来的过程中也遇到了大量的坑),用浏览器访问的时候却偏偏无法访问,查看tomcat的异常,发现一些类无法加载。去网上查了以后才知道,Java程序和mysql之间通信是需要驱动的。就这样搞了大概两天时间,我才把一个最简单的hello world完成了。搞完hello world只是万里长征的第一步,即使是做我那个小网站,也只是最开始的开始,后面有无数的坑等着我,我除了踩坑爬坑,别无选择。

接下来的一周,我花了很长时间去学习html和css,顺便继续开发我的servlet程序,但是,当我学完html和css后,同样的问题有来了,我无从下手!!我觉得作为一个新人,要想迅速上手一门技术是很难的,除非你有类似技术的开发经验(比如C#的人去搞Java),你唯一可以做的就是去模仿别人的东西,不断的写代码,不断的琢磨,然后慢慢变成自己的东西。我当时很绝望,于是上网直接找了套现成的皮肤,然后稍微改改,就作为了我的网站的前端页面。

前前后后,我一共花了半个月的时间,完成了我的小网站,虽然很丑,虽然漏洞百出,虽然不断被坑,但是,我还是学到了很多东西:servlet的基础知识,JSP的基础知识,Java的基础语法和常用的类,mysql驱动和JDBC,sql的增删改查,mysql的DDL语句,html和css的知识,tomcat应用部署和启动关闭。正是因为这半个月的坚持和努力,让我第一次获得了写代码的乐趣,也让我走进了Java的世界。

二、低谷

第一次编写小网站带给我的喜悦没有持续多久,我便陷入了迷茫。那时的我,并不知道Java是什么,它可以干些什么。我在图书馆逛了很久,也在网上找了很多资料,渐渐的知道了Java的两大体系:Java SE和Java EE,其中Java SE是开发Java程序的基础,Java EE是企业级开发。当时,我对Java SE只是停留在Java语法的基础上,并没有去了解JDK的庞大体系,而对Java EE也只是停留在servlet+jsp的层次,至于对于大量中间件、分布式应用等等则完全没有概念。一个人的眼界决定了他的走多远。接下来的一个月,我花了大量时间去学习servlet、jsp、jdbc,还把EL标签和JSTL标签也学完了。通过使用这些技术,我又做了几个小网站,那时的我觉得自己是多么的牛逼(现在看其实很傻比),也渐渐骄傲起来,觉得Java EE不过如此,这也导致了我接下来的一段时间几乎没有在去碰过网站技术。

也就是在那段不碰网站技术的日子里,我买了本书,叫《Java典型模块精解》。那时的我觉得那上面的东西都很高大上,什么电子相册模块,邮件发送模块等等。于是,我花了大概半个月的时间去模仿里面的代码,可是模仿来模仿去,我始终觉得自己的技术没有什么大的提高,唯一的提高就是了解了Java swing。我甚至发现,这些所谓的模块,其实都是类似的结构,swing作为程序显示部分,后台逻辑要么是操作数据库,要么是使用一些辅助工具(比如Java的邮件发送工具 Java mail),而且,swing的库实在太大,模仿了半天,要想自己写个程序出来,最后还是得去看书。就这样,没多久我就对这本书不感兴趣了。

三、基础!基础!

对待技术就像对待妹子,相处久了会腻,离开久了会想,即使你表面不承认。

我重拾Java是个不经意的选择,那时我只是恰好碰到本Java的书,于是随便翻翻,没想到越翻越来劲。以前我学Java,都是用到那就学到那,这一次,我决定系统学习Java,特别是Java的基础知识。我找了本Java的基础教材,从语法开始重新学起,到面向对象,集合框架,I/O,网络,数据库等。我把每个例子都敲了一遍代码,花了大概一个礼拜的时间,过了一遍书。

说实话,过一遍书还是有好处的。过了一遍之后,以前用过的东西会觉得好理解了很多,以前没用过的东西,则大概有个印象,但和我心中的预期还是有很大的落差。我以为过了一遍书,我就能把Java的基础知识都掌握了,但我毕竟图样图森破啊。我很失落,也开始反思,我觉得这一定是书的问题,不是自己的问题,于是,我求助于网友。网友都推荐《thinking in Java》,我也很天真的买了这本书,开始啃。啃着啃着发现,很多代码能看懂,但作者写的话就是不理解,啃再多遍都是一样的结果。我后来才知道,对技术的理解,必须建立在自己的阅历之上,常读常新,不是同一时间读一百遍会有一百种感受,而是每年读一遍会有不同的理解。

四、框架

框架是一个好东西,它将我带出了servlet体系,把我带进了一个更为广阔的天地:开源世界。

第一次使用框架是参加一个创新比赛,我学习并使用了struts2、spring和iBATIS这三个框架,俗称ssi。后来我一发不可收拾,先是用框架开发了几个web应用,然后借了struts2和ibatis的书阅读,把这两个框架用的十分熟练。这些技术也让我有能力去接一些小型的网站项目,虽然挣不来太多的钱,但它所带来的成就感却不是钱能够衡量的。这种成就感也驱使我去接触其他开源项目,比如说hibernate、Lucene、netty等。

开源框架在很长时间内都是我心目中Java的终结,我一直以为学会Java就是学会使用这些开源框架,但是,我错了。我发现我错的时候,是在我第一次看开源框架源代码的时候。开源框架的复杂代码让我感到震惊和恐惧,我认识到我是有多么的无知。会使用开源框架和会使用servlet有什么区别?都是打字员干的活啊!创造这些框架的人,才是真正的程序员!

框架给我带来的是更广阔的世界,但却让我更加迷茫,就像一只刚会飞翔的海燕,面对狂风暴雨的大海,内心充满的是敬畏和恐惧。

五、教学视频

如果我在一开始就去看教学视频,而不是自己摸索,我会少踩很多坑。

我遇到网络上的教学视频的时候,我已经对Java有了一定的基础了,但我还是花了很多时间去看视频。从Java基础,到多线程、俄罗斯方块游戏开发、ssi框架视频、mysql视频、前端视频、jdbc高级视频、Java web、EJB、电子商务网站项目等等。这些视频对我的帮助的确很大,它们帮我把以前零零散散学习的知识在短时间内串了起来。但是无论看多少视频,我的水平都没有发生质变,因为录视频的老师的水平,不足以让我产生质变。我始终相信,高手无法量产,一流的高手都是自学成才。教学视频仅仅是编程世界入门的通信证,而不是编程世界的终结。

六、面向对象和UML

开源框架源代码虽然可怕,但那也是人写出来的。

我最终还是下定决心去看源代码。当时选择的第一份阅读材料是iBATIS中使用的DBCP中使用的commons-pool。虽然commons-pool就区区几十个类,但是这些类结合在一起,却十分复杂。我尝试去理解代码,但看着看着就看不懂了,最后不得不放弃。后来我又试了好几次,都以失败告终。那时的我真的很痛苦,天花板看到了,可就是打不破,而安于现状又不甘心。直到有一天,我遇到了UML,我遇到了类图和序列图,我看到了有人使用这些图来分析源代码,面对这些分析我也第一次有点理解面向对象的精髓。于是,我尝试着使用类图和序列图去分析commons-pool,将静态的继承层次以及类与类之间的关联关系表达出来,将动态的程序调用顺序给画出来,就这样,我竟然理解了commons-pool的内部实现原理。我知道,我突破了这块天花板,我也知道,我接下来要面对的,是更复杂广阔的开源世界!后来,我又把DBCP和iBATIS的代码分析了一遍,收货颇丰。

七、尾声

未来的路一定是自己走的,但好的东西可以分享,俗话说它山之石可以攻玉,这也是我开博客的原因之一。希望在新的一年里,我能够多分享一些有意思也有意义的东西,和所有热爱技术的人一起成长。

时间: 2024-10-05 20:16:01

Java踩坑之路的相关文章

踩坑之路_"var name = ' ';"_迷之BUG

情景介绍:最近写一个拖拽生成图表的工具,自己的思路每次mousedown的时候动态将this的name属性值赋值给全局中变量(自己手贱测试时直接将变量名命名为了'name',一大波bug还有30s到达战场.....),mouseup时更具当前的全局属性值判断生成的图表类型:就酱... 首先给大家贴个html布局,有图有真相,(虽然简单的要死)正常结果应该是:拖拽 '折线图' 右侧生成折线图,柱状图生成柱状图: 然后我帅气的用 var name = ''; 从此开启bug模式: js代码如下: 出

webpack踩坑之路 (2)——图片的路径与打包

webpack踩坑之路 (2)--图片的路径与打包 刚开始用webpack的同学很容易掉进图片打包这个坑里,比如打包出来的图片地址不对或者有的图片并不能打包进我们的目标文件夹里(bundle).下面我们就来分析下在webpack项目中图片的应用场景. 在实际生产中有以下几种图片的引用方式: 1. HTML文件中img标签的src属性引用或者内嵌样式引用 <img src="photo.jpg" /> <div style="background:url(ph

html2canvas的踩坑之路

html2canvas的踩坑之路 前言 早有耳闻这个html2canvas比较坑,但无奈于产品需求的压迫,必须实现html转图片的功能,自此走上了填坑之路,好在最后的效果还算令人满意,这才没有误了产品上线周期. html2canvas介绍 html2canvas的详细介绍可以点击这里查看,其实简单来说就是通过canvas将HTML生成的DOM节点绘制到画布上,再可以通过自己的需求转换成图片.所以官方文档也说了,最后生成的效果不是100%相同的,这一点大家要有心理准备,无论怎样,一点点小瑕疵是肯定

jQuery升级踩坑之路

1.使用了被废弃的jQuery.browser属性 jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version , 取而代之的是 $.support . 在更新的 2.0 版本中,将不再支持 IE 6/7/8. 以后,如果用户需要支持 IE 6/7/8,只能使用 jQuery 1.9. 如果要全面支持 IE,并混合使用 jQuery 1.9 和 2.0, 官方的解决方案是: <!--[if lt IE 9]> <script src='jquer

java踩坑

java只传递指针遇到的坑: 1 import java.util.*; 2 3 public class mapTest { 4 public static class EntryWeight{ 5 public int entryid; 6 public float wordweight; 7 public int getentryid(){return entryid;} 8 public float getwordweigth(){return wordweight;} 9 public

angular踩坑之路:初探webpack

之前费了一番力气安装好了angular开发环境,后面的几天都是在angular中文官网上看文档,照着英雄教程一步一步操作,熟悉了angular的一些基本特性,这部分没有遇到什么大问题,还比较顺利.这两天在看官方文档中的Webpack简介,想跟着文档做一遍,了解一下如何用Webpack打包angular项目,结果遇到了一些问题,因为是初学angular和Webpack的小白,这些问题一时难以解决,花费了不少时间,想在这里记录一下. 首先跟着文档将相关的文件都添加到项目中,目录是这样子的: 根据文档

opencv入门踩坑之路(一)

因为找了个实验室搬砖,所以我开始学opencv和pytorch了 嘿嘿嘿,感觉记录踩过的坑会很有意思嘻嘻嘻 首先是安装opencv,这个贼简单,我用的win10 直接命令行 pip install opencv-python,如果需要安装特定版本,可以pip install opencv-python==版本号,但是直接用默认安装最新版,它不香吗? 接下来测试一下是否成功 版本号出来就说明成功啦 接下来跑第一个demo 这个demo的作用是显示一张图片 from cv2 import cv2 a

react js踩坑之路(一)

讲真如果让我选个主流的mvvm框架做项目,我会果断选择vue,写起来不要太方便哦.但是,pc端要兼容ie8这个坑货,所以pc端只好选用react了啦~移动端果断用vue咯 再来讲讲构建工具,还是基于webpack 和 gulp,然后将react和vue 分开打包相关配置如下 webpack会依次将公用的打包到vendors.js .react的打包到react中,vue相关的打包到vue中,最后剩下的部分打包到load.js中. 下面直接用react实现一个后台页面的container组件吧,这

webpack踩坑之路——构建基本的React+ES6项目

webpack是最近比较火的构建工具,搭配上同样比较火的ReacJS与ES6(ES2015)一定是现在很多潮流 programmer 的追求. 废话不多,下面就就看下如何从0搭起我们的构建工具. 安装 全局安装webpack,如果安装后还是提示没有webpack commond,可以尝试通过超级管理员身份安装. $ npm install webpack -g $ sudo npm install webpack -g  或者在项目里进行安装 $ npm install webpack --sa