-
4.3 ArrayList常见操作
-
4.4 ArrayList的扩容机制
-
5 . ArrayList的使用示例
-
- 5.1 ArrayList可以放自定义的数据类型
-
5.2 ArrayList可以对数据进行排序
-
5.3 删除第一个字符串当中的第二个字符串中的字符
-
5.4 ArrayList实现的简易扑克牌
-
6 . ArrayList的模拟实现
-
7 . 解决杨辉三角题
=======================================================================
=======================================================================================
问题:我们之前实现过的顺序表,只能保存 int类型的元素,如果现在需要保存 指向 Person类型对象的引用的顺序表,请问应该如何解决?如果又需要保存指向 Book 对象类型的引用呢?
回答:
对象类型的引用呢?
-
首先,我们在学习多态过程中已知一个前提,基类的引用可以指向子类的对象。
-
其次,我们也已知Object是 java 中所有类的祖先类。
那么,要解决上述问题,我们很自然的想到一个解决办法,将我们的顺序表的元素类型定义成 Object类型,这样我们的Object类型的引用可以指向Person类型的对象或者指向Book类型的对象了。
之前的实现的ArrayList:
改成Object之后:
问题:
-
能不能指定这个顺序表的类型?
-
指定类型之后,是不是只能存放指定的数据类型?
-
取出数据,能不能不进行强制类型转换?
于是就有了泛型
// 1. 尖括号 <> 是泛型的标志
// 2. E 是类型变量(Type Variable),变量名一般要大写
// 3. E 在定义时是形参,代表的意思是 MyArrayList 最终传入的类型,但现在还不知道
class MyArrayList{
private E[] elem;
private int usedSize;
public MyArrayList(){
this.elem = (E[]) new Object[10];
}
public void add(E val){
this.elem[usedSize] = val;
usedSize++;
}
public E get(int pos){
return this.elem[pos];
}
}
public class TestDemo {
public static void main(String[] args) {
MyArrayList myArrayList = new MyArrayList<>();
MyArrayList myArrayList1 = new MyArrayList<>();
MyArrayList myArrayList2 = new MyArrayList<>();
}
}
**1. 自动对类型进行检查
2. 自动对类型进行强制类型的转换
3. 泛型中尖括号当中的内容 不参与类型的组成**
泛型是编译时期的一种机制,擦除机制
**1. 泛型是为了解决某些容器、算法等代码的通用性而引入,并且能在编译期间做类型检查。
2. 泛型利用的是 Object 是所有类的祖先类,并且父类的引用可以指向子类对象的特定而工作。
3. 泛型是一种编译期间的机制,即 MyArrayList 和 MyArrayList 在运行期间是一个类型。
4. 泛型是 java 中的一种合法语法,标志就是尖括号 <>**
==========================================================================
| 基本数据类型 | 包装类 |
| :-: | :-: |
| byte | Byte |
| short | Short |
| int | Integer |
| long | Long |
| float | Float |
| double | Double |
| char | Character |
| boolean | Boolean |
2.2 包装类的使用,装箱(boxing)和拆箱(unboxing)
-
装箱 装包 : 把简单类型 ========> 包装类类型
-
拆箱 拆包 : 把包装类类型 =========> 简单数据类类型的数据
代码:
public static void main(String[] args) {
Integer a = 123;//装箱 装包[隐式的]
int b = a;//拆箱 拆包[隐式的]
System.out.println(“====================”);
//装箱 装包[显式的]
Integer a2 = Integer.valueOf(123);
Integer a3 = new Integer(123)
//拆箱 拆包[显式的]
int b2 = a2.intValue();
double d = a3.doubleValue();
}
==================================================================================
【说明】
**1.ArrayList实现了RandomAccess接口,表明ArrayList支持随机访问2.ArrayList实现了Cloneable接口,表明ArrayList是可以clone的
3.ArrayList实现了Serializable接口,表明ArrayList是支持序列化的
4.和Vector不同,ArrayList不是线程安全的,在单线程下可以使用,在多线程中可以选择Vector或者CopyOnWriteArrayList
5.ArrayList底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表**
==================================================================================
| 方法 | 解释 |
| :-- | :-- |
| ArrayList() | 无参构造 |
| ArrayList(Collection<? extends E> c) | 利用其他 Collection 构建 ArrayList |
| ArrayList(int initialCapacity) | 指定顺序表初始容量 |
有三种遍历方式:for循环,foreach,迭代器
public static void main(String[] args) {
ArrayList arrayList = new ArrayList<>();
arrayList.add(“hello”);
arrayList.add(“+”);
arrayList.add(“world!”);
System.out.println(arrayList);
System.out.println(“1.for循环”);
for (int i = 0; i < arrayList.size(); i++) {
System.out.print(arrayList.get(i)+" ");
}
System.out.println();
System.out.println(“2.foreach”);
for (String s:arrayList) {
System.out.print(s+" ");
}
System.out.println();
System.out.println(“3.使用迭代器的方法”);
Iterator it = arrayList.iterator();
while(it.hasNext()){
System.out.print(it.next()+" ");
}
System.out.println();
System.out.println(“4.迭代器List相关打印”);
ListIterator it2 = arrayList.listIterator();
while (it2.hasNext()){
System.out.print(it2.next()+" ");
}
4.2.1 迭代器 Iterator ListIterator
| 方法 | 解释 |
| :-- | :-- |
| boolean add(E e) | 尾插 e |
| void add(int index, E element) | 将 e 插入到 index 位置 |
| boolean addAll(Collection<? extends E> c) | 尾插 c 中的元素 |
| E remove(int index) | 删除 index 位置元素 |
| boolean remove(Object o) | 删除遇到的第一个 o |
| E get(int index) | 获取下标 index 位置元素 |
| E set(int index, E element) | 将下标 index 位置元素设置为 element |
| void clear() | 清空 |
| boolean contains(Object o) | 判断 o 是否在线性表中 |
| int indexOf(Object o) | 返回第一个 o 所在下标 |
| int lastIndexOf(Object o) | 返回最后一个 o 的下标 |
| List subList(int fromIndex, int toIndex) | 截取部分 list |
public static void main(String[] args) {
ArrayList arrayList = new ArrayList<>();
System.out.println(“==尾插e=”);
arrayList.add(“a”);
arrayList.add(“b”);
arrayList.add(“c”);
System.out.println(arrayList);
System.out.println(“==将 e 插入到 index 位置=”);
arrayList.add(0,“qwe”);
System.out.println(arrayList);
System.out.println(“==尾插 c 中的元素=”);
ArrayList arrayList1 = new ArrayList<>();
arrayList1.add(“!!!”);
arrayList.addAll(arrayList1);
System.out.println(arrayList);
System.out.println(“==删除 index 位置元素=”);
System.out.println(arrayList.remove(0));
System.out.println(arrayList);
System.out.println(“==删除遇到的第一个 o=”);
System.out.println(arrayList.remove(“a”));
System.out.println(arrayList);
System.out.println(“==获取下标 index 位置元素=”);
System.out.println(arrayList.get(1));
System.out.println(“==将下标 index 位置元素设置为 element=”);
System.out.println(“原来要修改的数据:”+arrayList.set(1,“d”));
System.out.println(arrayList);
System.out.println(“==判断 o 是否在线性表中=”);
System.out.println(arrayList.contains(“!!!”));
System.out.println(“==返回第一个 o 所在下标=”);
System.out.println(arrayList.indexOf(“!!!”));
System.out.println(“==返回最后一个 o 的下标=”);
System.out.println(arrayList.lastIndexOf(“!!!”));
System.out.println(“==截取部分 list=”);
List sub = arrayList.subList(0,2);//左闭右开
System.out.println(sub);
System.out.println(“==情况=”);
arrayList.clear();
System.out.println(arrayList);
}
运行结果:
**结论:
如果ArrayList调用无参的构造方法new ArrayList() , 那么顺序表的大小是0.当第一次add的时候, 整个顺序表才变为了10;
当这10个放满之后,才开始扩容,以1.5倍的方式扩容.
如果调用的是给定容量的构造方法new ArrayList(13) , 那么顺序表的大小就是给定容量的大小,如果放满了,还是以1.5倍进行扩容.**
=====================================================================================
import java.util.ArrayList;
class Student{
private String name;
private String classes;
private double score;
public Student(String name, String classes, double score) {
this.name = name;
this.classes = classes;
this.score = score;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getClasses() {
return classes;
}
public void setClasses(String classes) {
this.classes = classes;
}
public double getScore() {
return score;
}
public void setScore(double score) {
this.score = score;
}
@Override
public String toString() {
return “Student{” +
“name='” + name + ‘’’ +
“, classes='” + classes + ‘’’ +
“, score=” + score +
‘}’;
}
}
public class TestDemo10 {
public static void main1(String[] args) {
ArrayList students = new ArrayList<>();
students.add(new Student(“niubi”,“102-1”,98.9));
students.add(new Student(“21e”,“123”,22.2));
students.add(new Student(“qwq”,“wqqe”,455.4));
System.out.println(students);
}
}
运行结果:
public static void main(String[] args) {
ArrayList integers = new ArrayList<>();
integers.add(11);
integers.add(2);
integers.add(13);
Collections.sort(integers);
System.out.println(integers);
}
运行结果:
public static void main(String[] args) {
String str1 = “welcome to bit”;
String str2 = “come”;
ArrayList list1 = new ArrayList<>();
for (int i = 0; i < str1.length(); i++) {
char ch = str1.charAt(i);
if(!str2.contains(ch+“”)){
list1.add(ch);
}
}
for (char ch : list1 ) {
System.out.print(ch);
}
}
运行结果:
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
class Card{
private int rank;
private String suit;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
写在最后
为了这次面试,也收集了很多的面试题!
以下是部分面试题截图
vate String suit;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-DzhzwPlc-1711864486153)]
[外链图片转存中…(img-ZylFFXlN-1711864486154)]
[外链图片转存中…(img-Dxld0G1P-1711864486154)]
[外链图片转存中…(img-k7iB32SS-1711864486154)]
[外链图片转存中…(img-7ZhmeBQk-1711864486155)]
[外链图片转存中…(img-OYfs3iGT-1711864486155)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-bsPWsd0A-1711864486156)]
写在最后
为了这次面试,也收集了很多的面试题!
以下是部分面试题截图
[外链图片转存中…(img-GGKeC0M9-1711864486156)]