想要成为合格的Java程序员或工程师到底需要具备哪些专业技能,面试者在面试之前到底需要准备哪些东西呢?本文陈列的这些内容既可以作为个人简历中的内容,也可以作为面试的时候跟面试官聊的东西,你可以把这些内容写到你的简历中,当然更需要的是你在面试的时候向面试官展示这些专业技能。相信此文对正在寻觅Java程序员(Java工程师)职位的freshman以及希望成为中高级Java开发者的junior都会有所帮助。
专业技能
1熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架、多线程(并发编程)、I/O(NIO)、Socket、JDBC、XML、反射等。
2熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器、过滤器等Web组 件以及MVC架构模式进行Java Web项目开发的经验。
3对Spring的IoC容器和AOP原理有深入了解,熟练的运用Spring框架管理各种Web组件及其依赖关系,熟练的使用Spring进行事务、日志、安全性等的管理,有使用Spring MVC作为表示层技术以及使用Spring提供的持久化支持进行Web项目开发的经验,熟悉Spring对其他框架的整合。
4熟练的使用Hibernate、MyBatis等ORM框架,熟悉Hibernate和MyBatis的核心API,对Hibernate的关联映射、继承映射、组件映射、缓存机制、事务管理以及性能调优等有深入的理解。
5熟练的使用HTML、CSS和JavaScript进行Web前端开发,熟悉jQuery和Bootstrap,对Ajax技术在Web项目中的应用有深入理解,有使用前端MVC框架(AngularJS)和JavaScript模板引擎(HandleBars)进行项目开发的经验。
6熟悉常用的关系型数据库产品(MySQL、Oracle),熟练的使用SQL和PL/SQL进行数据库编程。
7熟悉面向对象的设计原则,对GoF设计模式和企业应用架构模式有深入的了解和实际开发的相关经验,熟练的使用UML进行面向对象的分析和设计,有TDD(测试驱动开发)和DDD(领域驱动设计)的经验。
8熟悉Apache、NginX、Tomcat、WildFly、Weblogic等Web服务器和应用服务器的使用,熟悉多种服务器整合、集群和负载均衡的配置。
9熟练的使用产品原型工具Axure,熟练的使用设计建模工具PowerDesigner和Enterprise Architect,熟练的使用Java开发环境Eclipse和IntelliJ,熟练的使用前端开发环境WebStorm,熟练的使用软件版本控制工具SVN和Git,熟练的使用项目构建和管理工具Maven和Gradle。
说明:上面罗列的这些东西并不是每一项你都要烂熟于心,根据企业招聘的具体要求可以做相应的有针对性的准备。我个人觉得前6项应该是最低要求,是作为一个Java开发者必须要具备的专业技能
项目介绍
本系统是X委托Y开发的用于Z的系统,系统包括A、B、C、D等模块。系统使用了Java企业级开发的开源框架E以及前端技术F。表示层运用了G架构,使用H作为视图I作为控制器并实现了REST风格的请求;业务逻辑层运用了J模式,并通过K实现事务、日志和安全性等功能,通过L实现缓存服务;持久层使用了M封装CRUD *** 作,底层使用N实现数据存取。整个项目采用了P开发模型。
说明:上面的描述中,E通常指Spring(Java企业级开发的一站式选择);F最有可能是jQuery库及其插件或者是Bootstrap框架,当然如果要构建单页应用(SPA)最佳的方案是前端MVC框架(如AngularJS)和JavaScript模板引擎(如HandleBars);G显然是MVC(模型-视图-控制),最有可能的实现框架是Spring MVC,除此之外还有Struts 2、JSF以及Apache为JSF提供的MyFaces实现,可以使用JSP作为MVC中的V,也可使用模板引擎(如Freemarker和Velocity)来生成视图,还可以是各种文档或报表(如Excel和PDF等),而Servlet和自定义的控制器是MVC中的C,当然Spring MVC中提供了作为前端控制器的DispatcherServlet;J通常是事务脚本,K应该是AOP(面向切面编程)技术,L目前广泛使用的有memcached和Redis;M的选择方案很多,最有可能的是Hibernate和MyBatis,也可以两种技术同时运用,但通常是将增删改交给Hibernate来处理,而复杂的查询则由MyBatis完成,此外TopLink、jOOQ也是优秀的持久层解决方案;底层的数据存取传统上是使用关系型数据库,可以是MySQL、Oracle、SQLServer、DB2等,随着大数据时代的来临,也可以采用NoSQL(如MongoDB、MemBase、BigTable等)和其他大数据存取方案(如GFS、HDFS等);项目的开发模型P可以是瀑布模型、快速原型模型、增量模型、螺旋模型、喷泉模型、RAD模型等。
项目开发流程
1可行性分析 >>> 可行性分析报告 / 项目开发计划书
2需求分析 >>> 需求规格说明书
1OOAD(用例图、时序图、活动图)
2界面原型:帮助理解需求、业务层设计时推导事务脚本
3设计 >>> 概要设计说明书/详细设计说明书
1抽取业务实体(领域对象):类图、E-R图(概念设计阶段)
2分层架构:确定各层的技术实现方案(具体到使用的框架、数据库服务器、应用服务器等)。业务层设计:事务脚本模式(事务:用户发送一次请求就是一个事务;脚本:一个方法或一个函数;事务脚本:把一次请求封装为一个方法或一个函数;事务脚本模式:一个事务开始于脚本的打开,终止于脚本的关闭)。业务层涉及的对象本有 三种类型:事务脚本类(封装了业务的流程)、数据访问对象( DAO,封装了持久化 *** 作)、数据传输对象(DTO,封装了失血/贫血领域对象),三者之间的关系是事务脚本类组合(聚合)数据访问对象,这二者都依赖了数据传输对象
3正向工程(UML类图生成Java代码)和逆向工程(Java代码生成UML类图)
4数据库物理设计(ER图转换成表间关系图、建库和建表、使用工具插入测试数据)
4编码 5测试 >>> 测试报告 / 缺陷报告
1单元测试:对软件中的最小可测试单元进行检查和验证,在Java中是对类中的方法进行测试,可以使用JUnit工具来实施。
2集成测试:集成测试也叫组装测试或联合测试。在单元测试的基础上,将所有模块按照设计要求组装成为子系统进行测试。
3系统测试:将已经确认的软件、硬件、外设、网络等元素结合在一起,进行信息系统的各种组装测试和确认测试,系统测试是针对整个产品系统进行的测试,目的是验证系统是否满足了需求规格的定义,找出与需求规格不符或与之矛盾的地方,从而提出更加完善的方案。
4验收测试:在软件产品完成了单元测试、集成测试和系统测试之后,产品发布之前所进行的软件测试活动。它是技术测试的最后一个阶段,也称为交付测试。验收测试的目的是确保软件准备就绪,并且可以让最终用户将其用于执行软件的既定功能和任务。
5交付和维护 >>> 用户手册 / *** 作手册
项目管理
版本控制:CVS/SVN/Git
自动构建:Ant/Maven/Ivy/Gradle
持续集成:Hudson/Jenkins
系统架构
负载均衡服务器:F5、A10
应用服务器:
>
Servlet容器:Tomcat、Resin
EJB容器:WildFly(JBoss Application Server)、GlassFish、Weblogic、Websphere 数据库服务器:MySQL、Oracle
第三方工具(插件)应用
图表工具:基于jQuery的图表插件(如jQchart、Flot、Charted等)、Chartjs、Highcharts等。
报表工具:Pentaho Reporting、iReport、DynamicReports等。
文档处理:POI、iText等。
工作流引擎:jBPM、OpenWFE、Snaker、SWAMP等。
作业调度:Quartz、JobServer、Oddjob等。
缓存服务:EhCache、memcached、SwarmCache等。
消息队列:Open-MQ、ZeroMQ等。
安全框架:Shiro、PicketBox等。
搜索引擎:IndexTank、Lucene、ElasticSearch等。
Ajax框架:jQuery、ExtJS、DWR等。
UI插件:EasyUI、MiniUI等。
富文本框:UEditor、CKEditor等。
面试提问
项目是为哪个公司开发的?
项目的投入是多少?
有多少人参与了项目开发?
整个团队中,测试人员、开发人员、项目经理比例是多少?
项目开发了多长时间?
项目总的代码量有多少?
你的代码量有多少?
项目采用了怎样的开发模型或开发流程?
项目的架构是怎样的?
项目的技术选型是怎样的?
你在项目中承担了怎样的职责?
是否经常开会或加班?
项目完成后有哪些收获或是经验教训?
项目中最困难的部分是什么?
如何解决团队开发时遇到的各种冲突?
明:对于没有实际项目经验的,可以在前程无忧、智联招聘、拉勾网等网站上搜索招聘Java程序员的公司,找到他们的官方网站了解他们做的项目,查看项目的详细介绍,然后尝试完成其中一部分功能,最好请教一下高人看看自己的设计和代码是否恰当,这样相当于积累了一定的项目经验。
面试时可以反问面试官的问题
我注意到你们使用了X技术,请问你们是如何解决Y问题的?
为什么你们的产品使用了X技术而不是Y技术?据我所知,X技术虽然有A、B、C等好处,但也存在D和E问题,而Y技术可以解决D和E问题。
我对您说的X技术不是太熟悉,但我感觉它是一个不错的解决方案,您能多讲讲它的工作原理吗?
你们团队是如何进行项目规划的?一周会有几次例会?每周的代码量大概是多少?
就X问题我能想到的解决方案目前就只有Y了,请问您会怎么解决这个问题?
录用谈判
要理直气壮的提出具体的待遇要求
开出比预期稍高的价码
不要只盯着薪水(很多公司更愿意就薪水之外的条件做出让步)
使用最合适的方法(可以尝试在电话或E-mail中谈判待遇)
自我评价
学习能力(搞IT行业的人需要不断的了解新的技术、工具和方法)
团队意识(相比个人英雄主义,IT行业更倡导团队合作)
抗压能力(很多IT企业的工作强度相对来说还是比较大的)
自学编程,免费获取精品IT教程以及资料,搜索:黑马程序员
网页链接
拟生成一个名为“测试数据xls”的Excel文件,其中第一个工作表被命名为“第一页”,大致效果如下:代码(CreateXLSjava):
//生成Excel的类
import javaioFile;
import jxlWorkbook;
import jxlwriteLabel;
import jxlwriteWritableSheet;
import jxlwriteWritableWorkbook;
public class CreateXLS {
public static void main(String args[]) {
try {
// 打开文件
WritableWorkbook book = WorkbookcreateWorkbook(new File(
"simplexls"));
// 生成名为“第一页”的工作表,参数0表示这是第一页
WritableSheet sheet = bookcreateSheet("first sheet", 0);
// 在Label对象的构造子中指名单元格位置是第一列第一行(0,0)
// 以及单元格内容为test
Label label = new Label(0, 0, "test123");
// 将定义好的单元格添加到工作表中
sheetaddCell(label);
/
生成一个保存数字的单元格 必须使用Number的完整包路径,否则有语法歧义 单元格位置是第二列,第一行,值为789123
/
jxlwriteNumber number = new jxlwriteNumber(1, 0, 789123);
sheetaddCell(number);
// 写入数据并关闭文件
bookwrite();
bookclose();
} catch (Exception e) {
Systemoutprintln(e);
}
}
}
编译执行后,会在当前位置产生一个Excel文件。
二、读取文件
以刚才我们创建的Excel文件为例,做一个简单的读取 *** 作,程序代码如下:
//读取Excel的类
import javaioFile;
import jxlCell;
import jxlSheet;
import jxlWorkbook;
public class ReadXLS {
public static void main(String args[]) {
try {
Workbook book = WorkbookgetWorkbook(new File("simplexls"));
// 获得第一个工作表对象
Sheet sheet = bookgetSheet(0);
// 得到第一列第一行的单元格
Cell cell1 = sheetgetCell(0, 0);
String result = cell1getContents();
Systemoutprintln(result);
bookclose();
} catch (Exception e) {
Systemoutprintln(e);
}
}
}
程序执行结果:test
三、修改文件
利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,其他 *** 作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件中添加一个工作表:
//修改Excel的类,添加一个工作表
//修改Excel的类,添加一个工作表
import javaioFile;
import jxlWorkbook;
import jxlwriteLabel;
import jxlwriteWritableSheet;
import jxlwriteWritableWorkbook;
public class UpdateXLS {
public static void main(String args[]){
try{
// Excel获得文件
Workbook wb=WorkbookgetWorkbook(new File("simplexls"));
// 打开一个文件的副本,并且指定数据写回到原文件
WritableWorkbook book= WorkbookcreateWorkbook(new File("simplexls"),wb);
// 添加一个工作表
WritableSheet sheet=bookcreateSheet("第二页",1);
sheetaddCell(new Label(0,0,"第二页的测试数据"));
bookwrite();
bookclose();
}catch(Exception e) {
Systemoutprintln(e);
}
}
}
执行结果如图:
高级 *** 作
一、 数据格式化
在Excel中不涉及复杂的数据类型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。
1、 字串格式化
字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,为方便叙述,我们为每一行命令加了编号:
WritableFont font1=
new WritableFont(WritableFontTIMES,16,WritableFontBOLD); 或//设置字体格式为excel支持的格式 WritableFont font3=new WritableFont(WritableFontcreateFont("楷体_GB2312"),12,WritableFontNO_BOLD );① WritableCellFormat format1=new WritableCellFormat(font1); ② Label label=new Label(0,0,”data 4 test”,format1) ③ 其中①指定了字串格式:字体为TIMES,字号16,加粗显示。WritableFont有非常丰富的构造子,供不同情况下使用,jExcelAPI的java-doc中有详细列表,这里不再列出。 ②处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种属性,后面的单元格格式化中会有更多描述。 ③处使用了Label类的构造子,指定了字串被赋予那种格式。 在WritableCellFormat类中,还有一个很重要的方法是指定数据的对齐方式,比如针对我们上面的实例,可以指定:
//把水平对齐方式指定为居中
format1setAlignment(jxlformatAlignmentCENTRE);
//把垂直对齐方式指定为居中
format1setVerticalAlignment(jxlformatVerticalAlignmentCENTRE);
//设置自动换行
format1setWrap(true);
二、单元格 *** 作
Excel中很重要的一部分是对单元格的 *** 作,比如行高、列宽、单元格合并等,所幸jExcelAPI提供了这些支持。这些 *** 作相对比较简单,下面只介绍一下相关的API。
1、 合并单元格
WritableSheetmergeCells(int m,int n,int p,int q);
作用是从(m,n)到(p,q)的单元格全部合并,比如:
WritableSheet sheet=bookcreateSheet(“第一页”,0);
//合并第一列第一行到第六列第一行的所有单元格
sheetmergeCells(0,0,5,0);
合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。
2、 行高和列宽
WritableSheetsetRowView(int i,int height);
作用是指定第i+1行的高度,比如:
//将第一行的高度设为200
sheetsetRowView(0,200);
WritableSheetsetColumnView(int i,int width);
作用是指定第i+1列的宽度,比如:
//将第一列的宽度设为30
sheetsetColumnView(0,30);
五、 *** 作
public static void write()throws Exception{
WritableWorkbook wwb=WorkbookcreateWorkbook(new File("c:/1xls"));
WritableSheet ws=wwbcreateSheet("Test Sheet 1",0);
File file=new File("C://jbproject//PVS//WebRoot//weekhit//1109496996281png");
WritableImage image=new WritableImage(1, 4, 6, 18,file);
wsaddImage(image);
wwbwrite();
wwbclose();
}
很简单和插入单元格的方式一样,不过就是参数多了些,WritableImage这个类继承了Draw,上面只是他构造方法的一种,最后一个参数不用了说了,前面四个参数的类型都是double,依次是 x, y, width, height,注意,这里的宽和高可不是的宽和高,而是所要占的单位格的个数,因为继承的Draw所以他的类型必须是double,具体里面怎么实现的我还没细看:)因为着急赶活,先完成功能,其他的以后有时间慢慢研究。以后会继续写出在使用中的心得给大家。
读:
读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl中的Workbook得到工作薄,用Sheet从工作薄中得到工作表,用Cell得到工作表中得某个单元格
InputStream->Workbook->Sheet->Cell,就得到了excel文件中的单元格
代码:
String path="c://excelxls";//Excel文件URL
InputStream is = new FileInputStream(path);//写入到FileInputStream
jxlWorkbook wb = WorkbookgetWorkbook(is); //得到工作薄
jxlSheet st = wbgetSheet(0);//得到工作薄中的第一个工作表
Cell cell=stgetCell(0,0);//得到工作表的第一个单元格,即A1
String content=cellgetContents();//getContents()将Cell中的字符转为字符串
wbclose();//关闭工作薄
isclose();//关闭输入流
我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel中的坐标对应
例如A1对应(0,0),A2对应(0,1),D3对应(3,2)Excel中坐标从A,1开始,jxl中全部是从0开始
还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet中的所有内容
写:
往Excel中写入内容主要是用jxlwrite包中的类
思路是这样的:
OutputStream<-WritableWorkbook<-WritableSheet<-Label
这里面Label代表的是写入Sheet的Cell位置及内容
代码:
OutputStream os=new FileOutputStream("c://testxls");//输出的Excel文件URL
WritableWorkbook wwb = WorkbookcreateWorkbook(os);//创建可写工作薄
WritableSheet ws = wwbcreateSheet("sheet1", 0);//创建可写工作表
Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容
wsaddCell(labelCF);//将Label写入sheet中
Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容
WritableFont wf = new WritableFont(WritableFontTIMES, 12, WritableFontBOLD, false);//设置写入字体
WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat
Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式
Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性
//现在可以写了
wwbwrite();
//写完后关闭
wwbclose();
//输出流也关闭吧
osclose;
//OK,只要把读和写结合起来,就可以在N个Excel中读取数据写入你希望的Excel新表中,还是比较方便的
下面是程序一例:
程序代码:
sql = "select from tablename";
rs = stmtexecuteQuery(sql);
//新建Excel文件
String filePath=requestgetRealPath("aaaxls");
File myFilePath=new File(filePath);
if(!myFilePathexists())
myFilePathcreateNewFile();
FileWriter resultFile=new FileWriter(myFilePath);
PrintWriter myFile=new PrintWriter(resultFile);
resultFileclose();
//用JXL向新建的文件中添加内容
OutputStream outf = new FileOutputStream(filePath);
jxlwriteWritableWorkbook wwb = WorkbookcreateWorkbook(outf);
jxlwriteWritableSheet ws = wwbcreateSheet("sheettest", 0);
int i=0;
int j=0;
for (int k = 0; k < rsgetMetaData()getColumnCount(); k++) {
wsaddCell(new Label(k,0,rsgetMetaData()getColumnName(k+1)));
}
while(rsnext()){
outprintln(rsgetMetaData()getColumnCount());
for (int k = 0; k < rsgetMetaData()getColumnCount(); k++) {
wsaddCell(new Label(k,j+i+1,rsgetString(k+1)));
}
i++;
}
wwbwrite();
wwbclose();
}catch(Exception e){
eprintStackTrace();
}
finally{
rsclose();
connclose();
}
responsesendRedirect("aaaxls");首先要明白,JSP和Servlet都是位于服务器端,平时我们做开发,自己的机器充当了客户机和服务器的双重角色。在典型的MVC开发模式中,JSP充当了视图层,Servlet充当控制层,JavaBeen充当模型层。
每一个JSP页面一般都会对应一个Sevlet,(在webxml中可以看到有关配置),JSP页面如果是以post方式发出请求给Servlet,就会调用Servlet中的doPost()方法,如果是以get方式发出请求,就会调用其doGet()方法,一般这两个方法只具体实现一个,可以在另一个方法调用有具体实现的那个方法。至于JSP页面是以get方式发出请求,还是以post方式发出请求,最简单的方式是看地址栏又没有像?name=xxxx&id=xxxx的键值对字符串,如果jsp网页中包含form表单,还可以看其method属性是get还是post,不过一般表单都是用post方式提交给后台Servlet。当请求传给Servlet时,同时也会把相关数据传过去,这样才可以在后台获取这些数据。一般使用requestgetParameter()方法
由于Servlet是控制层,顾名思义,它当然可以控制请求的转发 *** 作。使用requestgetRequestDispatcher("xxx,jsp")forward(request,response)这个只要HTML转义下就可以了 有一个orgspringframeworkwebutilHtmlUtils这样的工具类可以方便 *** 作
当然struts2里也有 你注意到没<s:property >中有个escape的属性用statement接口。保存富文本编辑框的内容,也就是带HTML格式的文本,就可以用statement接口完成,可以使用connection接口中的createStatement方法完成实。
public String parseHtml(String html,int length) {
if(html == null || html == "") {
return html = "空";
}else {
if(htmllength()<length){
return html;
}else {
/
<>为正则表达式,其中的表示任意字符,表示出现0次或0次以上,此方法可以去掉双头标签(双头针对于残缺的标签)
"<"表示<尖括号后的所有字符,此方法可以去掉残缺的标签,及后面的内容
" ",若有多种此种字符,可用同一方法去除
/
html = htmlreplaceAll("<>", " ")replaceAll("", "");
html = htmlreplaceAll("<", "");
return (htmlsubstring(0, length) + "");
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)