1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Java高级面试题!传智播客java基础入门pdf

Java高级面试题!传智播客java基础入门pdf

时间:2019-10-19 02:22:40

相关推荐

Java高级面试题!传智播客java基础入门pdf

流程描述

我们从bind函数开始:

1、首先创建了两个NioEventLoopGroup,这是初始化了两个线程组,这两个线程组根据命名可以知道一个是bossGroup,是服务器用来接收客户端的请求的,另一个是workGroup是用来处理NioServerSocketChannel的网络读写的。这两个线程组实际承担的是一个Reactor的角色。

2、第二步就是初始化一个ServerBootstrap,这是Netty用于启动NIO服务端的辅助启动类,目的是降低服务器开发的复杂度。ServerBootstrap的初始化首先是调用group方法,将两个线程组作为参数传到ServerBootstrap中。接着创建channel为NioServerSocketChannel。然后调用option配置channel的TCP参数,其中SO_BACKLOG设置为1024的意思是服务器监听队列的大小是1024,最后设置处理IO事件的处理器ChildChannelHandler,它的作用类似于Rector模式中的handler用来处理IO事件。

3、启动类初始化完成后调用ServerBootstrap的bind方法绑定端口,监听请求,在调用sync等待绑定完成。完成之后返回一个ChannelFuture作用是用于异步操作的通知回调。

4、调用 future.channel().closeFuture().sync进行阻塞,等待服务端链路关闭main函数退出。

5、调用EventLoopGroup的shutdownGracefully方法,释放相关的资源。

Netty的线程模型

netty是一个高可用的基于事件驱动的异步的NIO框架,核心的线程模型是Reactor,Reactor线程模型有单线程Reactor,多线程Reactor和多线程主从复制的Reactor,这里我们就用最简单的单线程Reactor来分析下Netty的线程模型,进而来看Netty的相关核心类在此模型下扮演的角色和作用。

在网络交互中,无论你是建立连接进行通信还是数据的读写都是继续网络通信协议的,底层就是TCP/IP协议栈,协议栈是操作系统层的,我们无法修改他的协议栈,但是操作系统给了我们可以操作和使用协议栈的接口,比如我们经常使用的bind、accept、connect等,而这写操作的本身,我们都是对socket的操作,所以我们可以任务一个socket,就是用户跟TCP/IP协议栈进行交互的门户。

传统的IO

一请求一应答,这是BIO。每次读写都需要生成新的线程,请求多的时候占用大量的线程资源。高并发的情况下很可能造成巨大的线上故障。

NIO Reactor模型

socket注册到Selector中,由Selector决策哪个事件可以执行。

Netty的线程模型

服务器的线程模型为例:

抽象出NioEventLoop来表示一个不断循环执行处理任务的线程,每个NioEventLoop有一个selector,用于监听绑定在其上的socket链路。服务端维护了两个EventLoopGroup,一个bossGroup,一个workGroup,bossGroup用来处理客户端的连接请求,然后打开Channel,把这个Channel交给workGroup中的一个EventLoop被注册来处理该Channel上的所有请求。一个Channel只会被一个workGroup处理,一个workGroup可以同时被多个Channel使用。

简单了解了Netty的一个线程模型,我们来看看netty编程中那些核心类的作用。

Netty架构

核心类分析

EventLoop

EventLoop是Netty中极其重要的组件,翻译为时间循环,一个EventLoop被分配给Channel来负责这个Cahnnel上的所有事件。EventLoop你可以理解为一个线程,EventLoopGroup是一个线程池,EventLoopGroup继承ScheduledExecutorService,也就是调度线程池,理论上EventLoopGroup应该具有ScheduledExecutorService的所有的功能,之所以叫做事件循环,我猜想它必然有一个循环把Cahnnel上面准备就绪的事件提交给一个Thread来处理。这个实现在SingleThreadEventLoop的一个继承类EpollEventLoop中的run方法实现

最后的内容

在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)

如何准备面试?

1、前期铺垫(技术沉积)

程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。

下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问,有需要的话就戳这里:蓝色传送门打包带走吧。

这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!

Java程序员必看《Java开发核心笔记(华山版)》 Redis学习笔记 Java并发编程学习笔记

四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇

Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版) 大厂面试必问——数据结构与算法汇集笔记

其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。

2、狂刷面试题

技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。

①大厂高频45道笔试题(智商题)

②BAT大厂面试总结(部分内容截图)

③面试总结

3、结合实际,修改简历

程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。

战累计的,千万不要临时抱佛脚。

另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。

以上文章中,提及到的所有的笔记内容、面试题等资料,均可以免费分享给大家学习,有需要的话就戳这里打包带走吧。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。