人生第一次面试之依托答辩

server/2025/1/11 22:41:21/

今天收到人生的第一场面试,是东华软件集团。答的那是依托答辩,就面了20分钟,还没考算法。其实依托答辩的效果是意料之中的,这次面试也只是想练练手。

目录

静态变量什么时候加载的?

重写和重载有什么区别?

如何优化sql?

索引过多会怎样?

not in可以用什么代替?

讲一下ArrayList和LinkedList?

讲一下hashmap和treemap?

SpringBoot核心注解?

微服务中gateway的作用?

讲讲mysql中的分页查询?

linux查看进程命令

linux查看日志命令:

对未来有什么规划?

期望实习薪资多少?


自我介绍

“从大一开始学习Java,一路学习Java基础,javaweb,ssm,springboot,springcloud,包括相关中间件,了解设计模式,大三开始准备考研,刚考完研准备找份实习”

静态变量什么时候加载的?

这题没见过,真不会,一下子就慌了,就随便说了句类加载的时候吗?她一听立马换下一道题了。

正确答案:

     Java中的静态变量在类加载阶段被初始化。当Java虚拟机(JVM)加载类时,它会执行类的初始化过程,它包括为静态变量分配内存并赋予默认值或者显示指定的初始值。具体来说,以下事件发生时静态变量会被加载:

    1.首次主动使用类:当程序首次通过以下方式之一访问某个类时,会触发该类的初始化,从而加载静态变量:

     -创建类的实例(即new一个对象)

     -访问类的静态或静态字段

     -使用反射来访问类中的任何成员

     -初始化该类的子类(这会导致父类也被初始化)

     -将该类作为参数传递给java.lang.invoke.Methodhandle.Lookup的查找方法

    -调用某些反射方法,比如Class.forName()加载类时,如果没有指定ClassLoder且该类还未初始化。

   2.静态内部类的加载: 如果静态变量位于静态内部类中,那么这个静态内部类会在其首次引用时加载,即使外部类之前已经加载过。

      静态变量的加载和初始化发生在类的构造器方法中,该方法是由编译器根据类中的静态变量赋值语句和静态代码块自动生成的。这个过程保证了静态变量在类的任何实例(对象)创建之前就已经准备就绪,并且静态变量方法只被初始化一次。

    总结来说,静态变量的加载时机与类的初始化时机紧密相关,是在首次被JVM主动使用时完成的。

重写和重载有什么区别?

我心想坏了,这肯定是刚才答得不好,开始瞧不起我了,大一就知道的题都问出来了。

“重写就是对原来的方法直接重新写过,比如toSrting()方法,本来原来是有一个方法体的,重写之后就会按照你重写的方法进行string格式的编写,重载是通过修改参数的类型和个数以及返回值类型来创建一个同名的方法”,她反问“返回值类型不同也是重载吗”,我答“是啊”。

犯了根本错误:返回值类型不同不是重载!

正确答案:

       方法的重载和重写都是实现多态的方式,区别在于前者实现的是编译时的多态性,而后者实现的是运行时的多态性。重载发生在一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同或者二者都不同)则视为重载;重写发生在子类与父类之间,重写要求子类被重写方法与父类被重写方法有相同的参数列表,有兼容的返回类型,比父类被重写方法更好访问,不能比父类被重写方法声明更多的异常(里氏代换原则)。重载对返回类型没有特殊的要求,不能根据返回类型进行区分。

如何优化sql?

  这道题见过很多次,但是记不起来了。“避免使用联表查询,对于经常使用的列可以建立索引,emm...暂时只能想到这些”

正确答案:

(1)表设计优化

          1.比如设置合适的数值(tinyint int bigint),要根据实际情况选择

          2.比如设置合适的字符串(char和varchar)char定长效率高,varchar可变长度,效率稍低

(2)SQL语句的优化

           1.select语句务必指明字段名称(避免使用select *)

           2.SQL语句要避免造成索引失效的写法

           3.尽量使用union all代替union union会多一次过滤,效率低

            4.避免在where子句中对字段进行表达式操作

             5.jion优化 能用innerjoin就不用left join right join,如果必须使用一定要以小表为驱动,内                    连接会对两个表进行优化,优先把小表放外边,大表放里边。left join或right join不会重                   新调整顺序

索引过多会怎样?

不知道,又是乱说了一句“会导致回表查询效率变慢”

正确答案:

1. 写操作性能下降
插入(INSERT)、更新(UPDATE)、删除(DELETE)等写操作会因为索引的增多而变得更为耗时,因为每次写操作都需要同步更新索引,特别是在频繁写操作的情况下。

2. 存储空间占用增加
每个索引都需要占用一定的存储空间,当索引过多时,会占用大量的存储空间,增加数据库的整体存储需求。

3. 查询性能下降
虽然索引可以加速查询操作,但过多的索引可能会导致索引的失效,使得数据库优化器很难选择到最合适的索引,从而导致查询性能下降。此外,索引过多也可能导致索引之间相互竞争,加剧查询性能下降。

4. 索引维护成本增加
随着索引数量的增加,数据库的索引维护成本也会相应增加。维护成本包括索引的创建、更新、重建和删除等操作,可能需要消耗较多的系统资源和时间。

5. 索引选择困难
当存在大量的索引时,数据库优化器在选择最佳的索引时可能会变得更加困难,这可能导致查询执行计划的选择不够有效,进而影响查询性能。

因此,合理地设计和维护索引对于数据库的性能是非常重要的,应尽量避免过多的索引,而是根据实际的查询需求和数据访问模式选择合适的索引来优化数据库性能。

not in可以用什么代替?

“不知道”

正确答案:

1.使用 LEFT JOIN 和 IS NULL

第一种替代方案是使用 LEFT JOIN 和 IS NULL。我们可以通过将要排除的值列表作为另一张表的数据,然后通过 LEFT JOIN 操作将两张表连接起来,最后使用 IS NULL 来获取不在列表中的值。

SELECT employee.id, employee.name
FROM employee
LEFT JOIN terminated_employee
ON employee.id = terminated_employee.id
WHERE terminated_employee.id IS NULL;

2.使用 NOT EXISTS

NOT EXISTS 是一种条件表达式,用于判断一个子查询的结果是否为空。我们可以使用 NOT EXISTS 来排除某个表中的一组值。

SELECT *
FROM orders o
WHERE NOT EXISTS (SELECT *FROM excluded_products eWHERE o.product_id = e.product_id
);

3.使用 LEFT JOIN 和 CASE WHEN

第三种替代方案是使用 LEFT JOIN 和 CASE WHEN。我们可以通过将要排除的值列表作为另一张表的数据,然后通过 LEFT JOIN 操作将两张表连接起来,最后使用 CASE WHEN 来判断列表中的值是否为空,进而实现排除的效果。

讲一下ArrayList和LinkedList?

终于到一道会的题了,“Arraylist底层是动态数组,LinkedList底层是双向链表,所以ArrayList可以用下标访问,而LinkedList不能用下标访问,查询时间复杂度为O(n),但ArrayList的删除和添加需要移动元素,时间复杂度为O(n),LinkedList只用改指针效率更高,所以经常访问的数据适合用ArrayList经常删除和添加的数据适合用LinkedList,他们都是线程不安全的"

这道题正确答案和这差不多

讲一下hashmap和treemap?

hashmap知道,treemap不知道。“hashmap底层是数组加链表,当链表长度大于8且数组长度大于64是链表会变成红黑树,treepmap底层是数组加树(treemap完全乱说的)”

正确答案:

1.相同点
首先,它们都是Java集合框架中的重要成员,都实现了Map接口,因此具有Map接口的基本功能,如存储键值对、根据键查找值等。

其次,它们都能够存储null键和null值(尽管在实际应用中,HashMap对null键和null值的处理更为宽松,而TreeMap则会在某些情况下抛出异常)。

最后,它们都是线程不安全的,如果在多线程环境下使用,需要额外的同步措施来保证线程安全。

2.不同点

(1)存储结构:
HashMap采用了哈希表的结构,通过哈希函数将键映射到表中的某个位置。这种结构使得HashMap在查找、插入和删除操作上都有着极高的效率,但同时也意味着它无法保持数据的有序性。而TreeMap则采用了红黑树的结构,通过比较器对键进行排序。这种结构使得TreeMap在保持数据有序性的同时,也能够在一定程度上保证查找、插入和删除操作的效率。

(2)时间复杂度:
HashMap的查找、插入和删除操作的时间复杂度都是O(1)(在理想情况下,即哈希函数分布均匀且没有哈希冲突时)。然而,在实际应用中,由于哈希冲突和链表或红黑树转换的影响,这些操作的时间复杂度可能会上升到O(n)。相比之下,TreeMap的查找、插入和删除操作的时间复杂度都是O(log n),因为它需要维护红黑树的平衡性。

(3)有序性:
正如前面所说,HashMap是无序的,它无法根据键的自然顺序或自定义比较器对键值对进行排序。而TreeMap则是有序的,它可以根据键的自然顺序或自定义比较器对键值对进行排序。这种有序性使得TreeMap在需要保持数据有序性的场合中更加适用。

SpringBoot核心注解?

没听过springboot核心注解,讲了一些常见的注解什么controller,mappaing,congfiguration,autowired,value等等

正确答案:

1.@SpringBootConfiguration
声明为配置类(根配置类,首先扫描该类,本身是一个IOC容器的配置类),将当前类内声明的一个或多个以@Bean注解标记的方法的实例纳入到spring容器中,并且实例名就是方法名。
SpringBoot使用Java Config技术进行配置,Java Config使用注解和Java代码的方式代替xml配置文件

  • 任何一个标注了@Configuration的Java类定义都是一个JavaConfig配置类。
  • 任何一个标注了@Bean的方法,其返回值将作为一个bean定义注册到Spring的IoC容器,方法名将默认成该bean定义的id

2.@ComponentScan

自动扫描当前包及子包下被@Component,@Controller,@Service,@Repository注解标记的类,将其作为bean加载到IOC容器中。
不指定范围则默认从注解所在类的包下进行扫描。

3.@EnableAutoConfiguration

核心注解,是自动配置的入口,SpringBoot根据添加的jar包来进行项目的默认配置

微服务中gateway的作用?

“将不同请求转发到对应的微服务上“

正确答案:

1.路由转发

在spring cloud gateway中我们可以自定义路由,将请求根据不同的路径或条件转到相应的下游服务中去。这对整个微服务架构中的服务管理来说非常简单、高效。

2.负载均衡
因为网关是做路由转发的,所以在网关中可以很方便的实现负载均衡。Spring Cloud官方默认的是采用spring-cloud-loadbalancer组件,如上面的代码中uri: lb://customer-service, 就是采用默认的负载均衡算法,请求到customer-service集群。

3.统一鉴权
在gateway中我们可以集成spring security和JWT等安全框架,进行统一的登录和鉴权。在网关中任何一个请求,我们都会先判断当前请求的用户是否已经登录,如果没有登录则会路由到登录页面进行登录,如果已经登录了则会继续鉴权,判断当前用户是否有访问该接口的权限,如果鉴权成功则会将请求路由给对应的服务进行处理。

4.流量的过滤
就像之前的统一鉴权一样,我们也可以基于网关做一些流量的过滤,比如一些恶意流量的过滤、黑名单的过滤。

5.限流降级
在网关中我们还可以做限流降级,目前官方推荐我们使用resilience4j组件来进行限流。这样我们就可以在网关层面进行流量的统一管控,从而避免大量的流量压垮我们的服务集群。

6.解决跨域的问题
在微服务架构中,我们的服务通常都会分布在不同的域中。Spring Cloud Gateway提供了跨越请求支持,使得不同域中的服务可以进行安全的通讯。

spring cloud gateway就是一个流量的统一入口,所以它能做很多事情,如路由转发、负载均衡、统一鉴权和限流等保护服务的机制。

但是,另外一方面作为所有流量的入口,网关会处理大量的请求,容易成为我们系统的瓶颈。所以,我们需要对资源进行合理的分配,做好网关应用的监控,如发现异常需及时进行处理。

讲讲mysql中的分页查询?

“利用limit关键字,要传两个参数,一个是每页的数据条数,总的数据条数,底层不太了解”

大错特错!

正确答案:

select * from table order by id limit m, n;

查询m+n条记录,去掉前m条,返回后n条。无疑该查询能够实现分页,但m越大,查询性能就越低,因为MySQL需要扫描全部m+n条记录。

SELECT * FROM table_name ORDER BY id LIMIT 10 OFFSET 1000;

查询返回从第1001条记录开始的10条记录。这种方法在数据量小或中等时效果良好,但在数据量非常大的情况下,性能会显著下降。

linux查看进程命令

“不知道”

正确答案:

1.静态查看进程

ps aux #查看进程使用情况
ps aux | less # 查看进程使用情况,考虑到显示过多,使用分管符和less命令查看
ps aux --sort CPU #查看进程使用情况,并按照CPU的使用率升序排列
ps aux --sort -CPU #查看进程使用情况,并按照CPU的使用率降序排列
ps aux --sort rss #查看进程使用情况,并按照内存的使用升序排列
ps aux --sort -rss  #查看进程使用情况,并按照内存的使用降序排列
ps -ef | grep XXX #查看指定的进程是否开启
ps axo user,pid,ppid……  #查看进程,并且只查看后面列举出的信息

2.动态查看进程

top命令可以动态查看进程,top命令常用参数如下:
-d 表示刷新的时间间隔,单位为s
-p 表示查看指定PID的进程
-u 表示查看指定用户的进程
-n 表示top刷新指定次数后退出

top -d 1
top -p 100
top -n 3 >123.txt
top -u nginx

linux查看日志命令:

“不知道,linux命令这块实在不太了解”

正确答案:

1tail

tail -n 10 test.log 查询日志尾部最后10行的日志;
tail -n +10 test.log 查询10行之后的所有日志;
tail -fn 10 test.log 循环实时查看最后1000行记录(最常用的)
tail -fn 1000 test.log | grep '关键字'
tail -n 4700 aa.log |more -1000 可以进行多屏显示(ctrl + f 或者 空格键可以快捷键)

 2、less

less log.log
shift + G 命令到文件尾部 然后输入 ?加上你要搜索的关键字例如 ?1213
按 n 向上查找关键字
shift+n 反向查找关键字
less与more类似,使用less可以随意浏览文件,而more仅能向前移动,不能向后移动,而且 less 在查
看之前不会加载整个文件。
less log2013.log 查看文件
ps -ef | less ps查看进程信息并通过less分页显示
history | less 查看命令历史使用记录并通过less分页显示
less log2013.log log2014.log 浏览多个文件

参数:

less与more类似,使用less可以随意浏览文件,而more仅能向前移动,不能向后移动,而且 less 在查
看之前不会加载整个文件。
less log2013.log 查看文件
ps -ef | less ps查看进程信息并通过less分页显示
history | less 查看命令历史使用记录并通过less分页显示
less log2013.log log2014.log 浏览多个文件
常用命令参数:
-b <缓冲区大小> 设置缓冲区的大小
-g 只标志最后搜索的关键词
-i 忽略搜索时的大小写
-m 显示类似more命令的百分比
-N 显示每行的行号
-o <文件名> 将less 输出的内容在指定文件中保存起来
-Q 不使用警告音
-s 显示连续空行为一行
/字符串:向下搜索"字符串"的功能
?字符串:向上搜索"字符串"的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
b 向后翻一页
h 显示帮助界面
q 退出less 命令

3.vi

vi test.log 
命令模式下敲斜杆( / ) 
屏幕右下角出现了 "/" 
然后输入你要查找的关键字敲回车就可以了。 
如果你要继续查找此关键字,敲字符 n 就可以继续查找了。
敲字符N(大写N)就会向前查询;如何退出查询:
按住 Esc 然后 :q!  

对未来有什么规划?

 “赶紧找个实习,后面好找工作”

期望实习薪资多少?

“只要能活就行,2千3千都行”

面试结束“。“啊,不考道算法吗”。“不用了,一周之内面试通过会给你打电话”,“好的,谢谢,这是我第一次面试,我知道效果不好,这也意料之中,感谢您和您公司给我一次面试的机会,谢谢。”“好的,再见”。


http://www.ppmy.cn/server/157293.html

相关文章

配置graspness虚拟环境

配置graspness虚拟环境并复现 通过conda建立虚拟环境安装MinkowskiEngine(ME)配置cuda安装nvcc等工具ME版本下载0.5.4版本的!!!安装pointnet2、knn把GraspNet-1Billion数据集下载并按着官方format排版(数据集总共大概100G)并训练模型通过conda建立虚拟环境 graspness工…

何为“正则表达式”!

详细解释&#xff1a; ^&#xff1a;在JSON的正则表达式中&#xff0c;^表示匹配输入字符串的开始位置。这意味着正则表达式将从字符串的开头开始进行匹配&#xff0c;确保整个字符串符合后续的模式要求。例如&#xff0c;对于字符串"3.14"&#xff0c;正则表达式会…

【Notepad++】Notepad++如何删除包含某个字符串所在的行

Notepad如何删除包含某个字符串所在的行 一&#xff0c;简介二&#xff0c;操作方法三&#xff0c;总结 一&#xff0c;简介 在使用beyoundcompare软件进行对比的时候&#xff0c;常常会出现一些无关紧要的地方&#xff0c;且所在行的内容是变化的&#xff0c;不方便进行比较&…

《机器学习》——贝叶斯算法

贝叶斯简介 贝叶斯公式&#xff0c;又称贝叶斯定理、贝叶斯法则&#xff0c;最初是用来描述两个事件的条件概率间的关系的公式&#xff0c;后来被人们发现具有很深刻的实际意义和应用价值。该公式的实际内涵是&#xff0c;支持某项属性的事件发生得愈多&#xff0c;则该属性成…

ChatGPT加速器:解锁高效智能对话的新工具

随着人工智能技术的飞速发展&#xff0c;智能对话系统如ChatGPT已经在各个领域得到了广泛的应用。无论是在客户服务、教育辅导&#xff0c;还是创意写作中&#xff0c;ChatGPT都表现出了强大的能力。然而&#xff0c;在一些特定的网络环境下&#xff0c;用户访问ChatGPT时可能遇…

【Linux】Linux命令

目录 ​编辑 系统维护命令 man man&#xff1a;查看 man 手册 sudo passwd 用户名&#xff1a;修改用户密码 su&#xff1a;切换用户 echo ”输出内容“&#xff1a;向终端输出内容&#xff0c;默认换行 date查看当前系统的日期 clear&#xff1a;清屏 df -Th /df -h&…

Leetcode 300. 最长递增子序列 动态规划 / 贪心 + 二分查找

原文链接&#xff1a;Leetcode 300. 最长递增子序列 class Solution { public:int lengthOfLIS(vector<int>& nums) {int n nums.size();// dp[i]表示以nums[i]结尾的严格递增子序列的长度int dp[n];dp[0] 1;int res 1;for (int i 1; i < n; i) {dp[i] 1;f…

如何修复三方库bug:marked.js 15.0.6 bug修复经过

marked一个非常流行的markdown格式解析器。 它在npmjs上的周下载量达500万之巨。 在其最新的version 15.0.6版本&#xff08;2025年1月8日使用&#xff09;&#xff0c;有处小bug&#xff1a;当在窄屏显示状态下&#xff0c;如手机端。代码会超出所在div&#xff0c;超出部分内…