既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
this.elem[usedSize] = val;
usedSize++;
}
public Object get(int pos){
return this.elem[pos];
}
}
好,我们找个例子来运行一下:
public static void main(String[] args) {
MyArrayList2 myArrayList2 = new MyArrayList2();
myArrayList2.add(1);
myArrayList2.add(“hello”);
String ret = (String) myArrayList2.get(1);
System.out.println(ret);//hello
}
这样也运行出来了啊,没问题啊?真的吗?假如我们顺序表内存一个`Book`类,然后我们将其转为我们自定义的`Person`类
MyArrayList books = new MyArrayList();
books.add(new Book);
ClassCastException Person person = (Person)books.get(0);
// 将 Object 类型转换为 Person 类型,需要类型转换才能成功
// 这里编译正确,但运行时会抛出异常
由此可见,`Object类`也有如下缺点:
1. 存放元素不能指定元素
2. 每次取出数据都需要进行强制类型转换
3. 编译期间不能进行检查
由此,我们便诞生了`泛型`:分为`泛型方法`和`泛型类`
### 1.2🍂 泛型语法
这里我们只了解简单的定义即可:
// 1. 尖括号 <> 是泛型的标志
// 2. E 是类型变量(Type Variable),变量名一般要大写
// 3. E 在定义时是形参,代表的意思是 MyArrayList 最终传入的类型,但现在还不知道
public class MyArrayList {
private E[] array;
private int size;
…
}
`注意: 泛型类可以一次有多个类型变量,用逗号分割`
### 1.3🍂 泛型的使用
我们用泛型来表示我们的顺序表:
class MyArrayList3 {
private E[] elem;
private int usedSize;
public MyArrayList3() {
this.elem = (E[]) new Object[10];
//this.elem = new E[10];
}
public void add(E val){
this.elem[usedSize] = val;
usedSize++;
}
public E get(int pos){
return this.elem[pos];
}
}
这样我们就可以定义各种数据类型的元素了
public static void main4(String[] args) {
MyArrayList3 myArrayList3 = new MyArrayList3<>();
System.out.println(myArrayList3);
MyArrayList3 myArrayList31 = new MyArrayList3<>();
System.out.println(myArrayList31);
MyArrayList3 myArrayList32 = new MyArrayList3<>();
System.out.println(myArrayList32);
// 定义了一个元素是 Book 引用的
MyArrayList MyArrayList<Book> books = new MyArrayList<Book>();
books.add(new Book());
//会产生编译错误,Person 类型无法转换为 Book 类型
books.add(new Person());
// 不需要做类型转换
Book book = book.get(0);
// 不需要做类型转换
// 会产生编译错误,
Book 类型无法转换为 Person 类型
Person person = book.get(0);
}
注意:实验的`Book`跟`Person`需要事先写好哦
**通过以上代码,我们可以看到泛型类的一个使用方式:只需要在所有类型后边跟尖括号,并且尖括号内是真正的类型,即 E 可以看作的最后的类型。但Book 只能想象成 E 的类型,但实际上 E 的类型还是 Object。**
### 1.4🍂 泛型的背后作用时期与作用原理
● 泛型是作用在`编译期间`的一种机制 —— `擦除机制`,即`运行期间`没有泛型的概念。
● 泛型代码在运行期间,就是我们上面提到的,利用 `Object` 达到的效果(我们以前说过的`反射机制`)。
泛型的`意义`
1. 自动对类型进行`检查`
2. 自动对类型进行`强转`
3. 泛型`不参与`数据类型的组成
>
> ## 🌕 预备知识二:包装类
>
>
>
Object 引用可以指向任意类型的对象,但有例外出现了,8 种基本数据类型不是对象,那岂不是刚才的泛型机制要失效了?
实际上也确实如此,为了解决这个问题,java 引入了一类特殊的类,即这 8 种基本数据类型的`包装类`,在使用过程中,会将类似 int 这样的值包装到一个对象中去。
### 2.1🍂 基本数据类型和包装类直接的对应关系
![在这里插入图片描述](https://img-blog.csdnimg.cn/1eb517bf286d40d98a1f39ce463941b7.png)
基本就是类型的`首字母大写`,除了 `Integer` 和 `Character`。
### 2.2🍂 隐式转换与显式转换
`包装类数据类型转换`
public static void main(String[] args) {
Integer a = 12345;
String str = “123”;
int ret = Integer.valueOf(str);//借助valueof实现数据类型转换
System.out.println(ret + 1);
}
`显式装包、拆包`
public static void main(String[] args) {
//显式转换
System.out.println(“=============”);
Integer a2 = Integer.valueOf(123);//装包
Integer a3 = new Integer(123);//装包
int b2 = a2.intValue();//拆包
double d = a2.doubleValue();//拆包
}
`隐式装包、拆包`
public static void main(String[] args) {
//隐式转换
Integer a = 123;//装包
int b = a;//拆包
System.out.println(a + " " + b);
}
● 装包,装箱:简单类型 ——> 包装类类型
● 拆箱,拆包:包装类 ——> 简单数据类型数据
### 2.3🍂 Integer范围分析
我们来看如下代码:
public static void main(String[] args) {
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!