java基础知识精华
转载:https://www.jianshu.com/p/6c078abb720f
java基础知识
java内存模型
- java运行时数据区域
hashMap
- 如何解决冲突
- 存储方式
- 冲突达到一定数量改用红黑树存储等
ConcurrentHashMap
- 段的概念
- 分段锁机制(读不加锁,写加锁)
- 大概的原理,先定位到某个段,然后段里面的操作交给hashmap
try finally块的处理
-try里面return某个(引用类型 值类型),finally块对其进行操作,最后结果
synchromized相关
-为什同步块对性能的影响大
- synchronized加在静态方法上面,锁是什么
- 不同线程
基本排序
- 选择排序
数据结构
- stack 数组实现
- 两个stack实现队列
阻塞队列
- 实现
- wait和notify实现
- condition条件变量方式
编程题
- 统计文本文件中出现频率最高的20个单词
ArrayList 和LinkedList
- 查找元素的时间复杂度
-分别适用于什么情况下
java多线程
- 状态转换
list和set的区别
spring中的注解
spring mvc中的注解
Cookie和Session的区别
如何获取一个网站每天的访问量
自己定义的类是如何实现hashcode()方法
关于集合添加元素
-equal hashcode
JVM
- Java内存分代模型,GC算法,JVM常见的启动参数; CMS算法的过程
- java 分布式开发
框架
- spring aop的底层实验原理。 aop与cglib,与asm的关系。
spriong ioc的生命周期,(init-method,intilizingbean接口方法afterPropertiesSet的先后顺序)等。
Hibernate对一二级缓存的使用,Lazy-Load的理解;
数据库相关
- mysql存储引擎中索引的实现机制;
- 数据库事务的几种粒度;
- 行锁,表锁;乐观锁,悲观锁
- MySql的存储引擎的不同
- 单个索引、联合索引、主键索引
- Mysql怎么分表,以及分表后如果想按条件分页查询怎么办(如果不是按分表字段来查询的话,几乎效率低下,无解)
- 分表之后想让一个id多个表是自增的,效率实现
- MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离
- SQL语句
- 索引的数据结构,B+树
- 事物的四个特性,以及各自的特点(原子、隔离)等等,项目怎么解决这些问题
网络协议
- HTTP协议;
HTTPS协议,SSL协议及完整交互过程;
redis
- redis,memcache底层客户端使用一致性Hash,看是否了解;
- redis的事件驱动多路复用底层实现;引申到NIO编程, 看对Netty,或mina是否了解。
- 如果候选者同时用过memcache,redis,看下是否了解两者在使用场景上的区别。以考察使用深度,以及是否有好奇精神。
string stringbuild stringbuffer的区别
- string类为什么是final
负载均衡的原理
https处理一个过程 对称加密非对称加密
java基础
- String类为什么是final的。
2.HashMap的源码,实现原理,底层结构。
3.反射中,Class.forName和classloader的区别
4.session和cookie的区别和联系,session的生命周期,多个服务部署时session管理。
5.Java中的队列都有哪些,有什么区别。
6.Java的内存模型以及GC算法 7.Java7、Java8的新特性
8.Java数组和链表两种结构的操作效率,在哪些情况下(从开头开始,从结尾开始,从中间开始),哪些操作(插入,查找,删除)的效率高
9.Java内存泄露的问题调查定位:jmap,jstack的使用等等
框架
- 1.struts1和struts2的区别
2.struts2和springMVC的区别
3.spring框架中需要引用哪些jar包,以及这些jar包的用途
4.srpingMVC的原理
5.springMVC注解的意思
6.spring中beanFactory和ApplicationContext的联系和区别
7.spring注入的几种方式
8.spring如何实现事物管理的
9.springIOC和AOP的原理
10.hibernate中的1级和2级缓存的使用方式以及区别原理 11.spring中循环注入的方式
多线程
- .Java创建线程之后,直接调用start()方法和run()的区别
2.常用的线程池模式以及不同线程池的使用场景
3.newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。
4.多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。
5.了解可重入锁的含义,以及ReentrantLock 和synchronized的区别
6.同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么他是同步的且效率高7.atomicinteger和volatile等线程安全操作的关键字的理解和使用
8.线程间通信,wait和notify
9.定时线程的使用
10.场景:在一个主线程中,要求有大量(很多很多)子线程执行完之后,主线程才执行完成。多种方式,考虑效率。
网络通信
- 1.http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。
2.socket通信,以及长连接,分包,连接异常断开的处理。
3.socket通信模型的使用,AIO和NIO。
4.socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞。
5.同步和异步,阻塞和非阻塞。
设计模式
- 1.单例模式:饱汉、饿汉。以及饿汉中的延迟加载 2.工厂模式、装饰者模式、观察者模式
网络之数据链路
[牛客] { http://www.nowcoder.com/discuss/3571 }
java 面试题及答案
- [第一部分]{ http://blog.csdn.net/hsk256/article/details/49052293 }
- [第二部分]{ http://blog.csdn.net/hsk256/article/details/49104955 }
- [第三部分]{ http://blog.csdn.net/hsk256/article/details/49363271 }
- [网络编程]{http://www.nowcoder.com/discuss/3814}
数据库性能优化
作者:HAHAYA
链接:https://www.jianshu.com/p/6c078abb720f
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
java基础知识精华的更多相关文章
- [Java面试二]Java基础知识精华部分.
一:java概述(快速浏览): 1991 年Sun公司的James Gosling等人开始开发名称为 Oak 的语言,希望用于控制嵌入在有线电视交换盒.PDA等的微处理器: 1994年将Oak语言更名 ...
- Java基础知识(壹)
写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...
- java基础知识小总结【转】
java基础知识小总结 在一个独立的原始程序里,只能有一个 public 类,却可以有许多 non-public 类.此外,若是在一个 Java 程序中没有一个类是 public,那么该 Java 程 ...
- Java基础知识系列——String
最近晚上没有什么事(主要是不加班有单身),就复习了一下Java的基础知识.我复习Java基础知识主要是依据Java API和The Java™ Tutorials. 今天是第一篇,复习了一下Strin ...
- 学习android学习必备的java基础知识--四大内部类
学习android必备的java基础知识--四大内部类 今天学习android课程,因为我的主专业是JAVA,但是兴趣班却有这其他专业的同学,学习android 需要具备一些java的基础知识,因此就 ...
- JAVA基础知识之网络编程——-网络基础(Java的http get和post请求,多线程下载)
本文主要介绍java.net下为网络编程提供的一些基础包,InetAddress代表一个IP协议对象,可以用来获取IP地址,Host name之类的信息.URL和URLConnect可以用来访问web ...
- java基础知识梳理
java基础知识梳理 1 基本数据类型
- java基础知识回顾之---java String final类普通方法
辞职了,最近一段时间在找工作,把在大二的时候学习java基础知识回顾下,拿出来跟大家分享,如果有问题,欢迎大家的指正. /* * 按照面向对象的思想对字符串进行功能分类. * ...
- Java 基础知识(一)
Java基础知识篇: 一.关键字解释 1. final:修饰非抽象类,非抽象方法和属性, 以及修饰方法参数,代表“无法改变的”.出于对设计或者效率的考虑使用该关键字. final类无法被继承,fina ...
随机推荐
- HDU 6201 transaction transaction transaction(树形DP)
transaction transaction transaction Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 132768/1 ...
- React Native 系列(四)
前言 本系列是基于React Native版本号0.44.3写的.RN支持CSS中的布局属性,因此可以使用CSS布局属性,这里就不详细地讲解了,这篇文章的重点主要是讲述一下RN中的Flex布局. CS ...
- 变量的解构赋值--ES6
1. 数组的解构赋值 基本用法 let [a, b, c] = [1, 2, 3]; let [a,,c] = [1,2,3]; let [a,...b] = [1,2,3]; // a=1; b=[ ...
- BZOJ1019 汉诺塔
定义f[i][j]为将i柱上的j个盘挪走(按优先级)的步数 p[i][j]为将i柱上的j个盘按优先级最先挪至何处 首先考虑一定p[i][j]!=i 设初始为a柱,p[i][j-1]为b柱 考虑两种情况 ...
- luoguP3250 [HNOI2016]网络 树链剖分 + 堆
机房某大佬告诉我,一条链在全局线段树中的区间最多有$log$段 因此同样的,代表不在这条链上的区间同样只有$log$段 对这$log$段区间进行维护即可 为了能够删除,在线段树的每个节点暴力维护一个堆 ...
- bzoj1375 双调路径
Description 来越多,因此选择最佳路径是很现实的问题.城市的道路是双向的,每条道路有固定的旅行时间以及需要支付的费用.路径由连续的道路组成.总时间是各条道路旅行时间的和,总费用是各条道路所支 ...
- ACM -- 算法小结(四)KMP(POJ3461)
KMP -- POJ3461解题报告 问题描述:给出字符串P和字符串T,问字符串P在字符串T中出现的次数 Sample Input 3 BAPC BAPC AZA AZAZAZA VERDI ...
- [转]MinGW编译wxWidgets问题
其实利用MinGW编译wxWidgets是一件挺简单的事情,但是最近在编译的时候遇到一些问题,并找到解决方案,因此在此分享一下个人经验.编译出错的原因是由于安装了MSYS的缘故. 错误信息类似于如 ...
- Transistor latch improves on/off circuitry
Figure 1 shows an example of on/off circuitry commonly used in battery-operated devices. The p-chann ...
- Simple Addition Permits Voltage Control Of DC-DC Converter's Output
http://electronicdesign.com/power/simple-addition-permits-voltage-control-dc-dc-converters-output In ...