java——2024-03-03

  1. String类的对象能被修改吗?如果不能需要用什么修改?StringBuilder和StringBuffer的区别?
  2. equals和==区别
  3. 谈谈对面向对象的理解
  4. 重载和重写的区别
  5. 说一下ArrayList,LinkedList底层实现以及区别
  6. 什么是哈希冲突?
  7. hashMap和conCurrentHashMap的区别
  8. hashcode() 与 equals() 的区别与联系
  9. 快排的思想
  10. 什么是死锁?怎么解决?
  11. MySQL事务的四大特性
  12. varchar和char的区别?里面的参数代表什么?
  13. 讲一下数据库的索引(什么是索引?索引的基本原理 索引类型 索引的优缺点)
  14. 三次握手
  15. 建立连接可以两次握手吗,为什么不可以?
  16. TCP、UDP的区别
  17. 垃圾回收的算法有哪些?
  18. wait()和sleep()的区别
  19. volatile关键字

重载(Overloading)指的是在同一个类中,可以定义多个方法具有相同的名字,但是参数列表不同(参数类型、个数或顺序)。在调用这些方法时,编译器会根据传入的参数来选择最匹配的方法进行调用。通过方法重载,可以实现一组功能类似但参数不同的方法。

重写(Overriding)指的是子类重新定义(覆盖)其父类中具有相同签名的方法。在继承关系中,当子类需要改变父类的方法实现时,可以使用方法重写。子类的访问权限修饰符不能比父类更严格。重写的方法具有相同的方法名、返回类型和参数列表,子类可以通过重写方法来提供特定于子类的实现。

17

http://t.csdnimg.cn/ZJOz5icon-default.png?t=N7T8http://t.csdnimg.cn/ZJOz5

  1. 引用计数:通过跟踪每个对象被引用的次数来确定何时释放内存。当对象的引用计数减为0时,表示没有指针指向该对象,可以安全地释放内存。

  2. 标记-清除(Mark and Sweep):该算法分为两个阶段。首先,通过根对象(如全局变量、栈中的变量等)标记所有可达对象。然后,清除未被标记的对象,并将它们的内存释放。

  3. 复制(Copying):将内存空间划分为两个区域,通常称为"From"和"To"。在使用过程中,对象存储在"From"区域,当触发垃圾回收时,将存活的对象复制到"To"区域中,随后清除"From"区域中的所有对象。

  4. 标记-压缩(Mark and Compact):结合了标记和清除以及对象移动,首先标记所有可达对象,然后将存活对象向一端移动,并清理掉不再使用的内存,从而压缩可用内存空间。

  5. 分代(Generational):基于观察,大多数对象很快就会变得不可达。该算法将对象根据其生命周期分为不同代,新创建的对象放入新生代,经过多次回收后仍然存活的对象会被晋升到老年代。

12.

 char用于存储固定长度的字符串,如果实际存储的字符串长度小于指定的长度会在后面使用空格进行填充。例如,如果你定义一个CHAR(10)的字段,不管你实际存储的字符串是几个字符,都会占用10个字符的存储空间。

varchar用于存储可变长的字符串,不填充空格,制定最大存储长度。实际可小于这个长度。比如:定义一个VARCHAR(10)的字段,存储"Hello"这个5个字符时,只会占用5个字符的存储空间。

1.

String对象不可变,需要修改就使用+,substring,concat拼接,还可以使用 StringBuilderStringBuffer 类来修改字符串的内容。

  1. 线程安全性:

    • StringBuilder:是非线程安全的。在多线程环境下使用 StringBuilder 进行字符串操作时,需要自行处理同步和线程安全的问题。
    • StringBuffer:是线程安全的,所有对它的方法都进行了同步处理,因此可以保证多线程环境下的安全访问。
  2. 性能:

    • 由于 StringBuffer 的所有方法都是同步的,因此它在多线程环境下能够保证线程安全,但会因为同步操作存在一定的性能开销。
    • 相比之下,StringBuilder 不是线程安全的,它没有额外的同步开销,因此在单线程环境下通常比 StringBuffer 更快。

2.

  1. == 运算符:

    • == 运算符用于比较两个对象的引用是否指向同一个内存地址,即判断两个对象是否是同一个对象。
    • 当使用 == 运算符比较基本数据类型时,比较的是它们的值是否相等。
    • 在比较引用类型时,如果两个引用变量指向同一个对象,则返回 true;否则返回 false
  2. equals() 方法:

    • equals() 方法是 Object 类中定义的方法,子类可以重写该方法来自定义比较规则。
    • 默认情况下,equals() 方法比较的是对象的内存地址,即与 == 运算符的作用相同。
    • 许多 Java 类库中的类(如 StringInteger 等)会重写 equals() 方法,以便按照特定的逻辑进行对象内容的比较

 10.

死锁是两个或者多个线程去争夺同一共享资源而导致的互相等待过程,在没有外部条件干预则会一直阻塞下去,每个线程都在等待另一个线程去释放锁。死锁有三个典型情况,第一个是

一个线程,一把锁,连续锁两次,如果锁是不可重入性锁,就会死锁;Java里的synchronized和ReentrantLock都是可重入性锁;

两个线程两把锁都在拥有一把锁的情况下去获取对方的锁,比如车钥匙锁在家里,家钥匙锁在车里

多个线程多把锁哲学家问题,圆桌,大家吃饭都拿起左手边筷子,而右手边空空,同时放不下筷子也阻塞等待拿不到另一个筷子。而解决办法就是对筷子进行编号。

死锁有四个必要条件,1。互斥使用当以线程获取到锁,其他线程也想去获取锁就只能进行阻塞等待,2.不可抢占,当线程1获取到锁,其他线程只能等待线程1主动释放锁,3.请求保持,拿到锁1去获取锁2,锁1不会释放,4.循环等待形成环,车钥匙放家里,家钥匙放车里。其中12是锁的基本特性,3可以通过改变代码结构由嵌套改为并列去解决,4进行编号加锁顺序

13

数据库索引是一种用于提高数据库查询性能的数据结构,它类似于书籍的目录,可以加快数据库中数据的检索速度。索引基本上是一种存储在数据库表上的数据结构,它使得数据库系统可以更快地找到和排序数据。

### 索引的基本原理

索引的基本原理是在数据库表的一列或多列上创建一个快速查找的数据结构,以便在执行查询时可以更快地定位到所需的数据行。当创建索引时,数据库系统会为索引的列值建立一个数据结构,这个数据结构可以提供快速的查找、排序和过滤功能。

### 索引类型

1. **单列索引**:针对单个列进行索引。
2. **唯一索引**:索引列的值必须是唯一的,用于保证数据完整性。
3. **复合索引**:针对多个列进行索引,可以提高联合条件查询的性能。
4. **全文索引**:用于全文搜索的索引,比如针对文本内容的搜索。
5. **空间索引**:用于地理空间数据类型的索引,比如地图坐标等。

### 索引的优缺点

#### 优点:
- 加快数据检索速度,特别是对大型数据表的查询。
- 可以通过使用覆盖索引减少对数据表的访问,提高查询性能。
- 在某些情况下,可以加速数据的排序操作。
- 提高数据的完整性,比如唯一索引可以保证数据的唯一性。

#### 缺点:
- 创建和维护索引需要额外的存储空间和计算资源。
- 当对数据表进行插入、更新和删除操作时,索引也需要相应地进行更新,可能会增加写操作的时间。
- 错误使用索引可能导致性能下降,比如在少量数据上使用索引或者不合适的索引类型。
- 索引可能会导致查询优化器选择不合适的查询执行计划,从而影响性能。

总的来说,索引在加快数据库查询速度方面有很大的优势,但在使用时需要权衡其对写操作的影响,以及正确地选择索引类型和索引列。

18.

都是用于进行线程暂停一段时间,

1.wait是object类的方法, sleep() 是 Thread 类的静态方法。

2.作用,wait同步使用与协作。sleep方法通常用于线程的暂停以便控制执行的任务时间间隔或者实现简单的定时任务(进行线程的休眠),;

3.wait() 会释放对象的锁,而 sleep() 不会释放任何锁。

当一个线程调用对象的 wait() 方法时,它会进入阻塞状态,并释放该对象的锁,直到其他线程调用相同对象的 notify() 或 notifyAll() 方法来唤醒它;而 sleep() 方法则会让当前线程休眠指定的时间,但不会释放任何锁。

4.使用场景:wait() 方法必须在循环中使用,通常与synchronized方法进行同步使用与协作,以防止虚假唤醒(即线程被意外唤醒)。而 sleep() 方法不需要在循环中使用,可以在任何地方使用。 

(wait是使用notify唤醒,sleep使用interrupted唤醒)

notify唤醒wait,不会有任何异常;

interrupt唤醒sleep则是出异常了。

其实理论上 wait 和 sleep 完全是没有可比性的,因为一个是用于线程之间的通信的,一个是让线程阻 塞一段时间,
唯一的相同点就是都可以让线程放弃执行一段时间 .
1. wait 需要搭配 synchronized 使用 . sleep 不需要 .
2. wait 是 Object 的方法  ,sleep 是 Thread 的静态方法 .

聚簇索引(Clustered Index)
定义:聚簇索引是一种索引机制,其顺序和表中数据行的物理顺序一致。换句话说,聚簇索引重新组织表的行,使行的物理顺序与索引的逻辑顺序相匹配。

基本原理:对于使用聚簇索引的表,表的数据行存储方式会根据索引的键值进行重新排列,这样相邻的记录将在磁盘上变得更加接近,从而提高范围查询的性能。

优点:聚簇索引的主要优点是范围查询的性能较好,因为相关的数据行存储在一起,可以减少磁盘 I/O 操作。

缺点:对于频繁的插入、删除操作,可能会导致页面分裂或碎片化,进而影响性能。此外,聚簇索引通常只能有一个,因为数据行只能以一种顺序进行组织。

非聚簇索引(Non-clustered Index)
定义:非聚簇索引是一种独立于实际数据行物理顺序的索引结构,它包含索引列的值和指向实际行的指针。

基本原理:非聚簇索引通过维护一个独立的数据结构,使得索引列的值和对应的数据行指针之间建立映射关系,从而加快数据检索速度。

优点:非聚簇索引可以提高数据检索的速度,而且在大部分情况下不会影响数据行的物理存储顺序。

缺点:由于要维护额外的指针结构,会占用更多的存储空间。此外,对于范围查询的性能可能会略逊于聚簇索引。

总体来说,聚簇索引适合范围查询较多的情况,而非聚簇索引适合频繁的插入、删除操作或者需要覆盖索引的情况。在实际应用中,根据具体的业务需求和数据库访问模式,可以灵活选择使用聚簇索引和非聚簇索引来优化数据库的性能。

15

过三次握手,双方可以确保彼此都能接收和发送数据,避免了可能出现的数据丢失和混乱情况。如果只进行两次握手,则无法建立可靠的连接,因为缺少了一次确认步骤,无法保证双方之间的通信稳定性和完整性

ArrayList的底层实现是基于数组(Array),它使用动态数组来存储元素,当创建一个ArrayList时,会分配一个初始容量的数组,当元素数量超过当前容量时,会自动进行扩容

LinkedList的底层实现是基于链表(Linked List),它使用双向链表来存储元素。每个节点包含元素本身以及指向前一个节点和后一个节点的引用。由于每个节点都需要额外的存储空间来保存引用,因此LinkedList相对于ArrayList会占用更多的内存。

ArrayList适用于频繁读取和随机访问的场景,而LinkedList适用于频繁插入和删除的场景 

hashcode()和equals()是Java中Object类中的两个方法,它们在处理对象的比较和哈希值计算时起着重要的作用。

equals()方法用于比较两个对象是否相等。在Object类中,默认的equals()方法是比较对象的引用是否相同,即比较内存地址。但是对于自定义的类,需要根据实际情况重写equals()方法,通常会比较对象的属性值是否相等。

hashCode()方法用于返回对象的哈希码,它是一个int类型的数值。哈希码的作用在于对对象进行快速的定位和检索,例如在哈希表(HashMap、HashSet等)中使用。在理想情况下,不同的对象应该有不同的哈希码,但是相等的对象应该有相同的哈希码。因此,重写equals()方法的同时也应该重写hashCode()方法,以保证当两个对象通过equals()方法相等时,它们的哈希码也相等。

在Java中,如果重写了equals()方法,就应该同时重写hashCode()方法,以遵循以下规则:

  1. 如果两个对象通过equals()方法相等,那么它们的hashCode()方法应返回相同的值。
  2. 如果两个对象通过equals()方法不相等,它们的hashCode()方法不要求返回不同的值,但是为了提高哈希表性能,应尽量使得不相等的对象返回不同的哈希码

16 

  1. 可靠性

    • TCP是面向连接的协议,提供可靠的数据传输。它通过数据包的序号、确认和重传机制来确保数据的可靠性和顺序性,能够保证数据不丢失、不重复、按顺序到达。
    • UDP是无连接的协议,不提供可靠性保证。UDP发送数据时不需要建立连接,也不进行数据校验和重传,因此可能会出现数据丢失、重复、乱序等情况。
  2. 传输效率

    • TCP的可靠性带来了额外的开销,如连接设置、数据校验、重传等,导致TCP传输速度相对较慢。
    • UDP没有TCP那些可靠性机制,因此传输速度更快,适用于对实时性要求较高的应用。
  3. 连接方式

    • TCP是面向连接的,通信前需要建立连接,通信结束后需要释放连接。这种连接方式适用于稳定传输的场景,如文件传输、网页访问等。
    • UDP是面向无连接的,每个数据报都是独立的,发送方不需要与接收方建立连接。这种连接方式适用于实时性要求高、数据量小且丢失数据可以接受的场景,如视频流、音频通话等。
  4. 数据包大小限制

    • TCP对数据包大小有限制,当数据量大时需要分片传输,可能会引起网络拥塞。
    • UDP没有固定的数据包大小限制,适合用于快速传输小数据量的信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/431915.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

tomcat动静分离和负载均衡

目录 引言 1.实验环境搭建 2.部署Nginx服务器及配置静态页面Web服务 3.部署Tomcat服务及配置动态页面Web服务 4.实验验收 动态页面 静态页面 引言 tomcat服务既可以处理动态页面,也可以处理静态页面;但其处理静态页面的速度远远不如nginx和apache…

笨办法学 Python3 第五版(预览)(三)

原文:Learn Python the Hard Way, 5th Edition (Early Release) 译者:飞龙 协议:CC BY-NC-SA 4.0 练习 30:假如 这是你将要输入的下一个 Python 脚本,它向你介绍了if语句。输入这个代码,确保它能够完美运行…

gin gorm学习笔记

代码仓库 https://gitee.com/zhupeng911/go-advanced.git https://gitee.com/zhupeng911/go-project.git 1. gin介绍 Gin 是使用纯 Golang 语言实现的 HTTP Web框架,Gin接口设计简洁,提供类似Martini的API,性能极高,现在被广泛使用…

基于ZYNQ PS-SPI的Flash驱动开发

本文使用PS-SPI实现Flash读写,PS-SPI的基础资料参考Xilinx UG1085的文档说明,其基础使用方法是,配置SPI模式,控制TXFIFO/RXFIFO,ZYNQ的IP自动完成发送TXFIFO数据,接收数据到RXFIFO,FIFO深度为12…

Vmware Workstation 不可恢复错误:0xc0000005 has occured

上周打开虚拟机的时候报错:Vmware Workstation 不可恢复错误:0xc0000005 has occured,查看网上资料说是vmware版本太低,需要手动更新本地版本。 由于本地网络不是很好,没能正常更新,无意中出现问题前更改了…

概率基础——极大似然估计

概率基础——极大似然估计 引言 极大似然估计(Maximum Likelihood Estimation,简称MLE)是统计学中最常用的参数估计方法之一,它通过最大化样本的似然函数来估计参数值,以使得样本出现的概率最大化。极大似然估计在各…

docker单节点搭建在线商城

本文档使用到的软件包以上传到资源中 目录 1. 创建容器并配置基础内容 1.1 将gpmall-repo上传到容器中 1.2 添加yum源 2. 安装基础服务 2.1 安装JAVA环境 2.2 安装Redis缓存服务 2.3 安装Elasticsearch服务 2.4 安装Nginx服务 2.5 安装MariaDB数据库 2.6 安…

数据库分库分表中间件选择

目前分库分表的中间件有三种设计思路,分别是: 采用分散式架构,适用于用Java开发的高性能轻量级OLTP应用程序,以Sharding-JDBC为代表。采用中间层Proxy架构,提供了静态输入和所有语言支持,适用于OLAP应用程…

验证Tomcat进程是否启动成功 ps -ef | grep tomcat

验证Tomcat启动是否成功,有多种方式: 查看启动日志 more /usr/local/apache-tomcat-9.0.86/logs/catalina.out tail -50 /usr/local/apache-tomcat-9.0.86/logs/catalina.out 查看进程 ps -ef | grep tomcat 注意: ps命令是linux下非常强…

《剑指offer》14--剪绳子(整数拆分)[C++]

目录 题目描述 贪心算法 输出结果 题目描述 把一根绳子剪成多段,并且使得每段的长度乘积最大。 给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。 示例 1: 输入: 2 输出: 1 解释:…

ZYNQ--PS_PL交互(AXI_HP)

AXI_HP接口 通过AXI_HP接口,可直接通过AXI_FULL协议向DDR中通过DMA传输数据。 BD设计 AXI_HP接口设置 AXI_Master代码 module axi_full_master #(parameter C_M_TARGET_SLAVE_BASE_ADDR 32h40000000,parameter integer C_M_AXI_BURST_LEN 16,parameter …

代码随想录算法训练营第22天|235.二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点

目录 一、力扣235.二叉搜索树的最近公共祖先1.1 题目1.2 思路1.3 代码 二、力扣701.二叉搜索树中的插入操作2.1 题目2.2 思路2.3 代码 三、力扣450.删除二叉搜索树中的节点3.1 题目3.2 思路3.3 代码3.4 总结 一、力扣235.二叉搜索树的最近公共祖先 1.1 题目 1.2 思路 利用二叉…

09-Linux部署Redis

Linux部署Redis 简介 Redis,全称为Remote Dictionary Server(远程字典服务),是一个开源的、使用ANSI C语言编写的、支持网络连接的、基于内存的、同时支持持久化的日志型Key-Value数据库,并提供多种语言的API。 Red…

七、西瓜书——降维与度量学习

1.K近邻 k 近邻(k-Nearest Neighbor,简称 kNN)学习是一种常用的监督学习方法,其工作机制非常简单: 给定测试样本,基于某种距离度量找出训练集中与其最靠近的k个训练样本,然后基于这k个“邻居”的信息来进行预测,通常,在分类任务中可使用“投票法”&#…

$nextTick底层原理(详细) - vue篇

公众号:需要以下pdf,关注下方 2023已经过完了,让我们来把今年的面试题统计号,来备战明年的金三银四!所以,不管你是社招还是校招,下面这份前端面试工程师高频面试题,请收好。 前言 n…

CUDA学习笔记04:向量之和

参考资料 CUDA编程模型系列二(向量操作)_哔哩哔哩_bilibili (非常好的学习资料!) vs2019 随意新建一个空项目,按照之前的环境配置配好项目依赖: CUDA学习笔记02:测试程序hello world-CSDN博客 代码结构…

jitpack上传aar异常: ERROR: No build artifacts found

问题 如图所示,提示 ERROR: No build artifacts found 解决 无法找到artifacts的情况下,我们就需要手动添加artifacts 。 //maven-publish 插件的配置 // publishing 用于定义项目的发布相关配置 publishing {// 配置maven 仓库repositories { Repo…

5201B数据网络测试仪

|5201B数据网络测试仪| | 产品综述 | 电科思仪5201B便携式数据网络测试仪,集成高性能IP基础测试硬件平台,提供L2-L3流量测试及协议仿真解决方案,支持以太网报文线速生成与分析、统计、报文捕获,以及路由、接入、组播、数据中心等协…

item_fee-获得淘宝商品快递费用 API调用说明获取测试key

item_fee-获得淘宝商品快递费用 .通过传入商品id、区域id,来获取该商品的快递费用。 公共参数 点此获取API请求地址 名称类型必须描述keyString是调用key(必须以GET方式拼接在URL中)secretString是调用密钥api_nameString是API接口名称&a…

Linux系统的服务/进程

系统守护进程(服务) •服务就是运行在网络服务器上监听用户请求的进程 •服务是通过端口号来区分的 常见的服务及其对应的端口 1.ftp:21 FTP指的是文件传输协议,它是用于在计算机网络上进行文件传输的标准网络协议。通过FTP&am…