首先常用api(String,StringBuffer/StringBuilder等)
1.集合类,线程类
2.Servlet(很少用纯粹的servlet写,但你要懂,因为很多框架都是基于servlet封装的)
3.json,xml读写
4.数据库访问(CRUD,事务,连接池)
5.http请求(HttpClient)
6其他,包括常用框架,设计模式,面向对象
初级程序员会这些就可以写项目了。后期遇到的问题就会复杂得多,要靠各种经验和知识的积累。
除了要掌握的20%以外还要掌握些什么知识才能游刃有余。下面说说我接触(使用)过、的东西吧。
java以分布式应用丰富的生态闻名,在分布式系统中逃不过CAP的抉择。早早了解一些分布式一致性协议paxos、raft等。学习zookeeper的原理和使用场景(metadata、分布式锁、leaderEletion… etc)
RPC框架在SOA架构中起着重要的作用,好好探究终是有好处的,在这里推荐阿里巴巴的dubbo框架,同时会netty、mina等网络库
Hadoop系列 Storm Spark 等离线\实时计算框架
ElasticSearch\SolrCloud 分布式搜索 ELK 日志相关的东西对这些比较敏感,当然在更多的场景使用ES也是有很多的
消息队列 kafka\MetaQ RabbitMQ 恩,昨天ZeroMQ(不完全算作MQ)的作者选择安乐死了,愿天堂没有痛苦
然后就是各种基础知识,编程语言、网络方面、数据库、数据结构和算法。不要觉得任何一项都精通了,敢说精通的知乎能有几个。
1.学会使用eclipse,svn等IDE和工具(不用说了吧,主要是看你工作的地方,比如大家用eclipse你想用IntelliJ IDEA也可以,但是刚工作肯定很多不懂,这时候暂时还不要标新立异的好,出了问题好问。当然你是ide大神请无视)
2. 刚入职还接触不到核心工作,就让我先改改页面什么的,作为web开发html、css、和javascript不用精通,至少需要了解用法和语法吧,虽然 有前端工程师,但是这个肯定也是要了解的(自己公司小项目组,各个都被逼成全栈了)。javascript其实还是很强大的,但是刚开始不用写的很深,很 多轮子可以用,比如easyui,正如@王大胖 所说的
会查阅官方文档
知道用法往网页里嵌,然后后台按格式把数据传到前台就好。
3. 然后开始逐步往后台写了,熟悉下设计模式,如果太多太难理解可以先理解工厂模式,写一个接口再用一个或若干个实现类实现这个接口,需要用的时候在根据需要 来确定用哪个实现类。(一开始不理解这么做这么繁琐有什么用,但是自从上次项目的数据库从oracle换成mysql就知道这么做其实大有用处)一般项目 开发都会用到设计模式,不了解可能会摸不清楚整个项目的架构,无从下手。
4.不同公司用的框架不一样,但struts,spring还是用 的比较多的,所以这两个东西还是比较熟悉的好,不然你可能连整个项目的架构都不清楚,不要说自己写,连改都很难入手。比如项目的跳转是怎么配的,哪个配置 文件代表了什么。(一开始我把项目本地跑起来以后我连主页在哪是哪个文件怎么进去的都不清楚T.T,一直在找index.jsp然后才知道项目用 freemarker做的,是一个ftl文件)
5.web项目要操作数据库的工作是少不了的了,自己跟的项目没用hibernate,主要用的是StringBuffer拼接sql,如果从事web开发,sql还是要比较熟的。按带我的小哥说,sql这么厉害,就没有sql完成不了的事。
<!–(这句正确与否观望中,但是一开始做一个抽取功能,自己把所有的人抽到程序里再抽,后来直接用sql抽了返回抽中的结果就好了,越用越发现sql真的猴犀利呀)–>
提醒,不应该用sql在数据库里做太多事,具体解决方法可以参考之前提的另外一个问题
请问多个功能需要同批数据是在程序里面遍历好还是sql数据库返回好? – 编程
但是sql的重要还是不言而喻的
6. 自己感觉做web项目设计高深算法的可能做的比较深才会遇到,更多的是对字符串和数值格式的操作,比如后台从数据库抽出来到前台怎么展示,用户输入的数据 怎么怎么存到数据库里,所以最好熟悉下字符串的操作,分割呀合并呀,String转float、int什么的,日期格式呀什么的。
如果公司有专业运维,服务器部署什么的交给他们就好了,如果没有就最好还是了解下,远程连接呀,linux的一些简单的命令呀,tomcat呀什么的
当然作为一个提供分布式服务接口的java工程师,需要熟练具备以下技能点:
1、java基本语法:最好能偶尔使用java8 lambda简化代码逻辑,google的guava库等等
2、docker基本使用:如今越来越多的公司选择将服务部署在docker上,构成独立的服务云平台,而且docker操作和资源调度分配很爽的。
3、消息队列:kafka、rabbitmq、notify、metamq等等,消息队列作为处理高吞吐量,不计较及时结果的应用场景的工具非常受欢迎。所采用的实际应用手法就是消息队列+补偿机制。
4、zookeeper或Etcd:这俩种都是分布式服务提供服务的注册中心,通过它们可以实现多服务多机器部署且实现负载均衡。
5、RPC:远程调用的场景使用越来越广泛,特别在分布式服务中更加离不开它。它能使多个服务间的调用如同调用本地方法一样简便。针对RPC的实现使用较为广泛的有Thrift、protobuffer等。
6、Netty:是一个高性能、异步事件驱动的NIO框架。能为RPC提供高性能的调用
7、git和maven等项目管理及依赖包管理的工具,这是协作开发的基础。
8、Redis:差点忘了这个必知必会的技能...Redis作为高性能的内存数据库,基本覆盖了访问量大的服务缓存。当然memcached前几年用的也居多,不过功能可被Redis替代。除了缓存也可以提供分布式锁机制。
最近去面试Java的东时学员整理:
0、 集合框架:源码阅读,重点理解 HashMap,ArrayList 等常用集合类;
1、 并发包:理解 ConcurrentHashMap 原理,线程池,异步并发,锁;
2、 IO / NIO;
3、 Java SE 基础:主要是一些基本概念和语法细节,如 equals 和 hashcode 作用,访问修饰等;4. SSH 框架:IoC 和 AOP 的原理,涉及概念有动态代理和反射;
5、 设计模式:常见的会画 UML,例如徒手撸各种单例实现,JDK 里面涉及的设计模式;
6、 Socket 编程。
当然,你去的话也可能不是这些,大体上脱离不了这些范围内的知识点,在编程工作中需要的,你自然会去学,不必局限自己必须学会什么才能工作,但是,这些20%的基础你必须掌握。
原文地址:https://www.cnblogs.com/shan1393/p/9017419.html