1.Redis的数据结构有哪些?怎么使用的? String——字符串 Hash——字典 List——列表 Set——集合 Sorted Set——有序集合 2.jvm的内存是如何划分的,各自的存储什么内容
第一块:PC寄存器 PC寄存器是用于存储每个线程下一步将执行的JVM指令,如该方法为native的,则PC寄存器中不存储任何信息。 第二块:JVM栈 JVM栈是线程私有的,每个线程创建的同时都会创建JVM栈,JVM栈中存放的为当前线程中局部基本类型的变量(java中定义的八种基本类型:boolean、char、byte、short、int、long、float、double)、部分的返回结果以及Stack Frame,非基本类型的对象在JVM栈上仅存放一个指向堆上的地址。 第三块:堆(Heap) 它是JVM用来存储对象实例以及数组值的区域,可以认为Java中所有通过new创建的对象的内存都在此分配,Heap中的对象的内存需要等待GC进行回收。 1) 堆是JVM中所有线程共享的,因此在其上进行对象内存的分配均需要进行加锁,这也导致了new对象的开销是比较大的 (2) Sun Hotspot JVM为了提升对象内存分配的效率,对于所创建的线程都会分配一块独立的空间TLAB(Thread Local Allocation Buffer),其大小由JVM根据运行的情况计算而得,在TLAB上分配对象时不需要加锁,因此JVM在给线程的对象分配内存时会尽量的在TLAB上分配,在这种情况下JVM中分配对象内存的性能和C基本是一样高效的,但如果对象过大的话则仍然是直接使用堆空间分配 (3) TLAB仅作用于新生代的Eden Space,因此在编写Java程序时,通常多个小的对象比大的对象分配起来更加高效。 (4) 所有新创建的Object 都将会存储在新生代Yong Generation中。如果Young Generation的数据在一次或多次GC后存活下来,那么将被转移到OldGeneration。新的Object总是创建在Eden Space。 第四块:方法区域(Method Area) (1)在Sun JDK中这块区域对应的为PermanetGeneration,又称为持久代。 (2)方法区域存放了所加载的类的信息(名称、修饰符等)、类中的静态变量、类中定义为final类型的常量、类中的Field信息、类中的方法信息,当开发人员在程序中通过Class对象中的getName、isInterface等方法来获取信息时,这些数据都来源于方法区域,同时方法区域也是全局共享的,在一定的条件下它也会被GC,当方法区域需要使用的内存超过其允许的大小时,会抛出OutOfMemory的错误信息。 第五块:运行时常量池(Runtime Constant Pool) 存放的为类中的固定的常量信息、方法和Field的引用信息等,其空间从方法区域中分配。 第六块:本地方法堆栈(Native Method Stacks) JVM采用本地方法堆栈来支持native方法的执行,此区域用于存储每个native方法调用的状态。3.zookeeper的连接问题
4.cap原理
C - Consistent ,一致性A - Availability ,可用性P - Partition tolerance ,分区容错性分布式系统之所以叫分布式,是因为提供服务的各个节点分布在不同机器上,相互之间通过网络交互。那么必然存在网络故障断开的风险,这个网络断开的专业场景成为网络分区。 CAP一句话就是,在网络分区时,不能同时保证可用性和一致性
5.数据库索引是什么数据结构? B+树
6.什么时候索引会失效?
like “%_” 百分号在前not in ,not exist.B-tree索引 is null不会走,is not null会走,位图索引 is null,is not null 都会走字符型字段为数字时在where条件里不添加引号如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)7.spring的aop怎么用的(使用场景)?
Authentication 权限 Caching 缓存 Context passing 内容传递 Error handling 错误处理 Lazy loading 懒加载 Debugging 调试 logging, tracing, profiling and monitoring 记录跟踪 优化 校准 Performance optimization 性能优化 Persistence 持久化 Resource pooling 资源池 Synchronization 同步 Transactions 事务