• 关于技术索引


    一.Java基础知识

    String、Integer、Long、Enum、BigDecimal、ThreadLocal、ClassLoader、URLClassLoader、ArrayList、 LinkedList。
    HashMap、LinkedHashMap、TreeMap、CouncurrentHashMap、HashSet、LinkedHashSet、TreeSet。
    Java String的使用。replaceFirst、replaceAll、replace区别,String对“+”的重载,字符串的不可变性。
    JDK 6和JDK 7中substring的原理及区别。
    自动拆装箱:Integer的缓存机制。
    熟悉Java中各种关键字:transient、instanceof、volatile、synchronized、final、static、const 原理及用法。
    ArrayList和LinkedList和Vector的区别。List和Vector的区别。
    HashMap、HashTable、ConcurrentHashMap区别。apache集合处理工具类的使用。
    不同版本的JDK中HashMap的实现的区别以及原因。
    枚举:枚举的用法、枚举与单例、Enum类。
    Java IO,Java bio、nio和aio的区别、三种IO的用法与原理、netty并学会使用。
    Java反射与javassist。反射与工厂模式、 java.lang.reflect.*Java序列化:什么是序列化与反序列化、为什么序列化。序列化底层原理。序列化与单例模式。protobuf。为什么说序列化并不安全。
    注解:元注解、自定义注解、Java中常用注解使用、注解与反射的结合。
    JMS:什么是Java消息服务、JMS消息传送模型。
    JMX:java.lang.management.*、 javax.management.*
    泛型。泛型与继承。类型擦除。泛型中K T V E。
    object等的含义、泛型各种用法。
    单元测试:junit、mock、mockito、内存数据库(h2)。
    正则表达式:java.lang.util.regex.*
    常用的Java工具库:commons.lang, commons.*... guava-libraries netty
    什么是API&SPI。
    异常:异常类型、正确处理异常、自定义异常。
    时间处理:时区、时令、Java中时间API。
    编码方式:解决乱码问题、常用编码方式。
    语法糖:Java中语法糖原理、解语法糖。
    Java 8:lambda表达式、Stream API。
    Java 9:Jigsaw、Jshell、Reactive Streams。
    Java 10:局部变量类型推断、G1的并行Full GC、ThreadLocal握手机制。

     

    二.Java并发编程

    什么是线程,与进程的区别。
    Thread、Runnable、Callable、ReentrantLock、ReentrantReadWriteLock、Atomic*、Semaphore、CountDownLatch、、ConcurrentHashMap、Executors。
    线程池:自己设计线程池、submit() 和 execute()。
    线程安全:死锁、死锁如何排查、Java线程调度、线程安全和内存模型的关系。
    锁:CAS、乐观锁与悲观锁、数据库相关锁机制、分布式锁、偏向锁、轻量级锁、重量级锁、monitor、锁优化、锁消除、锁粗化、自旋锁、可重入锁、阻塞锁、死锁。
    volatile。happens-before、编译器指令重排和CPU指令重。
    synchronized:synchronized是如何实现的?synchronized和lock之间关系。不使用synchronized如何实现一个线程安全的单例。
    sleep 和 wait。wait 和 notify。notify 和 notifyAll。ThreadLocal。
    写一个死锁的程序。写代码来解决生产者消费者问题。守护线程:守护线程和非守护线程的区别以及用法。原子操作类和CAS;
    Lock,Condition和显示锁;
    AbstractQueuedSynchronizer分析;
    并发工具类和并发容器;
    线程池和Executor框架;
    实现原理和Java内存模型;
    线程安全;

     

    三.JVM

    JVM内存结构:堆、栈、方法区、直接内存、堆和栈区别。
    Java内存模型:内存可见性、重排序、顺序一致性、volatile、锁、final垃圾回收:内存分配策略、垃圾收集器(G1)、GC算法、GC参数、对象存活的判定。
    JVM参数及调优。
    Java对象模型:oop-klass、对象头。
    HotSpot:即时编译器、编译优化。
    类加载机制:classLoader、类加载过程、双亲委派(破坏双亲委派)、模块化(jboss modules、osgi、jigsaw)。
    虚拟机性能监控与故障处理工具:jps, jstack, jmap、jstat, jconsole, jinfo, jhat, javap, btrace、Tprofiler。
    编译与反编译:javac 、javap 、jad 、CRF。
    使用工具:VisualVM。
    JVM的内存模型分析?
    jvm运行时数据区?
    jvm性能监控工具?
    jvm的堆和栈是如何工作的?
    JVM内存管理机制:内存区域与内存溢出异常:运行时数据区域:程序计数器,虚拟机栈,本地方法栈,虚拟机对象;
    垃圾收集器与内存分配策略:垃圾回收算法与基础,窜行收集器,并行收集器,内存分配与回收策略;
    JVM执行子系统:类文件结构,类加载机制,字节码执行引擎
    程序编译与代码优化:编译期优化,运行期优化
    字节码、class文件格式
    CPU缓存,L1,L2,L3和伪共享
    尾递归。位运算。用位运算实现加、减、乘、除、取余。
    设计模式:了解23种设计模式。
    实现AOP,实现IOC。不用synchronized和lock,实现线程安全的单例模式。nio和reactor设计模式。
    网络编程。tcp、udp、http、https等常用协议。三次握手与四次关闭、流量控制和拥塞控制、OSI七层模型、tcp粘包与拆包。
    http/1.0 http/1.1 http/2之前的区别。Java RMI,Socket,HttpClient。
    cookie 与 session。cookie被禁用,如何实现session。
    使用单例、使用Future模式、使用线程池、选择就绪、减少上下文切换、减少锁粒度、数据压缩、结果缓存
    线上问题分析:dump获取:线程Dump、内存Dump、gc情况。dump分析:分析死锁、分析内存泄露。
    自己编写各种outofmemory,stackoverflow程序:
    HeapOutOfMemory、 Young OutOfMemory、MethodArea OutOfMemory、ConstantPool OutOfMemory、DirectMemory OutOfMemory、Stack OutOfMemory Stack OverFlow。
    常见问题解决思路:内存溢出、线程死锁、类加载冲突。
    使用工具尝试解决以下问题,并写下总结:当一个Java程序响应很慢时如何查找问题、当一个Java程序频繁FullGC时如何解决问题、
    如何查看垃圾回收日志、当一个Java应用发生OutOfMemory时该如何解决、如何判断是否出现死锁、如何判断是否存在内存泄露
    用Java写一个简单的静态文件的HTTP服务器。实现客户端缓存功能,支持返回304 实现可并发下载一个文件 
    使用线程池处理客户端请求,使用nio处理客户端请求 支持简单的rewrite规则 上述功能在实现的时候需要满足“开闭原则”。 编译与反编译;Java代码的编译与反编译;Java的反编译工具;词法分析,语法分析(LL算法,递归下降算法,LR算法),语义分析,运行时环境,中间代码,代码生成,代码优化。

     

    四.框架

    Servlet线程安全问题。Servlet中的filter和listener。
    Hibernate的缓存机制。Hiberate的懒加载。
    Spring Bean的初始化。Spring的AOP原理。自己实现Spring的IOC。
    Spring MVC。Spring Boot2.0Spring Boot的starter原理,自己实现一个starter。
    Spring Security
    应用服务器:JBoss,tomcat,jetty,Weblogic,Undertow。
    Spring 5:响应式编程。
    Spring Boot 2.0:性能优化

    五.数据库

    MySql 执行引擎;MySQL 执行计划;如何查看执行计划,如何根据执行计划进行SQL优化。
    事务事务的隔离级别、事务能不能实现锁的功能。
    数据库锁:行锁、表锁、使用数据库锁实现乐观锁。
    数据库主备搭建,binlog,内存数据库,h2。
    常用的nosql数据库:redis、memcached。
    分别使用数据库锁、NoSql实现分布式锁。性能调优。
    简单的数据结构:栈、队列、链表、数组、哈希表、
    树:二叉树、字典树、平衡树、排序树、B树、B+树、R树、多路树、红黑树。
    排序算法:各种排序算法和时间复杂度 深度优先和广度优先搜索 全排列、贪心算法、KMP算法、hash算法、海量数据处理。
    Solr,Lucene,ElasticSearch。
     

    六.其他

    了解nginx和apache服务器的特性并搭建一个对应的服务器。
    用Java实现FTP、SMTP协议。
    进程间通讯的方式。
    什么是CDN?如果实现?什么是DNS?反向代理。

    工具:git & svn,maven & gradle。
    Linux的常用命令;进程同步;缓冲区溢出;分段和分页;虚拟内存与主存;Zookeeper:基本概念、常见用法。Storm,流式计算,了解Spark,S4。 在linux上部署storm,用zookeeper做协调,运行storm hello world,local和remote模式运行调试storm topology。 Hadoop,离线计算HDFS、MapReduce。 分布式日志收集flume,kafka,logstash。 数据挖掘,mahout。什么是XSS:XSS的防御。 什么是CSRF。什么是注入攻击。SQL注入、XML注入、CRLF注入。 什么是文件上传漏洞。 加密与解密。MD5,SHA1、DES、AES、RSA、DSA。 什么是DOS攻击和DDOS攻击。 memcached为什么可以导致DDos攻击、什么是反射型DDoS。 SSL、TLS,HTTPS。 如何通过Hash碰撞进行DOS攻击。 用openssl签一个证书部署到apache或nginx。 数据一致性、服务治理、服务降级。 分布式事务:2PC、3PC、CAP、BASE、 可靠消息最终一致性、最大努力通知、TCC。 Dubbo:服务注册、服务发现,服务治理。 分布式数据库:怎样打造一个分布式数据库、什么时候需要分布式数据库、mycat、otter、HBase。 分布式文件系统:mfs、fastdfs。 分布式缓存:缓存一致性、缓存命中率、缓存冗余。 SOA、康威定律。 ServiceMesh。 Docker & Kubernets CDN技术 监控什么:CPU、内存、磁盘I/O、网络I/O等。 监控手段:进程监控、语义监控、机器资源监控、数据波动。监控数据采集。日志、埋点。 Dapper。 负载均衡。tomcat负载均衡、Nginx负载均衡。 DNS:DNS原理、DNS的设计。 扩展篇云计算:IaaS、SaaS、PaaS、虚拟化技术、openstack、Serverlsess。 搜索引擎:Solr、Lucene、Nutch、Elasticsearch。 权限管理:Shiro。 哈希算法、Merkle树、公钥密码算法、共识算法、Raft协议、Paxos 算法与 Raft 算法、拜占庭问题与算法、消息认证码与数字签名。 比特币:挖矿、共识机制、闪电网络、侧链、热点问题、分叉。 以太坊,超级账本,人工智能。 数学基础、机器学习、人工神经网络、深度学习、应用场景。 常用框架:TensorFlow、DeepLearning4J 其他语言:Groovy、Python、Go、NodeJs、Swift、Rust,groovy,cassandra,Protobuf,WebWork 了解Hadoop+Zookeeper+Flume+Hive+HDFS大数据离线数据分析,能够实现网站的pv,uv,vv,br等数据监控分析,并且也了解Storm+Kafka的实时数据分析。 Spark MLlib SonarQube DCDB技术; 任务调度技术; elog技术; eMonitor技术;(监控系统) epaas技术;(容器云) MySQL延迟问题和数据刷盘策略 CQRS
  • 相关阅读:
    2015 多校联赛 ——HDU5389(dp)
    spring MVC配置详解
    面试题整理11
    面试题整理09
    Spring和SpringMVC的区别
    SpringMVC01
    js中typeof与instanceof用法小记
    Java 可变参数
    log4j文件的配置
    Hibernate 分组查询 子查询 原生SQL
  • 原文地址:https://www.cnblogs.com/ZJOE80/p/12753792.html
Copyright © 2020-2023  润新知