Java编程:面试题中的static、final、冒泡排序与抽象类接口解析
需积分: 5 125 浏览量
更新于2024-07-09
收藏 92KB DOCX 举报
"CGB_面试题_第一阶段.docx"
面试题目主要涵盖了Java语言中的一些核心概念,包括`static`和`final`关键字的用法、冒泡排序算法的实现以及`abstract class`和`interface`的区别。接下来,我们将详细讨论这些知识点。
1. `static`和`final`的用法:
- `static`修饰符:
- 静态属性:这些变量属于类,而不是类的实例。它们在类加载时被初始化,可以通过类名直接访问,不依赖于对象存在。
- 静态方法:同样属于类,可以直接通过类名调用,它们不能访问类的非静态成员,因为非静态成员需要具体的对象实例才能访问。
- 静态代码块:在类加载时执行,用于初始化静态变量。
- `final`修饰符:
- 修饰变量:常量,一旦赋值就不能改变。对于实例变量,如果在构造器中未赋值,那么在其他地方仍然可以赋值。
- 修饰方法:该方法不能在子类中被重写,保证了方法的唯一性。
- 修饰类:此类不能被其他类继承,确保了类的封闭性。
2. 冒泡排序算法:
冒泡排序是一种简单的排序算法,其基本思想是重复地交换相邻两个元素,直到没有任何一对数字需要交换。核心代码如下:
```java
for(int i = 0; i < arr.length - 1; i++) { // 控制轮数
for(int j = 0; j < arr.length - 1 - i; j++) { // 控制每一轮的次数
if(arr[j] > arr[j + 1]) { // 每次都是和它下一个元素比
int t = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = t;
}
}
}
```
这段代码会遍历数组,比较相邻元素,如果前一个元素大于后一个,就交换它们的位置,通过多轮这样的比较,实现排序。
3. `abstract class`和`interface`的区别:
- 相同点:
- 两者都不能直接实例化。
- 实现或继承它们的类必须实现它们声明的所有抽象方法。
- 不同点:
- 继承方式:接口使用`implements`,抽象类使用`extends`。一个类可以实现多个接口,但只能继承一个抽象类。
- 功能定位:接口更强调特定功能的实现,通常用于定义行为规范;抽象类则更注重所属关系,提供部分实现,帮助定义类的结构。
- 方法特性:接口中的方法默认是抽象的,没有方法体;抽象类可以包含抽象方法和具体方法。
- 变量特性:接口中的变量默认是`public static final`,即常量;抽象类中可以有各种类型的变量。
这些知识是Java编程基础中的关键部分,对理解和编写高质量的Java代码至关重要。理解并掌握这些概念,将有助于在面试中展示扎实的编程基础。
2023-03-22 上传
2022-02-17 上传
点击了解资源详情
2023-03-22 上传
104 浏览量
157 浏览量
2025-01-08 上传
2025-01-08 上传
2025-01-08 上传
小沈在这儿^
- 粉丝: 1
- 资源: 1
最新资源
- 珠算练习题.珠算练习题珠算练习题
- BWTC-开源
- side-projects-in-flask
- 常用的css3 button彩色按钮样式代码
- 调制解调GUI.rar_GUI 2FSK_ZOM_ask_qpsk_fsk_qam_ask调制解调
- DynaWeb:DynaWeb是一个Dynamo软件包,它提供对一般与interwebz(特别是与REST API)交互的支持。
- sparse-unet:Keras中稀疏的U-Net实施
- hic-bench:一组用于Hi-C和ChIP-Seq分析的管道
- 行业文档-设计装置-一种折叠式太阳能电池包装盒.zip
- WeatherDashboard
- lugref.zip_IUTR_MATLAB仿真_luGre_lugref_摩擦模型
- 赣极方棋动物、赣极方棋动物代码
- PayOrDie:using使用Sketch的支付应用程序原型
- 行业文档-设计装置-一种拉式找平铁锨.zip
- Brain Derived Vision on IBM CELL-开源
- 初级认证实践.rar