上篇整理了下后面准备更系统化写的Java编程进阶的思路,如果仅看里面的词,很多同学会觉得都懂,但我真心觉得没有多少人是真懂的,所以简单的想了一些题目,感兴趣的同学们可以来做做看,看看自己的Java编程水平怎么样。

懒得去做小程序了,所以大家就直接回复你的答案吧,我会来一一点评下,友情提醒下,有些题目有点坑。

  1. 基于BIO实现的Server端,当建立了100个连接时,会有多少个线程?如果基于NIO,又会是多少个线程? 为什么?

  2. 通常来说基于NIO实现的Server端,会用多少个线程去处理IO事件,为什么?

  3. 一个典型的客户端集群->LB->服务端集群这样的结构中,如客户端采用连接池,长连接的方式,这种设计你觉得可能会出现什么问题?如果客户端采用的是单个长连接的方式呢?如果有问题,你觉得应该怎么解决?

  4. cglib和Java的动态代理相比,具体有什么不同?

  5. 在基于Netty实现FrameDecoder时,下面两种代码的表现会有什么不同?

    第一种

    private void callDecode(...) {

    List<Object> results = new ArrayList<Object>();

    while (cumulation.readable()) {

    int oldReaderIndex = cumulation.readerIndex();

    Object frame = decode(context, channel, cumulation);

    if (frame == null) {

    if (oldReaderIndex == cumulation.readerIndex())

    break;

    else

    continue;

    }

    else if (oldReaderIndex == cumulation.readerIndex()) {

    throw new IllegalStateException( ".....");

    }

    results.add(frame);

    }

    if(results.size() > 0)

    fireMessageReceived(context, remoteAddress, results);

    }

    第二种

    private void callDecode(...) {

    int oldReaderIndex = cumulation.readerIndex();

    Object frame = decode(context, channel, cumulation);

    if (frame != null)

    fireMessageReceived(context, remoteAddress, frame);

    }

  6. 用Executors.newCachedThreadPool创建的线程池,在运行的过程中有可能产生的风险是?

  7. new ThreadPoolExecutor(10,100,10,TimeUnit.MILLISECONDS,new LinkedBlockingQueue(10));一个这样创建的线程池,当已经有10个任务在运行时,第11个任务提交到此线程池执行的时候会发生什么,为什么?

  8. 实现一个自定义的ThreadFactory的作用通常是?

  9. 除了用Object.wait和Object.notifyAll来实现线程间的交互外,你还会常用哪些来实现?

  10. 为什么ConcurrentHashMap可以在高并发的情况下比HashMap更为高效?

  11. AtomicInteger、AtomicBoolean这些类之所以在高并发时高效,共同的原因是?

  12. 请合理的使用Queue来实现一个高并发的生产/消费的场景,给些核心的代码片段。

  13. 请实现让10个任务同时并发启动,给些代码片段。

  14. 在Java程序运行阶段,可以用什么命令行工具来查看当前Java程序的一些启动参数值,例如Heap Size等。

  15. 用什么命令行工具可以查看运行的Java程序的GC状况,请具体写出命令行格式。

  16. 用什么工具,可以在Java程序运行的情况下跟踪某个方法的执行时间,请求参数信息等,并请解释下工具实现的原理。

  17. 当一个Java程序接收请求,很长时间都没响应的话,通常你会怎么去排查这种问题?

  18. Java进程突然消失了,你会怎么去排查这种问题?

  19. 以下这段代码思路,你觉得在运行时可能会产生的风险是,应该如何改进?

    public List<User> getUsers(String[] userIds){

    // 从数据库查找符合userIds的user记录

    //  将返回的记录组装为User对象,放入List并返回

    }

  20. 以下两种代码,在运行时有什么不同?为什么?

    第一种

    private static final boolean isLoggerDebugEnabled = log.isDebugEnabled();

    public void xx(User user){

    if(isLoggerDebugEnabled){

    log.debug("enter xx method, user id is: " + user.getId());

    }

    }

    第二种

    public void xx(User user){

    log.debug("enter xx method, user id is: " + user.getId());

    }

  21. Java程序为什么通常在刚启动的时候会执行的比较慢,而处理了一些请求后会变快,AOT能带来什么帮助?

  22. Parallel GC、CMS GC、ZGC、Azul Pauseless GC最主要的不同是?背后的原理也请简单描述下?

  23. 请写一段程序,让其运行时的表现为触发5次ygc,然后3次fgc,然后3次ygc,然后1次fgc,请给出代码以及启动参数。

  24. Go的Coroutine和Java的线程机制最主要的不同是?如果Java语言要透明的实现Coroutine,你觉得主要的难点是?

Answer

1、BIO 有100个线程。BIO面向连接,一个连接一个线程,直接从流stream里读写。

NIO 可以只有1个处理线程。NIO面向缓冲区,读写操作的是缓冲区(buffer)。一个连接对应一个channel,不会直接从channel读写,数据都是通过缓冲区处理。

NIO有Selector,通过while循环检查或系统调用通知,检查多个channel的状态是否可读写,所以可以用单线程管理多个channel。

Java IO与NIO:https://juejin.im/post/5af79bcc51882542ad771546

Java NIO 之 Channel(通道):https://juejin.im/post/5af7f01b6fb9a07a9f01a339

2、2*cpu核数 左右

3、长连接建立后一般不会断开,也就是某个client会固定请求到某台server,随着扩容缩容、服务器上下线,会负载不均衡。

解决方法:

A、重启负载高的服务器

B、用短连接

C、不用LB

4、CGLIB通过字节码操作生成代理,能对类做代理。

JDK通过反射接口生成代理,所以被代理类必须有实现接口。

5、X

6、使用SynchronousQueue队列,不会缓存请求,可能导致线程数暴涨。

7、放到阻塞队列里

8、命名线程

9、阻塞队列、

10、ConcurrentHashMap 用分段锁,锁粒度更小

11、使用CAS指令实现原子操作,不需要加锁

12、阻塞队列

13、略

14、ps -ef | grep java

15、jstat -gc pid 5000

16、btrace、Arthas(只用过一次)

17、先看线程

18、查看操作系统/var/log/dmesg日志,通常是OOM导致被OS杀掉进程

19、userIds数组过程,导致处理时间变成,消耗完所有IO线程,服务能力降为0。

措施:限制长度

20、第二种运行时会拼接字符串,对性能有影响

21、刚启动是解释执行还要占用资源并采样镜像JTT编译,AOP在启动后提供最搞笑运行代码

22、略

23、略

24、X

来测试下你的Java编程能力的更多相关文章

  1. 阿里毕玄:来测试下你的Java编程能力

    上篇整理了下后面准备更系统化写的Java编程进阶的思路,如果仅看里面的词,很多同学会觉得都懂,但我真心觉得没有多少人是真懂的,所以简单的想了一些题目,感兴趣的同学们可以来做做看,看看自己的Java编程 ...

  2. JAVA编程能力提升学习图

    阿里大神毕玄整理的关于进阶JAVA的学习体系,知道下...

  3. 零基础从实践出发学java编程【总结篇】

    1.背景 很多人学习java的第一步就是系统的学习java基础语法,有的java基础语法还没学完就崩溃了,确实java基础语法太多太细,而且都是理论,学着让人很懵: 好不容易学完基础语法,又要学框架. ...

  4. 软工+C(11): 从命令行开始逐步培养编程能力(Java)

    上一篇:助教指南,持续更新... // Version: 0.0.4 许多人,所不知道的是,每一种编程语言都有其对应的单元测试框架,对程序在不同阶段的测试环节也概念模糊.在实际动手编写程序许久之后才听 ...

  5. JAVA编程规范(下)

    JAVA编程规范(下) 2016-03-27 6. 代码的格式化 6.1 对代码进行格式化时,要达到的目的 1.     通过代码分割成功能块和便于理解的代码段,使代码更容易阅读和理解: 2.     ...

  6. Java学习笔记(六)——google java编程风格指南(下)

    [前面的话] 年后开始正式上班,计划着想做很多事情,但是总会有这样那样的打扰,不知道是自己要求太高还是自我的奋斗意识不够?接下来好好加油.好好学学技术,好好学习英语,好好学习做点自己喜欢的事情,趁着自 ...

  7. Java编程的逻辑 (93) - 函数式数据处理 (下)

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  8. Java编程的逻辑 (90) - 正则表达式 (下 - 剖析常见表达式)

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  9. Java编程的逻辑 (7) - 如何从乱码中恢复 (下)?

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

随机推荐

  1. JMeter Ultimate Thread Group阶梯式减压

    选择或者搜索Stantard Set标准集, 我们要用的Ultimate Thread Group最终线程组包含在里面: 下载完成之后,JMeter会自动重启. 添加最终线程组: 还是以打开博客园首页 ...

  2. 一起学HBase——总结HBase中的PUT、GET、DELETE操作

    传统的关系型数据库有CRUD增删改查操作,同样对于NoSQL列式数据库也有CRUD操作.本文对HBase中常用的Scan.GET.PUT.DELETE操作的用法做个总结. Put操作 Put相当于传统 ...

  3. net core体系-web应用程序-4asp.net core2.0 项目实战(任务管理系统)-2项目搭建

    系统要求 首先建议采用 Windows 10 专业版/企业版/教育版,且必须是64位操作系统,原因是docker装起来比较方便,Win7装起来比较麻烦,且不确定是否有其他问题(自己没有实践过) 其次W ...

  4. 关于python3.6上传文件时报错:HTTPSConnectionPool(host='***.org', port=443): Max retries exceeded with url: /post (Caused by SSLError(SSLError(1, '[SSL: CERTIFICATE_VERIFY_FAIL解决办法

    第一个报错: 最近在练习post请求中上传文件时遇到了一个奇葩事情,两台电脑上写了一模一样的代码,一个运行正常,另一个一片红. 最后了解了一下原因以及解决办法.先记录下关键代码: files = {& ...

  5. Git permission denied(public key) 解决方法

    1. 在Linux上: # ssh-keygen       ##一定用 id_rsa.pub # cat /root/.ssh/id_rsa.pub 2. copy 整个文件内容到剪切板 3. 打开 ...

  6. 如何配置.Net Core Centos守护进程配置

    一.安装supervisor 运行命令 yum install supervisor 二.配置supervisor 1.运行命令创建文件夹 mkdir -p /etc/supervisor/conf. ...

  7. BZOJ 5104

    这个模数比较有趣 可以求出 $\sqrt{5}$ 然后就可以做了 $f_n=\dfrac{\sqrt{5}}{5}[(\dfrac{\sqrt{5}+1}{2})^n-(\dfrac{1-\sqrt{ ...

  8. org.hibernate.exception.SQLGrammarException: could not extract ResultSet &&&&&Incorrect syntax near '@P0'.

    这个故障的原因比较多: 1.如数据库中的字段和类中的字段类型不一致: 2.数据库dialect不够具体 myeclispe自动生成的是  org.hibernate.dialect.SQLServer ...

  9. Java_String

    整理一下java中关于String的内容.Spring应该是java中使用最频繁的类了,那么今天我们仔细研究下关于Spring的内容. 定义: String类是一个字符串类型的类,使用"   ...

  10. HTML5_canvas_pen.translate()_

    .save() 和 .restore() 除了会保存之前的样式,还会保存之前的坐标轴 pen.translate(x, y); 将画布的 坐标轴原点(0, 0) 从画布的左上角,移动到 (x, y) ...