学习大数据所需的java基础(5)

文章目录

  • 集合框架
  • Collection接口
  • 迭代器
    • 迭代器基本使用
    • 迭代器底层原理
    • 并发修改异常
  • 数据结构
    • 队列
    • 数组
    • 链表
  • List接口
      • 底层源码分析
  • LinkList集合
      • LinkedList底层成员解释说明
      • LinkedList中get方法的源码分析
      • LinkedList中add方法的源码分析
  • 增强for
    • 增强for的介绍以及基本使用发
    • 2.使用增强for的注意事项
  • 集合工具类
    • 比较器
  • 泛型
    • 为什么要使用泛型
    • 泛型的定义
      • 含有泛型的类
      • 含有泛型的方法
      • 含有泛型的接口
    • 泛型的高级使用
      • 泛型的上限和下限


集合框架

概述:容器
作用:一次存储多个数据
特点:
长度可变
只能存储引用数据类型的数据
有很多的方法直接操作元素,方便
单列集合:一个元素由一部分构成
list.add(“张三”)
双列集合:一个元素由两部分构成------ key value形式 键值对形式
map.put(“张三”,“18”)
在这里插入图片描述

Collection接口

概述:Collection是单列集合的顶级接口
特点:
a.元素有序
b.元素可重复
c.没有索引
创建
Collection 集合名 = new ArrayList()
a.E:代表的是集合元素的具体类型
b.<>里面只能存储引用类型,如果啥也不写,默认为Object类型
----- 不对
---- 对
------对
等号右边的泛型可以空着
5.方法:
boolean add(E e) : 将给定的元素添加到当前集合中(我们一般调add时,不用boolean接收,因为add一定会成功)
boolean addAll(Collection<? extends E> c) :将另一个集合元素添加到当前集合中 (集合合并)
void clear():清除集合中所有的元素
boolean contains(Object o) :判断当前集合中是否包含指定的元素
boolean isEmpty() : 判断当前集合中是否有元素->判断集合是否为空
boolean remove(Object o):将指定的元素从集合中删除
int size() :返回集合中的元素数。
Object[] toArray(): 把集合中的元素,存储到数组中

		Collection<String> collection = new ArrayList<String>();//往集合中添加元素collection.add("李云龙");collection.add("丁伟");collection.add("孔捷");collection.add("楚云飞");System.out.println(collection);//将另一个集合元素添加到当前集合中,集合合并Collection<String> collection1 = new ArrayList<String >();collection1.add("魏大勇");collection1.add("大彪");collection1.add("段鹏");System.out.println(collection1);//将另一个集合元素添加到当前集合中(集合合并)collection1.addAll(collection);System.out.println(collection1);//清除集合中所有的元素collection1.clear();System.out.println(collection1);//判断当前集合中是否包含指定元素System.out.println(collection.contains("李云龙"));//将指定的元素从集合中删除collection.remove("孔捷");System.out.println(collection);//返回集合中的元素数System.out.println("collection.size() = " + collection.size());//将集合中的元素存储到数组中Object[] array = collection.toArray();for (int i = 0; i < array.length; i++) {System.out.println(array[i]);}

迭代器

迭代器基本使用

概述:Iterator接口
作用: 遍历集合
获取 Collection中的方法 Iterator iterator()
方法: boolean hasNext() ---- 判断集合还有没有下一个元素
E next ---- 获取下一个元素

public class test02 {public static void main(String[] args) {Collection<String> collection = new ArrayList<String>();collection.add("李云龙");collection.add("丁伟");collection.add("孔捷");//定义一个迭代器Iterator<String> iterator = collection.iterator();while (iterator.hasNext()){String element1 = iterator.next();//String element2 = iterator.next();System.out.println("element1 = " + element1);//System.out.println("element2 = " + element2);}}
}

注意:使用i迭代器时尽量不要连续调用多次next方法获取元素,防止报错

迭代器底层原理

只有ArrayList集合使用迭代器的时候Iterator指向的是Itr,其他集合不一定,比如HashSet集合

public class test03 {public static void main(String[] args) {final HashSet<String> set = new HashSet<>();set.add("孙悟空");set.add("猪八戒");set.add("唐僧");set.add("沙和尚");Iterator<String> iterator = set.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}}
}

并不是顺序输出
在这里插入图片描述

并发修改异常

我们定义一个集合,存储亮剑中三个团长,遍历集合,在遍历的过程中,如果获取出来的是李云龙,就直接在集合中添加”张大彪“

public class test04 {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("李云龙");list.add("孔捷");list.add("丁伟");Iterator<String> iterator = list.iterator();while (iterator.hasNext()){String element =  iterator.next();if ("李云龙".equals(element)){list.add("张大彪");}}System.out.println(list);}
}

我么发现报错:ConcurrentModificationException
modCount:实际操作次数
expectionModCount:预期操作次数
结论:当实际操作次数和预期操作次数不相等时,出现并发修改异常
总结:当我们调用add方法,底层单独给modCount+1,但是没有重新将更改后的modCount赋值给二线expectionModCount
再调用next方法时,next方法底层做了一个判断,当实际操作次数和预期操作次数不相等时,出现并发修改异常

拓展:ArrayList集合中的方法:ListIterator()

数据结构

学过数据机构的同学们,对此章节可能会比较了解,这里不做详细的介绍,只简单的过一下 ·

特点: 先进后出

队列

特点:先进先出

数组

特点 查询快,增删慢
查询快:有索引,我们可以通过索引获取对应的元素
增删慢:定长
添加元素:先创建一个新的数组,指定新长度,将老数组的元素复制到新数组中,再添加新的元素
删除元素:先创建一个新的数组,指定新新长度,将老数组的元素复制到新数组中

链表

特点:查询慢,增删快
分类:
单向链表:一个字节分两部分
前面的字节记录后面字节的地址
后面字节不记录前面字节的地址
如果集合底层数据结构用的是单向链表,无法保证元素有序
双向链表:一个字节分三部分
前面的字节机会后面字节的地址
后米娜的字节记录前面字节的地址
如果集合底层数据结构用的是双向链表,能够保证元素有序

List接口

概述:list接口是Collection接口的子接口
实现类
ArrayList,LinkedList,Vector
4.常用方法:
boolean add(E e) -> 将元素添加到集合中->尾部(add方法一定能添加成功的,所以我们不用boolean接收返回值)
void add(int index, E element) ->在指定索引位置上添加元素
boolean remove(Object o) ->删除指定的元素,删除成功为true,失败为false
E remove(int index) -> 删除指定索引位置上的元素,返回的是被删除的那个元素
E set(int index, E element) -> 将指定索引位置上的元素,修改成后面的element元素
E get(int index) -> 根据索引获取元素
int size() -> 获取集合元素个数

public class test05 {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("李云龙");list.add("丁伟");list.add("孔捷");list.add("张大彪");list.add("魏大勇");list.add("段鹏");//往指定位置添加元素list.add(3,"楚云飞");//删除指定元素,删除成功返回true,失败返回falselist.remove("楚云飞");//删除指定位置的元素,返回值为删除的元素System.out.println(list.remove(0));//将指定索引位置上的元素,修改为后面的元素,返回值为被替换元素的值System.out.println(list.set(1, "李云龙"));
//        System.out.println(list);//根据索引获取元素System.out.println(list.get(2));//获取集合元素的个数System.out.println(list.size());//快速遍历集合的方法for (int i = 0; i < list.size(); i++) {System.out.println(list.get(i));}}
}

底层源码分析

ArrayList是一个集合,集合的长度是可变的,ArrayList底层数据结构数组,所以需要进行数组扩容使得数组长度可变
rrayList有一个空参构造: ArrayList() 构造一个初始容量为10的空列表
注意:不是 new就创建一个长的为10的空列表
而是第一次add的时候才会创建长度为10的空列表

扩容方式为
elementData = Arrays.copyOf(elementData, newCapacity);->数组扩容,数组复制
扩容1.5倍

LinkList集合

基本使用
概述:是List接口下的实现类
特点:
a.元素有序
b.元素可重复
c.有索引
d.线程不安全
数据结构双向链表
LinkList 将来我们有可能有大量的首位元素的操作,LinkList有很多特有方法
这些特有防火阀都是直接操作首位元素的
.方法:
public void addFirst(E e):将指定元素插入此列表的开头。
public void addLast(E e):将指定元素添加到此列表的结尾。
public E getFirst():返回此列表的第一个元素。
public E getLast():返回此列表的最后一个元素。
public E removeFirst():移除并返回此列表的第一个元素。
public E removeLast():移除并返回此列表的最后一个元素。
public E pop():从此列表所表示的堆栈处弹出一个元素。
public void push(E e):将元素推入此列表所表示的堆栈。
public boolean isEmpty():如果列表不包含元素,则返回true。

public class test06 {public static void main(String[] args) {LinkedList<String> list = new LinkedList<>();System.out.println("农药的龙年王者限定皮肤");list.add("赵云");list.add("孙尚香");list.add("孙策");list.add("安其拉");list.add("大乔");System.out.println(list);//将指定元素插入到列表开头list.addFirst("龙年限定");//将指定元素插入得到列表结尾list.addLast("就这五个");//返回列表的第一个元素System.out.println(list.getFirst());//返回列表的最后一个元素System.out.println(list.getLast());//移出并返回列表的第一个元素System.out.println(list.removeFirst());//移出并返回列表的最后一个元素System.out.println(list.removeLast());//从此列表表示的堆栈处弹出一个元素,底层调用removFirstlist.pop();//将元素推入到次列表所表示的堆栈,底层调用addFirstlist.push("龙年限定");}
}

LinkedList底层成员解释说明

1.LinkedList底层成员
transient int size = 0; 元素个数
transient Node first; 第一个节点对象
transient Node last; 最后一个节点对象

2.Node代表的是结点对象
private static class Node {
E item;//节点上的元素
Node next;//记录着下一个节点地址
Node prev;//记录着上一个节点地址

    Node(Node<E> prev, E element, Node<E> next) {this.item = element;this.next = next;this.prev = prev;}

LinkedList中get方法的源码分析

public E get(int index) {checkElementIndex(index);return node(index).item;
} Node<E> node(int index) {// assert isElementIndex(index);if (index < (size >> 1)) {Node<E> x = first;for (int i = 0; i < index; i++)x = x.next;return x;} else {Node<E> x = last;for (int i = size - 1; i > index; i--)x = x.prev;return x;}

LinkedList中add方法的源码分析

LinkedList<String> list = new LinkedList<>();
list.add("a");
list.add("b");    void linkLast(E e) {final Node<E> l = last;final Node<E> newNode = new Node<>(l, e, null);last = newNode;if (l == null)first = newNode;elsel.next = newNode;size++;modCount++;
}

增强for

增强for的介绍以及基本使用发

作用 遍历集合或者数组
格式
for(元素的数据类型 变量名:要遍历的集合名或者数组名){
变量代表的就是每一个元素
}
快捷键
集合名或者数组名.,for

ArrayList<String> list = new ArrayList<>();list.add("李云龙");list.add("丁伟");list.add("孔捷");list.add("张大彪");list.add("魏大勇");list.add("段鹏");for (String s : list) {System.out.println(s);}int[] arr = {1, 2, 3, 4, 5};for (int i : arr) {System.out.println(i);}

2.使用增强for的注意事项

1.在使用增强for遍历集合的时候尽量也不要随意改变集合长度,不然也会出现"并发修改异常"
a.增强for在遍历集合的时候,实现原理为迭代器
b.增强for在遍历数组的时候,实现原理为普通for

public class test07 {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("李云龙");list.add("丁伟");list.add("孔捷");list.add("张大彪");list.add("魏大勇");list.add("段鹏");for (String s : list) {System.out.println(s);}int[] arr = {1, 2, 3, 4, 5};for (int i : arr) {System.out.println(i);}

集合工具类

概述:Collections集合工具类
特点
构造私有
成员方法是静态的
使用
类名直接调用
常用方法
static boolean addAll(Collection<? super T> c, T... elements)->批量将元素存到集合中 static void shuffle(List<?> list) -> 将集合中的元素顺序打乱
static void sort(List list) ->将集合中的元素按照默认规则排序->ASCII
static void sort(List list, Comparator<? super T> c)->将集合中的元素按照指定规则排序

public class test01 {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();//批量将元素存到集合中Collections.addAll(list,"李玉龙","孔捷","丁伟");System.out.println(list);System.out.println("============================");//将集合中的元素打乱Collections.shuffle(list);System.out.println(list);//将集合中的元素按照默认规则排序  ASCIICollections.sort(list);System.out.println(list);}
}

比较器

概述 Comparator:接口–比较器
方法:
int compare(T o1,T o2) ----- 设置比较规则
o1-o2 ----- 升序
o2-o1 ------降序
相关代码,首先构造javabean

public class Person implements Comparable<Person>{private String name;private int age;public Person() {}public Person(String name, int age) {this.name = name;this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}@Overridepublic String toString() {return "Person{" + name + '\'' + ",age:" +age+'}';}@Overridepublic int compareTo(Person o) {return o.getAge() - this.getAge();}
}

构建测试类

public class test01{public static void main(String[] args) {final ArrayList<Person> list = new ArrayList<>();list.add(new Person("刘备",30));list.add(new Person("关羽",48));list.add(new Person("张飞",45));System.out.println(list);//由于sort继承comparable.调用重写的方法Collections.sort(list);System.out.println(list);}
}

泛型

使用
注意:
泛型中写的类型都是引用数据类型
如果<>中什么都不写,元素默认类型为Object类型

为什么要使用泛型

从使用上看,如果使用了泛型,规定了数据类型,那么数据类型是一致的,防止了类型转换异常
从定义上看,定义泛型以后,在使用的时候确定啥类型,泛型就是啥类型,通用

泛型的定义

含有泛型的类

定义格式:
piublc class 类名{ }
什么时候确定泛型类型
new对象的时候确定类型

public class MyArrayList <E>{public void add(E e){System.out.println(e);}
}
public class test02 {public static void main(String[] args) {final MyArrayList<String> list = new MyArrayList<>();list.add("李云龙");final MyArrayList<Integer> list1 = new MyArrayList<>();list1.add(123);}
}

含有泛型的方法

格式 修饰符 返回值类型 方法名(E e) { }
调用的时候确定类型

public class Mylist {public <E> void add(E e){System.out.println(e);}
}

测试类

public class test03 {public static void main(String[] args) {final Mylist mylist = new Mylist();mylist.add(1);mylist.add("李云龙");}
}

含有泛型的接口

格式 public interfa 接口名{}
什么时候确定类型
在实现类的时候确定类型 比如Scanner
在实现类的时候还不确定类型,只能在new的时候确定类型 ---- 比如 ArrayList

public interface MyList <E>{public void add(E e);
}
public class MyScanner implements MyList<String>{@Overridepublic void add(String s) {System.out.println(s);}
}
public class MyScanner implements MyList<String>{@Overridepublic void add(String s) {System.out.println(s);}
}
public class Test01 {public static void main(String[] args) {MyScanner myScanner = new MyScanner();myScanner.add("哈哈哈");}
}

泛型的高级使用

什么时候使用泛型通配符:参数位置当不知道接收什么类型时 ------ 一般用在集合方面
用在什么位置上 一般用在参数位置上

import java.util.ArrayList;public class test06 {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("李云龙");list.add("孔捷");list.add("丁伟");ArrayList<Integer> list1 = new ArrayList<>();list1.add(1);list1.add(2);list1.add(3);method(list);method(list1);}public static void method(ArrayList<?> list){for (Object o : list) {System.out.println(o);}}
}

泛型的上限和下限

泛型通配符的高级使用 受限泛型
上限:
a.格式: 类型名称<? extends 类> 对象名
b,意义:?只能接收extends后面的本类以及子类
下限
a.格式:类型名称<? super 类> 对象名
b.意义: ?只能接受super后面的本类以及父类

import java.util.ArrayList;
import java.util.Collection;public class test07 {public static void main(String[] args) {Collection<Integer> list1 = new ArrayList<>();Collection<String> list2 = new ArrayList<>();Collection<Number> list3 = new ArrayList<>();Collection<Object> list4 = new ArrayList<>();getElement1(list1);//getElement1(list2); 报错getElement1(list3);//getElement1(list4);  报错System.out.println("================================");//getElement2(list1);  报错//getElement2(list2);  报错getElement2(list3);getElement2(list4);}// 上限 ?只能接受extends后面的本类以及子类public static void  getElement1(Collection<? extends Number> collection){}//下限 ?只能接受super后的本类以及父类public static void  getElement2(Collection<? super Number> collection){}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【成都游戏业:千游研发之都的发展与机遇】

成都游戏业&#xff1a; 千游研发之都的发展与机遇 作为我国西部游戏产业的龙头&#xff0c;成都这座城市正在高速发展&#xff0c;目标是崛起成为千亿级游戏研发之都。多年来&#xff0c;在政策扶持、人才汇聚以及文化底蕴等助力下&#xff0c;成都游戏业已经形成完整的产业链…

MyBatis--02-1- MybatisPlus----条件构造器

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言AbstractWrapper 条件构造器官网文档https://baomidou.com/pages/10c804/#abstractwrapper](https://baomidou.com/pages/10c804/#abstractwrapper)![在这里插入…

安全这么卷了吗?北京,渗透,4k,不包吃住,非实习

起初某HR找人发了条招聘信息 看到被卷到4k一个月被震惊到了 随后发布了朋友圈&#xff0c;引起来众多讨论 对此网友发表众多评价 越来越卷的工作现象确实是一个普遍存在的问题 另外&#xff0c;也可以考虑和雇主沟通&#xff0c; 寻求更合理的工作安排&#xff0c; 或者…

[ 2024春节 Flink打卡 ] -- Paimon

2024&#xff0c;游子未归乡。工作需要&#xff0c;flink coding。觉知此事要躬行&#xff0c;未休&#xff0c;特记 Flink 社区希望能够将 Flink 的 Streaming 实时计算能力和 Lakehouse 新架构优势进一步结合&#xff0c;推出新一代的 Streaming Lakehouse 技术&#xff0c;…

springboot访问webapp下的jsp页面

一&#xff0c;项目结构。 这是我的项目结构&#xff0c;jsp页面放在WEB-INF下的page目录下面。 二&#xff0c;file--->Project Structure,确保这两个地方都是正确的&#xff0c;确保Source Roots下面有webapp这个目录&#xff08;正常来说&#xff0c;应该本来就有&#…

Python in Visual Studio Code 2024年2月发布

排版&#xff1a;Alan Wang 我们很高兴地宣布 2024 年 2 月版 Visual Studio Code 的 Python 和 Jupyter 扩展已经推出&#xff01; 此版本包括以下公告&#xff1a; 默认安装的 Python 调试器扩展快速选择 Python 解释器中的“Create Environment”选项Jupyter 的内置变量查…

flink反压

flink反压&#xff08;backpressure&#xff09;&#xff0c;简单来说就是当接收方的接收速率低于发送方的发送速率&#xff0c;这时如果不做处理就会导致接收方的数据积压越来越多直到内存溢出&#xff0c;所以此时需要一个机制来根据接收方的状态反过来限制发送方的发送速率&…

Spring6学习技术|IoC|手写IoC

学习材料 尚硅谷Spring零基础入门到进阶&#xff0c;一套搞定spring6全套视频教程&#xff08;源码级讲解&#xff09; 有关反射的知识回顾 IoC是基于反射机制实现的。 Java反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&…

网页数据的解析提取(正则表达式----re库详解)

前面&#xff0c;我们已经可以用requests库来获取网页的源代码&#xff0c;得到HTML代码。但我们真正想要的数据是包含在HTML代码之中的。要怎样才能从HTML代码中获取想要的信息呢&#xff1f;正则表达式是一个万能的方法&#xff01;&#xff01;&#xff01; 目录 正则表达…

多维时序 | Matlab实现基于VMD-DBO-GRU、VMD-GRU、GRU的多变量时间序列预测

多维时序 | Matlab实现基于VMD-DBO-GRU、VMD-GRU、GRU的多变量时间序列预测 目录 多维时序 | Matlab实现基于VMD-DBO-GRU、VMD-GRU、GRU的多变量时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab实现基于VMD-DBO-GRU、VMD-GRU、GRU的多变量时间序列预测…

辽宁博学优晨教育:视频剪辑培训,开启创意新篇章

在数字化时代&#xff0c;视频已成为信息传播的重要载体。辽宁博学优晨教育紧跟时代步伐&#xff0c;推出全新的视频剪辑培训课程&#xff0c;为广大学员开启创意之旅&#xff0c;探索视频剪辑的无限可能。 一、视频剪辑&#xff1a;时代的选择与技能的进阶 随着互联网的普及和…

Stable diffusion UI 介绍-文生图

1.提示词&#xff1a; 你希望图中有什么东西 2.负面提示词&#xff1a;你不希望图中有什么东西 选用了什么模型 使用参数 1.采样器 sampling method 使用什么算法进行采样 2.采样迭代步数 sampling steps 生成图像迭代的步数&#xff0c;越多越好&#xff0c;但是生成速度越大越…

【C语言】socket 层到网络接口的驱动程序之间的函数调用过程

一、socket 层到网络接口的驱动程序之间的函数调用过程概述 在 Linux 操作系统中&#xff0c;socket 层到网络接口的驱动程序之间的函数调用过程相对复杂&#xff0c;涉及多个层次的交互。以下是一个简化的概述&#xff0c;描述数据从 socket 传递到硬件驱动&#xff0c;再到硬…

uniapp播放mp4省流方案

背景&#xff1a; 因为项目要播放一个宣传和讲解视频&#xff0c;视频文件过大&#xff0c;同时还为了节省存储流量&#xff0c;想到了一个方案&#xff0c;用m3u8切片替代mp4。 m3u8&#xff1a;切片播放&#xff0c;可以理解为一个1G的视频文件&#xff0c;自行设置文…

【微服务生态】Dubbo

文章目录 一、概述二、Dubbo环境搭建-docker版三、Dubbo配置四、高可用4.1 zookeeper宕机与dubbo直连4.2 负载均衡 五、服务限流、服务降级、服务容错六、Dubbo 对比 OpenFeign 一、概述 Dubbo 是一款高性能、轻量级的开源Java RPC框架&#xff0c;它提供了三大核心能力&#…

总结Rabbitmq的六种模式

RabbitMQ六种工作模式 RabbitMQ是由erlang语言开发&#xff0c;基于AMQP&#xff08;Advanced Message Queue 高级消息队列协议&#xff09;协议实现的消息队列&#xff0c;它是一种应用程序之间的通信方法&#xff0c;消息队列在分布式系统开发中应用非常广泛。 RabbitMQ有六…

9.vue学习笔记(组件传递Props校验+组件事件-组件传递数据+组件事件-配合“v-model”使用)

文章目录 1.组件传递Props校验1.1.默认值1.2.必选项1.3.注意事项&#xff1a;props 是只读的 2.组件事件-组件传递数据2.1.温馨提示&#xff1a;组件之间传递数据的方案 3.组件事件-配合“v-model”使用 1.组件传递Props校验 Vue组件可以更细致地声明对传入的 props 的校验要求…

顺序表经典算法及其相关思考

27. 移除元素 - 力扣&#xff08;LeetCode&#xff09; 思路一 利用顺序表中的SLDestroy函数的思想&#xff0c;遇到等于val值的就挪动 思路二 双指针法&#xff1a;不停的将和val不相等的数字往前放。此时的des更像一个空数组&#xff0c;里面存放的都是和val不相等、能够存…

【人工智能学习思维脉络导图】

曾梦想执剑走天涯&#xff0c;我是程序猿【AK】 目录 知识图谱1. 基础知识2.人工智能核心概念3.实践与应用4.持续学习与进展5.挑战与自我提升6.人脉网络 知识图谱 人工智能学习思维脉络导图 1. 基础知识 计算机科学基础数学基础&#xff08;线性代数、微积分、概率论和统计学…

先进语言模型带来的变革与潜力

用户可以通过询问或交互方式与GPT-4这样的先进语言模型互动&#xff0c;开启通往知识宝库的大门&#xff0c;即时访问人类历史积累的知识、经验与智慧。像GPT-4这样的先进语言模型&#xff0c;能够将人类历史上积累的海量知识和经验整合并加以利用。通过深度学习和大规模数据训…