前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java相关技术问答(一)

java相关技术问答(一)

作者头像
老梁
发布2019-09-10 16:51:33
4350
发布2019-09-10 16:51:33
举报
文章被收录于专栏:Java工程师成长之路

网上一些没有标准答案的面试题,我自己做的解答总结,有任何异议可以提出来~^_^,不断更新中...

Springboot除了自动配置与传统的spring还有哪些不同

  1. 传统的springweb项目需要部署在tomcat这样的容器才能运行,springboot集成了tomcat容器,可以直接通过他提供的main方法直接运行,或者打成jar包或war包直接运行
  2. springboot提供了很多第三方打包的插件,可以很方便的引用pom,通过简单配置来集成第三方插件,像redis,jpa等

hashmap线程不安全的出现场景

  1. 在多线程环境下,同时put一个全局的hashmap,此时若hashmap刚好进行扩容,进入rehash方法,线程1执行了一部分然后挂起,被线程2抢走cpu继续运行,可能导致链表的循环引用,当下次get这个key值时,会造成死循环

Object中hashcode方法重写了,equals方法要不要改;equals方法重写了,hashcode方法要不要改?

  1. 首先从原理上将,hashcode存在是为了快速的定位像在hashmap中键值得位置,当hashcode重写,仅仅影响的是不同的键值hashcode值变了,并不影响键值得存取和判重
  2. 但是如果equals方法变了,影响的是值,要判断值是否相同,不止需要equals相同,hashcode也要相同,所以equals变了,hashcode方法也要变

线上服务cpu很高怎么办?可以采取哪些措施?

  1. 首先,top一下,判断哪个进程占用cpu很高
  2. 然后top -Hp pid判断该进行哪个线程最占用cpu,目的是找到哪个方法栈最占用cpu
  3. 找到线程pid后,进行16进制转换
  4. 然后用jstack 进程id | grep 线程id 来打印栈信息,可以找到哪个类或方法占用了最高cpu,就可以去查程序代码的原因

TCP与UDP有什么不同?TCP是如何保证可靠传输的?

  1. TPC是面向连接的,UDP是无连接的
  2. TPC是可靠服务,保证数据完整不丢失,不重复,有序,无差错。UDP不保证数据完整性
  3. TPC是一对一连接,UDP可以有一对一,一对多,多对一,多对多
  4. TCP提供了丢包重试机制,应答机制,有序接收机制保证数据可靠性

网关能够为后端服务带来哪些好处?

  1. 首先是隐藏后端ip地址
  2. 方便进行负载均衡
  3. 提供统一的地址管理,调用监控,安全过滤
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-10-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Springboot除了自动配置与传统的spring还有哪些不同
  • hashmap线程不安全的出现场景
  • Object中hashcode方法重写了,equals方法要不要改;equals方法重写了,hashcode方法要不要改?
  • 线上服务cpu很高怎么办?可以采取哪些措施?
  • TCP与UDP有什么不同?TCP是如何保证可靠传输的?
  • 网关能够为后端服务带来哪些好处?
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档