本文主要是介绍面试灵魂拷问,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1、什么是多线程?实现多线程的方式?线程池的核心参数?run()和start()方法区别?
1)多线程就是同时执行多个应用程序,需要硬件的支持。简单来说,CPU在多个软件间快速切换,给人同时执行的感觉。
并行:同一时刻,多个指令同时在多个CPU上同时执行;
并发:同一时刻,多个指令在一个CPU上交替执行。
进程:就是一个正在运行的应用软件,比如QQ;
线程:就是应用软件中做的事,比如QQ游戏,阅读。
2)实现多线程的方式:继承Thread类,实现Runnable接口,实现Callnable接口
(通过Callable接口提供的是call方法,来获取返回值对象,是一个Object对象)
3)七个核心参数:
线程池的问题:核心线程满了,最大线程没满,任务队列没满,问来了一个新任务,什么时候开启一个新的线程?
就是个坑!!!!!任务队列没满,就是不会开启一个新线程,当任务队列满了,会去开新线程!!!多线程其他的问题在这张图上!比如,线程什么时候回收,答:任务完成并且大于空闲时间。
4)为什么要重写run()方法?run()和start()方法的区别?
因为run()方法要执行被封装的方法。
run():封装线程执行的代码,相当于普通方法,没有开启线程。
start():开启线程,然后由JVM调用此线程的run()方法。
5)什么情况下使用多线程?
Ⅰ :多用户多请求的高并发的时候使用多线程
Ⅱ :大任务处理起来比较耗时,这时候可以起到多个线程并行加快处理(例如:分片上传)。
2、mysql慢查询是什么?如何优化
超过指定时间的sql查询就叫慢查询!这个功能需要在MySQL的配置文件my.cnf中写上最大等待时间 long_query_time = 10。
就是有因为慢,所以需要优化!!!
比如尽量不用 > < = like %等,这样会进行全表扫描
不用in, 改成between优化
优化数据库结构,在字段很多的表中,将不常用的字段抽出来形成新的表,因为当一个表的数据量很大时,会由于使用频率低的字段的存在而变慢。
3、HashMap、hashtable、cocurrenthashmap的区别?
hashmap是线程不安全的,效率高。
hashtable实际是一个被弃用的类,虽然说是线程安全的,但是它在修改数据的时候会锁住整张哈希表,执行效率低。在多线程进行操作时,基本等同于串行。所以一般推荐线程安全的话,一般推荐cocurrenthashmap,他把整个map分成16个segment,在对一个segment进行写操作时,会把这个segment加锁,其他线程就无法进入这个线程操作,但是其他线程的segment读写并不受影响。相比hashtable,整体性能提高16倍。但是读操作却不会加锁,而是采用volatile这个关键字进行修饰,保证读操作的可见性,保证线程不会读到脏数据。
并发量大的时候推荐使用cocurrenthashmap。
4、hashmap为什么是线程不安全的?
1.多个线程某一时刻同时操作HashMap并执行put,hash值同,需解决 冲突。2.put()方法不是同步的 3.addEntry()方法不是同步的 4.resize()扩容方法不是同步的
5、Springboot和Spring的区别?
Springboot基本上是Spring框架的扩展,内置了tomcat,简化Spring项目的搭设和开发过程,比如配置文件。
6、SpringBoot的自动装配?
Springboot有一个引导类叫SpringBootApplation,在这个类里面有很多注解,@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan
与我们自动装配有关的是@EnableAutoConfiguration这个注解,这个注解里面有个@import注解,里面导入了AutoConfigurationImportSelector这样一个类,在这个类里面有个getCandidateConfigurations方法,这个方法就会找到Meta文件下的spring.factories,在spring.factories里面有很多全路径类名,通过反射加载到ioc容器中
问:spring.factories里面的类都会全部加载吗?不是的,符合条件的才会进行加载!
7、btree和b+tree的区别?
8、synchronized悲观锁能不能同时拥有两把以上?
可以,像在我们的单例模式中,懒汉式(延时加载)就是用了两把悲观锁来保证线程安全。因为只有一把synchronized时,当判断对象是否为null时,如果另一个对象也进来了,就会创建两个对象,违背了单例设计模式的原则。所以在调用getInstance()方法时,在判空方法上也加上一个synchronized。
懒汉式的特点就是延时加载,比如配置文件,就是采用懒汉式的方法。
9、dubbo开发流程和运行流程?
开发流程:导坐标,搭建zookeeper注册中心(注册中心是一个软件)。
@Service(提供方注解),@reference(消费方注解)
运行流程:
提供方启动时向注册中心提供服务,消费方启动向注册中心订阅自己的服务。注册中心向消费方返回提供方的地址(地址变更会推送变更的数据),提供方就可以根据这个地址找到对应的方法调用。
dubbo是基于Rpc调用的,使用rpc协议使得服务器与服务器间的通信效率更高,更方便(因为在OSI网络通信模型中,rpc跨域了传输层和应用层)。
10、zuul和gateway?
zuul是springcloud里面的一个组件,但基本不用了,而是用gateway。注意,gateway不是springcloud里面的,而是spring里面的,因为zuul的研发团队大佬们跳槽,其余大佬们意见不统一,zuul2开发等了两年没结束。spring等不及了,就自己研发了gateway。
11、String字符串的数字如何转成int类型的字符串,不能用工具类?
纯数字字符串遍历每一个字符,然后每一个字符减去 ‘0’ 这个字符,就是对应的数字。--------重点是考察基础掌握!
12、hashcode和equals方法的区别?
hoshcode相等,对象不一定相等。equals相等,对象一定相等。我们不可能每插入一次值,都去比较对象是否相等,如果有1000个数据,现在插入第1001个,要比较1000次?用hashcode就可以快速的定位。
13、jdk1.8的新特性?
lambda表达式、stream流、新的日期API( LocalDate | LocalTime | LocalDateTime
)
14、Linux常用命令有哪些?
linux查看当前正在运行的进程:ps -aux
查看某个进程:ps -ef|grep
杀死某个进程 : kill -9 [ pid ]
查看端口被占用: netstat
查看jvm内存:jstat
15、Spring中bean对象的生命周期?
首先我们需要一个类,如UserService,会去给这个类定义一些属性,这些属性都是在BeanDefinition(比如scope、是否延时加载等)里面的。在Spring启动扫描时,会将Beandefinition对象给放置到Beanfactory里面的beanDefinitionMap里面,等Beanfactory组建完成,Bean工厂后置处理器也执行结束,会进行对象的实例化,给对象进行属性填充(用的比较多的@Autowired)。这时候我们也可以进行一些初始化的操作。当初始化完成可以进行一些其他的操作,比如AOP的切面等等,最后就是调用它的destroy方法销毁。
16、悲观锁和乐观锁
这篇关于面试灵魂拷问的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!