广东长荣科技有限公司-Java笔试题

Java工程师笔试题目(限30分钟完成)

一、请参考图片回答以下问题。

二、如何理解面向对象编程?

三、String s = new String("Hello");s = s + " world!";这两行代码执行后,内存是如何变化的?

四、Java中链表、栈、队列如何实现?

五、数据库连接池的工作机制是什么?

六、HttpSession的生命周期?

七、Spring优缺点?Spring、Springboot、Springcloud有和区别?

八、如何实现单点登录,并且保证登录安全?

笔试总结


Java工程师笔试题目(限30分钟完成)

一、请参考图片回答以下问题。

「广东长荣科技有限公司Java面试」面试:Java。总体感觉比较正常,难度是简单题型,感觉没戏。-看准网 (kanzhun.com)icon-default.png?t=M85Bhttps://www.kanzhun.com/firm/interview/detail/1nZ43Nq8EFA~.html?ka=com-interview-card-click1. 如左图,回答相关数据库表设计和sql查询问题:

  1. 请为图中学生选择题设计数据库表结构,存储答题卡模板及标准答案;另外设计一个数据库表存储学生填涂的答案,答案存在单选或多选。
  2. 写出统计每个学生的选择题总分sql。
  3. 写出统计选择题得分最高的前10题和得分最低的前10题。

2. 仔细观察上图中的填空题,每个小题有若干个填入项(如19小题),每个填入项的(如19小题1、2空项)下横线长度存在长短不一。

答:......... 

请回答以下问题:

  1. 设计其在数据库中存储结构。
  2. 如何在网页中解析并显示?(先描述网页设计结构并用伪代码[html\css\js]描述解析过程。)
  3. 假设图片第三大题存在跨页的情况如何处理?

答:..........

二、如何理解面向对象编程?

面向对象编程相对于面向过程而言,关注的是对象可以做那些事情、可以完成那些事情;而面向过程关注的是这个事情的怎么做

面向对象有3个重要的特性——封装、继承、多态。

封装

内部的细节,也就是一个实体类的信息对外界是透明的(不可见)。对于其属性,我们使用private关键字,然后通过get、set方法向提供外界访问方式,这样外界只能按照我们定义的规则来操作该对象。

继承

就是对基类方法做一些改变和扩展,提高代码复用性

多态

父类的引用指定子类对象,提高代码复用性

三、String s = new String("Hello");s = s + " world!";这两行代码执行后,内存是如何变化的?

(1)String s = new String("Hello");

会创建两个对象,首先在常量池中开辟一个空间存字符串“"Hello"”。new String(“”)再会在堆中创建一个空间,它会指向常量池,最后在栈中申请一个变量s,s指向堆内存。

(2)s = s + " world!";

会在常量池中开辟一个空间存字符串" world!",会在堆内存中进行拼接操作,最后s指向这个新的字符串!

四、Java中链表、栈、队列如何实现?

Java中提供了集合容器,顶层的接口是Collection,链表、栈、队列分别是LinkedList(双链表)、Stack、Queue容器去实现的。具体的特性栈(先进后出)、队列(先进先出)

五、数据库连接池的工作机制是什么?

这个和线程池是很类似的。数据库连接池在初始化的时候,会创建一定数量(就是最小连接数

)的SQL连接,放在连接池中;数据库连接池有一个最大连接数和最小连接数。最小连接数不管是否在使用是一直都存在的,若超过了最大连接数,多余的连接请求会被放在等待队列中。

六、HttpSession的生命周期?

HttpSession是JavaWeb用来提供跟踪会话Session用的。它的生命周期从首次访问服务器开始,到用户关闭浏览器(时间片到)结束。

具体来说就是:

  1. 当浏览器首次被访问会像服务器发送会话请求,服务器会为其创建一个HttpSession对象,并分配一个ID
  2. 这个HttpSession会一直在服务器中,服务器会将id发给浏览器
  3. 浏览器根据ID给服务器发信息即可
  4. 一定时间内没有发,服务器会认为浏览器关闭了,服务器会销毁HttpSession对象。

七、Spring优缺点?Spring、Springboot、Springcloud有和区别?

Spring:轻量、IOC、AOP,帮助我们控制bean的生命周期,解耦(简单的说,时间不足)

Spring缺点:迭代了太多版本,不易扩展

八、如何实现单点登录,并且保证登录安全?

答:指的是用户只要登入一次就可以访问服务器中相互信任的模块(不用二次登入)!为用户提供便捷的操作。

实现大致有两种方案

单体项目中可以使用Cookie保存共享的Session,因为只有一个tomcat(时间不够)

分布式的项目中就不能使用上述,因为Tomcat是集群,在集群中Session是不能通信的。所以可以使用Token,使用Redis,key为token,value为用户信息,在搞一个认证模块,在里面完成认证!

笔试总结

不咋地,30min我觉得应该是完不成的,感觉像是HR刷KPI的,**公司 

posted @ 2022-11-16 22:27  金鳞踏雨  阅读(37)  评论(0编辑  收藏  举报  来源