想进阿里?先看看这些面试题你会多少

1. junit用法,before,beforeClass,after, afterClass的执行顺序

2. 分布式锁

3. nginx的请求转发算法,如何配置根据权重转发

4. 用hashmap实现redis有什么问题(死锁,死循环,可用ConcurrentHashmap)

5. 线程的状态

5. 线程的阻塞的方式

6. sleep和wait的区别

7. hashmap的底层实现

8. 一万个人抢100个红包,如何实现(不用队列),如何保证2个人不能抢到同一个红包,可用分布式锁

9. java内存模型,垃圾回收机制,不可达算法

10. 两个Integer的引用对象传给一个swap方法在方法内部交换引用,返回后,两个引用的值是否会发现变化


11. aop的底层实现,动态代理是如何动态,假如有100个对象,如何动态的为这100个对象代理

12. 是否用过maven install。 maven test。git(make install是安装本地jar包)

13. tomcat的各种配置,如何配置docBase

14. spring的bean配置的几种方式

15. web.xml的配置

16. spring的监听器。

17. zookeeper的实现机制,有缓存,如何存储注册服务的

18. IO会阻塞吗?readLine是不是阻塞的

19. 用过spring的线程池还是java的线程池?

20. 字符串的格式化方法 (20,21这两个问题问的太低级了)


21. 时间的格式化方法

22. 定时器用什么做的

23. 线程如何退出结束

24. java有哪些锁?乐观锁 悲观锁 synchronized 可重入锁 读写锁,用过reentrantlock吗?reentrantlock与synmchronized的区别

25. ThreadLocal的使用场景

26. java的内存模型,垃圾回收机制

27. 为什么线程执行要调用start而不是直接run(直接run,跟普通方法没什么区别,先调start,run才会作为一个线程方法运行)

28. qmq消息的实现机制(qmq是去哪儿网自己封装的消息队列)

29. 遍历hashmap的三种方式

30. jvm的一些命令



31. memcache和redis的区别

32. mysql的行级锁加在哪个位置

33. ConcurrentHashmap的锁是如何加的?是不是分段越多越好

34. myisam和innodb的区别(innodb是行级锁,myisam是表级锁)

35. mysql其他的性能优化方式

36. linux系统日志在哪里看

37. 如何查看网络进程

38. 统计一个整数的二进制表示中bit为1的个数

39. jvm内存模型,java内存模型

40. 如何把java内存的数据全部dump出来


41. 如何手动触发全量回收垃圾,如何立即触发垃圾回收

42. hashmap如果只有一个写其他全读会出什么问题

43. git rebase

44. mongodb和hbase的区别

45. 如何解决并发问题

46. volatile的用途

47. java线程池(好像之前我的理解有问题)

48. mysql的binlog

49. 代理模式

50. mysql是如何实现事务的


51. 读写分离何时强制要读主库,读哪个从库是通过什么方式决定的,从库的同步mysql用的什么方式

52. mysql的存储引擎

53. mysql的默认隔离级别,其他隔离级别

54. 将一个链表反转(用三个指针,但是每次只发转一个)

55. spring Aop的实现原理,具体说说

56. 何时会内存泄漏,内存泄漏会抛哪些异常

57. 是否用过Autowire注解

58. spring的注入bean的方式

59. sql语句各种条件的执行顺序,如select, where, order by, group by

60. select  xx from xx where xx and xx order by xx limit xx; 如何优化这个(看explain)

欢迎大家加入Java高级架构/互联网:570210627
本群提供免费的学习指导 架构资料 以及免费的解答
不懂得问题都可以在本群提出来 之后还会有职业生涯规划以及面试指导
进群修改群备注:开发年限-地区-经验
方便架构师解答问题

猜你喜欢

转载自blog.csdn.net/qq_41790443/article/details/80574240