Wend看源码-Java-Collections 工具集学习
摘要
java.util.Collections
它提供了一系列静态方法,用于对集合(如List
、Set
、Map
等)进行操作。这些操作包括排序、查找、替换、同步等多种功能,帮助开发者更方便地处理集合数据。以下是Collections 提供的一些主要方法的总结。
sort
对指定的 List
进行自然排序(元素需实现 Comparable
接口)。或根据指定的 Comparator
实现来对 List
进行排序,通过自定义 Comparator
可以灵活地定义排序规则,比如实现降序排序或者按照特定业务逻辑排序等。
示例代码
// 示例1 :使用 sort 对列表进行排序private static void sortList(){// 创建一个整数列表List<Integer> numberList = new ArrayList<>();numberList.add(5);numberList.add(3);numberList.add(8);numberList.add(1);// 1. 使用sort方法进行自然排序(升序)List<Integer> sortedList = new ArrayList<>(numberList);Collections.sort(sortedList);System.out.println("升序排序后的列表: " + sortedList);// 2. 使用自定义Comparator进行降序排序Comparator<Integer> reverseComparator = (a, b) -> b - a;Collections.sort(numberList, reverseComparator);System.out.println("降序排序后的列表: " + numberList);}
binarySearch
二分查找。在已排序(升序)的 List
中使用二分查找算法查找指定元素 key
,返回元素在列表中的索引,如果不存在则返回一个特定的负数表示插入点。
示例代码
// 示例2 :查找元素(二分查找,要求列表已排序)private static void binarySearch() {// 创建一个整数列表List<Integer> sortedList = new ArrayList<>();sortedList.add(1);sortedList.add(2);sortedList.add(3);sortedList.add(4);sortedList.add(5);// 3. 查找元素(二分查找,要求列表已排序)int index = Collections.binarySearch(sortedList, 3);System.out.println("元素3在升序排序后的列表中的索引: " + index);}
reverse
反转指定 List
中元素的顺序。
示例代码
// 示例3 :反转列表元素顺序private static void reverseList() {// 创建一个整数列表List<Integer> sortedList = new ArrayList<>();sortedList.add(1);sortedList.add(2);sortedList.add(3);sortedList.add(4);sortedList.add(5);// 4. 反转列表元素顺序Collections.reverse(sortedList);System.out.println("反转后的列表: " + sortedList);}
fill
用指定的对象 obj
填充整个 List
,也就是将列表中的所有元素都设置为 obj
。
示例代码
// 示例4 :填充列表private static void fillList() {// 创建一个字符串列表List<String> stringList = new ArrayList<>();stringList.add("old");Collections.fill(stringList, "new");System.out.println("填充后的字符串列表: " + stringList);}
max(最大值)
根据元素的自然顺序返回集合中的最大元素(元素需实现 Comparable
接口)。或依据指定的 Comparator
返回集合中的最大元素。
min(最小值)
根据元素的自然顺序返回集合中的最小元素(元素需实现 Comparable
接口)。或依据指定的 Comparator
返回集合中的最小元素。
示例代码
// 示例5 :获取最大值和最小值(自然顺序)private static void getMaxAndMin() {List<Integer> numberList = new ArrayList<>();numberList.add(10);numberList.add(20);numberList.add(5);System.out.println("最大值(自然顺序): " + Collections.max(numberList));System.out.println("最小值(自然顺序): " + Collections.min(numberList));}
unmodifiableList(不可变集合)
返回指定 List
的不可变视图,对该视图进行修改操作会抛出 UnsupportedOperationException
,可用于保护原始列表不被意外修改。类似的还有 unmodifiableSet
、unmodifiableMap
等针对 Set
和 Map
类型创建不可变视图的方法。
示例代码
// 示例6 :创建不可变列表视图示例private static void createImmutableList() {List<Integer> sortedList = new ArrayList<>();sortedList.add(1);sortedList.add(2);sortedList.add(3);sortedList.add(4);sortedList.add(5);// 创建不可变列表视图示例List<Integer> immutableList = Collections.unmodifiableList(sortedList);// 下面这行代码会抛出UnsupportedOperationException异常,因为不可变视图不允许修改// immutableList.add(99);// 不可变的Set、MapSet<Integer> immutableSet = Collections.unmodifiableSet(new HashSet<>(sortedList));Map<Integer, String> immutableMap = Collections.unmodifiableMap(new HashMap<>());}
synchronizedList(同步集合)
返回指定 List
的线程安全的同步包装版本,适用于多线程环境下对列表的操作,避免并发修改异常等问题。同样也有针对 Set
和 Map
的同步包装方法如 synchronizedSet
、synchronizedMap
。
示例代码
// 示例7 :使用 synchronizedList 创建线程安全的列表private static void synchronizedList() {List<Integer> sortedList = new ArrayList<>();sortedList.add(1);sortedList.add(2);sortedList.add(3);sortedList.add(4);sortedList.add(5);// 创建线程安全的列表List<Integer> synchronizedList = Collections.synchronizedList(sortedList);// 通过synchronizedList获取的列表是线程安全的,但是需要注意的是,对列表的迭代操作仍然需要手动同步synchronized (synchronizedList) {for (Integer num : synchronizedList) {System.out.println(num);}}}
copy(拷贝)
将 src
列表中的元素拷贝到 dest
列表中,要求 dest
列表要有足够的空间(通常先创建一个合适大小的目标列表)
nCopies(创建不可变列表并填充指定元素)
它用于创建一个不可变的List
,其中包含指定数量(n
)的指定对象(o
)。
示例代码
// 示例8 :使用 nCopies 创建指定大小的列表,并填充指定元素,使用copy复制一个Listprivate static void Copy() {List<Integer> sortedList = new ArrayList<>();sortedList.add(1);sortedList.add(2);sortedList.add(3);sortedList.add(4);sortedList.add(5);// 创建一个包含10个元素的列表,每个元素都是0List<Integer> copyList = new ArrayList<>(Collections.nCopies(10, 0));System.out.println("创建的列表: " + copyList);Collections.copy(copyList, sortedList);System.out.println("拷贝后: copyList: " + copyList);}
shuffle(重新洗牌)
用于对指定的List
进行随机重排(洗牌操作),使得列表中的元素顺序被打乱,并且所有可能的排列出现的概率大致相等。
示例代码
// 示例9 :使用 shuffle 对列表进行洗牌private static void shuffleList() {List<Integer> arrayList = new ArrayList<>();arrayList.add(1);arrayList.add(2);arrayList.add(3);arrayList.add(4);Collections.shuffle(arrayList);System.out.println("Shuffled ArrayList: " + arrayList);List<Integer> linkedList = new LinkedList<>();linkedList.add(5);linkedList.add(6);linkedList.add(7);linkedList.add(8);Collections.shuffle(linkedList);System.out.println("Shuffled LinkedList: " + linkedList);}
swap(交换元素)
用于交换指定列表中两个指定位置上的元素。
// 示例10 :使用 swap 交换列表中的元素private static void swapList() {// 创建一个包含若干元素的列表List<String> fruitList = new ArrayList<>();fruitList.add("Apple");fruitList.add("Banana");fruitList.add("Cherry");fruitList.add("Date");System.out.println("交换前的列表: " + fruitList);// 使用Collections.swap方法交换列表中指定位置的元素// 交换索引为1和索引为3的元素(也就是交换 "Banana" 和 "Date")Collections.swap(fruitList, 1, 3);System.out.println("交换后的列表: " + fruitList);}
rotate(元素右移)
用于将指定列表中的元素向右旋转指定的距离。旋转操作会改变列表中元素的顺序,但是不会改变列表的大小。如果旋转的距离大于列表的大小,那么这个距离会被列表的大小取模。旋转的距离是指列表中的元素将要移动的位置数。如果距离是正数,元素将向右移动;如果距离是负数,元素将向左移动。
示例代码
// 示例11 :使用 rotate 向右旋转列表中的元素private static void rotateList() {// 创建一个包含若干元素的列表List<String> fruitList = new ArrayList<>();fruitList.add("Apple");fruitList.add("Banana");fruitList.add("Cherry");fruitList.add("Date");// 打印原始列表System.out.println("Original list: " + fruitList);// 向右旋转列表中的元素,距离为2Collections.rotate(fruitList, 2);// 打印旋转后的列表System.out.println("Rotated list: " + fruitList);}
replaceAll(替换全部)
用于将列表中所有出现的一个指定的元素替换为另一个元素。这个方法会修改原始的列表。调用此方法时,列表中的所有匹配元素都会被替换。
示例代码
// 示例12 :replaceAll 替换列表中的元素private static void replaceAll(){// 创建一个包含若干元素的列表List<String> fruitList2 = new ArrayList<>();fruitList2.add("Apple");fruitList2.add("Banana");fruitList2.add("Cherry");fruitList2.add("Date");// 打印原始列表System.out.println("Original list: " + fruitList2);// 使用Collections.replaceAll方法替换列表中的元素 将列表中的 "Banana" 替换为 "Grape"Collections.replaceAll(fruitList2, "Banana", "Grape");// 打印替换后的列表System.out.println("Replaced list: " + fruitList2);}
indexOfSubList(找到第一个包含子元素的位置)
用于返回列表中第一次出现的指定子列表的起始索引,如果列表不包含子列表,则返回 -1。
lastIndexOfSubList(找到最后一个包含子元素的位置)
用于返回列表中最后一次出现的指定子列表的起始索引,如果列表不包含子列表,则返回 -1。
示例代码
// 示例13 :indexOfSubList 和 lastIndexOfSubList 查找子列表的位置private static void indexOfSubList(){// 创建一个包含若干元素的列表List<String> fruitList3 = new ArrayList<>();fruitList3.add("Apple");fruitList3.add("Banana");fruitList3.add("Cherry");fruitList3.add("Date");fruitList3.add("Apple");fruitList3.add("Banana");// 创建一个包含若干元素的子列表List<String> subList = new ArrayList<>();subList.add("Apple");subList.add("Banana");// 使用Collections.indexOfSubList方法查找子列表的位置int index1 = Collections.indexOfSubList(fruitList3, subList);System.out.println("Index of sublist: " + index1);// 使用Collections.lastIndexOfSubList方法查找子列表的位置int index2 = Collections.lastIndexOfSubList(fruitList3, subList);System.out.println("Last index of sublist: " + index2);}
checkedCollection(进行类型检查的集合)
用于创建一个动态类型安全的集合视图。在运行时会对添加、修改等操作涉及的元素类型进行严格检查,确保集合中的元素类型符合指定的类型要求,若不符合则抛出 ClassCastException
异常,以此增强程序的类型安全性。同样也有针对List、 Set
和 Map
的方法如 checkedList、checkedSet和 checkedMap。
示例代码
// 示例14 : 使用checkedCollection创建类型检查集合private static void checkedCollection(){ArrayList rawList = new ArrayList<>();rawList.add(1);rawList.add("hello");// 创建一个只允许存放Integer类型元素的检查集合,以rawList为基础Collection checkedCollection = Collections.checkedCollection(rawList, Integer.class);try {// 尝试添加一个符合要求的Integer元素,操作正常checkedCollection.add(2);// 尝试添加一个不符合要求的String元素,会抛出ClassCastExceptioncheckedCollection.add("world");} catch (ClassCastException e) {System.out.println("类型不匹配,出现异常: " + e.getMessage());}}
emptyList(创建一个空集合)
该方法常用于需要返回一个空列表的情况,避免创建不必要的可变列表实例,提升性能和代码的简洁性。同样也有针对Set
和 Map
的方法如emptySet和emptyMap 等。
singletonList(单元素集合)
方法会创建一个不可变的列表,该列表只包含一个指定的元素。这个列表的长度固定为 1
,同样也是不可变的,任何修改操作都会引发 UnsupportedOperationException
异常。常用于只需要表示单个元素的列表场景,比如某些方法要求传入一个列表参数,但实际只有一个值的情况。同样也有针对Set和Map的方法如singleton和singletonMap。
示例代码
// 示例15. 创建空集合,单元素集合private static void emptyAndSingleton(){// 示例18. 创建空集合List<String> empty = Collections.emptyList();System.out.println("创建的空列表: " + empty);// 示例19. 创建单元素集合List<String> singleton = Collections.singletonList("hello");System.out.println("创建的单元素列表: " + singleton);// 创建单元素只读MapMap<String, Integer> readOnlyMap = Collections.singletonMap("key", 1);System.out.println("创建的只读Map: " + readOnlyMap);// 创建不可变SetSet<String> immutableSet2 = Collections.singleton("hello");System.out.println("创建的不可变Set: " + immutableSet2);}
frequency(统计元素出现次数)
方法用于统计指定元素在给定集合中出现的次数。它遍历整个集合,通过比较元素是否相等(使用 equals
方法判断)来确定指定元素出现的频次,然后返回对应的整数值。
示例代码
// 示例15.frequency 计算元素出现的次数private static void frequency(){List<String> list = new ArrayList<>();list.add("apple");list.add("banana");list.add("apple");int count = Collections.frequency(list, "apple");System.out.println("元素 'apple' 在列表中出现的次数: " + count);}
disjoint(判断两个列表是否不相交)
用于判断两个集合是否没有共同的元素(即是否 “不相交”)。它会遍历两个集合中的元素,通过比较元素是否相等(使用 equals
方法判断)来确定它们之间是否存在交集。如果两个集合没有任何相同的元素,则返回 true
;反之,若存在至少一个相同元素,则返回 false
。
示例代码
// 示例16.disjoint 判断两个集合是否有交集private static void disjoint(){List<String> list1 = new ArrayList<>();list1.add("a");list1.add("b");List<String> list2 = new ArrayList<>();list2.add("c");list2.add("d");boolean disjoint = Collections.disjoint(list1, list2);System.out.println("两个集合是否不相交: " + disjoint);List<String> list3 = new ArrayList<>();list3.add("a");list3.add("e");disjoint = Collections.disjoint(list1, list3);System.out.println("另外两个集合是否不相交: " + disjoint);}
newSetFromMap
方法利用给定的 Map
来创建一个 Set
。实际上返回的 Set
实现是基于传入的 Map
的,Set
中的元素对应 Map
的键,添加到 Set
中的元素会在 Map
中相应地添加键,并将对应的值设置为 Boolean.TRUE
。这个方法常用于需要自定义 Set
的一些特性(例如基于特定的 Map
实现来获得不同的性能、同步等特性)的场景。
示例代码
// 示例17. 使用newSetFromMap创建基于Map的Setprivate static void newSetFromMap(){Map<String, Boolean> underlyingMap = new HashMap<>();// 基于自定义的Map创建一个SetSet<String> customSet = Collections.newSetFromMap(underlyingMap);customSet.add("element1");customSet.add("element2");System.out.println("基于Map创建的Set: " + customSet);System.out.println("对应的Map内容: " + underlyingMap);}
相关推荐
开源项目 JavaUsefulMode:JavaUsefulMode: 基于Java 语言的自定义实用工具集
JavaUsefulMode是小编编写Java方向学习专栏时的代码示例汇总总结,其中包含了本章节对于java.util.Collections的工具类学习的代码示例,感兴趣的小伙伴可以直接下载学习。
相关文章:

Wend看源码-Java-Collections 工具集学习
摘要 java.util.Collections它提供了一系列静态方法,用于对集合(如List、Set、Map等)进行操作。这些操作包括排序、查找、替换、同步等多种功能,帮助开发者更方便地处理集合数据。以下是Collections 提供的一些主要方法的总结。…...

[JAVA]MyLogger
import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.logging.*;/*** 可以自已定义日志打印格式,这样看起来比较方便些**/ class MyFormatter extends Formatter {Overridepublic String format(LogRecord ar…...

玩转OCR | 腾讯云智能结构化OCR初次体验
目录 一、什么是OCR(需要了解) 二、产品概述与核心优势 产品概述 智能结构化能做什么 举例说明(选看) 1、物流单据识别 2、常见证件识别 3、票据单据识别 4、行业材料识别 三、产品特性 高精度 泛化性 易用性 四、…...

记一次 dockerfile 的循环依赖错误
文章目录 1. 写在最前面1.1 具体循环依赖的例子 2. 报错的位置2.1 代码快速分析2.2 代码总结2.3 关于 parser 的记录 3. 碎碎念 1. 写在最前面 笔者在使用 dockerfile 多阶段构建的功能时,写出了一个「circular dependency detected on stage: xx」的错误。 解决方…...

Trimble天宝X9三维扫描仪为建筑外墙检测提供了全新的解决方案【沪敖3D】
随着城市化进程的快速推进,城市高层建筑不断增多,对建筑质量的要求也在不断提高。建筑外墙检测,如平整度和垂直度检测,是衡量建筑质量的重要指标之一。传统人工检测方法不仅操作繁琐、效率低下,还难以全面反映墙体的真…...

【MySQL】深度学习数据库开发技术:使用CC++语言访问数据库
**前言:**本节内容介绍使用C/C访问数据库, 包括对数据库的增删查改操作。 主要是学习一些接口的调用, 废话不多说, 开始我们的学习吧! ps:本节内容比较容易, 友友们放心观看哦! 目录 准备mysql…...

LabVIEW化工实验室设备故障实时监测
化工实验室中,各类设备的运行状态直接影响实验的精度与安全性。特别是重要分析仪器的突发故障,可能导致实验中断或数据失效。为了实现设备运行状态的实时监控与故障快速响应,本文提出了一套基于LabVIEW的解决方案,通过多参数采集、…...

单例模式懒汉式、饿汉式(线程安全)
饿汉式单线程安全吗 饿汉式单例(Eager Singleton)是线程安全的。这种实现方式在类加载时就创建了单例实例,因此在多线程环境中,不存在多个线程同时创建实例的问题。 饿汉式单例的实现 以下是一个饿汉式单例的示例: …...

Cursor登录按钮点击没反应
问题 系统:Windows11 Cursor:Cursor 0.44.9 当安装Cursor打开进行登录时,点击Sign in没反应 解决方案 1.打开window11的设置 2.点击应用中的默认应用 3.在设置应用程序的默认值中搜索Google(没有Google浏览器的尝试下载一个&a…...

论文实现:Reactive Nonholonomic Trajectory Generation via Parametric Optimal Control
1. 多项式螺旋 曲率: κ ( s ) a 0 a 1 s a 2 s 2 a 3 s 3 a 4 s 4 a 5 s 5 \begin{align} \kappa(s) a_0 a_1s a_2s^2 a_3s^3 a_4s^4 a_5s^5 \end{align} κ(s)a0a1sa2s2a3s3a4s4a5s5 机器人朝向: θ ( s ) a 0 s a 1 …...

基于单片机中药存放环境监测系统的实现
基于单片机中药存放环境监测系统的实现 项目开发背景 随着现代中药的广泛应用,中药材的存储环境对其质量有着至关重要的影响。温湿度、烟雾、火灾等环境因素,若不加以控制,将会导致中药材失效或变质。因此,设计一个基于单片机的…...

九垠赢+商业管理系统 Common.ashx 文件上传致RCE漏洞复现
0x01 产品简介 九垠赢+商业管理系统是基于互联网技术的进销存管理软件,适用于新零售背景下各种业态的线上线下一体化的商超经营管理。赢+ERP以商业管理系统为底座,融合了多种软、硬件解决方案,实现了从企业、供应商、三方平台到顾客等日常管理的全线数字化、智能化和移动化…...

速盾:服务器CDN加速解析的好处有哪些呢?
随着互联网应用的普及,越来越多的企业开始关注如何提升网站的访问速度和用户体验。为了实现这一目标,许多企业选择使用CDN(内容分发网络)来加速网站的内容分发。CDN通过在全球范围内分布多个节点,将内容缓存到离用户最…...

C++ 设计模式:备忘录模式(Memento Pattern)
链接:C 设计模式 链接:C 设计模式 - 状态模式 备忘录模式(Memento Pattern)是一种行为设计模式,它允许在不破坏封装性的前提下捕获和恢复对象的内部状态。这个模式在需要保存和恢复对象状态的场景中非常有用ÿ…...

Android 系统 Activity 系统层深度定制的方法、常见问题以及解决办法
Android 系统 Activity 系统层深度定制的方法、常见问题以及解决办法 目录 引言Activity 系统层概述Activity 系统架构图Activity 系统层深度定制的方法 4.1 自定义 Activity 生命周期4.2 自定义 Activity 启动流程4.3 自定义 Activity 转场动画4.4 自定义 Activity 窗口管理4…...

PDF怎么压缩得又小又清晰?5种PDF压缩方法
PDF 文件在日常办公与学习中使用极为频繁,可想要把它压缩得又小又清晰却困难重重。一方面,PDF 格式本身具有高度兼容性,集成了文字、图像、矢量图等多样元素,压缩时难以兼顾不同元素特性,稍不注意,文字就会…...

YK人工智能(三)——万字长文学会torch深度学习
2.1 张量 本节主要内容: 张量的简介PyTorch如何创建张量PyTorch中张量的操作PyTorch中张量的广播机制 2.1.1 简介 几何代数中定义的张量是基于向量和矩阵的推广,比如我们可以将标量视为零阶张量,矢量可以视为一阶张量,矩阵就是…...

关于CISP报名费用详情
CISP即“注册信息安全专业人员”,是中国信息安全测评中心实施的国家认证项目,旨在培养信息安全领域的专业人才。对于有意报考CISP的考生而言,了解报名考试费用是备考过程中不可或缺的一环。 CISP的报名考试费用主要包括培训费用、考试费用、…...

vim 按下esc后取消高亮
配置 ideavimrc文件 " 按下 Esc 键时自动取消高亮 " 在普通模式下按下 Esc 键取消高亮 nnoremap <Esc> :nohlsearch<CR> " 在插入模式下按下 Esc 键取消高亮 inoremap <Esc> <Esc>:nohlsearch<CR>" 额外:当退出…...

SwiftUI:多语言实现富文本插值
实现的UI需求: 要求: 英文显示:3068 people have joined this plan today! 中文显示:今日有 3068 人已加入此计划! 实现代码: Text(AttributedString(localized:"**\(payPeoples)** people have joi…...

操作系统基础
概念 控制和管理操作系统软件和硬件 用户观点:用户和计算机之间的接口 基本概念 特征 并发,共享,虚拟,异步 功能 处理机管理,存储器管理,文件管理,设备管理 作为用户和硬件接口 命令接口&am…...

函数调用流程可用工具
方法 1、gdb,这个网上很多找找就有 2、tcmalloc,直接在调用的地方调一个malloc就可以看到调用的流程,具体见tcmalloc 3、backtrace,个人感觉这么最方便,具体见backtrace...

UniApp 页面布局基础
一、UniApp 页面布局简介 在当今的移动应用开发领域,跨平台开发已成为一种主流趋势。UniApp作为一款极具影响力的跨平台开发框架,凭借其“一套代码,多端运行”的特性,为开发者们提供了极大的便利,显著提升了开发效率。…...

2D图像测量到3D点云之物体三维尺寸测量!!!!
0,引言 本文将从双目采集的2D图像到3D点云进行转化,并进行物体尺寸测量,旨在为读者展示2D图像如何关联3D点云,并进行相关工业应用。 将2D图像转化为3D点云,并进行物体尺寸测量的技术,在工业领域有着广泛的…...

[TOTP]android kotlin实现 totp身份验证器 类似Google身份验证器
背景:自己或者公司用一些谷歌身份验证器或者microsoft身份验证器,下载来源不明,或者有广告,使用不安全。于是自己写一个,安全放心使用。 代码已开源:shixiaotian/sxt-android-totp: android totp authenti…...

2025决战智驾:从中阶卷到L3,车企需要抓好一个数据闭环
作者 |王博 编辑 |德新 全国都能开之后,智驾继续走向哪里? 2024年末,大部分主流车企已经实现了无(高精度)图全国都能开。而第一梯队的玩家,从以规则为主的算法框架,向神经网络模型为主的新架构…...

电子电气架构 --- 汽车电子电器设计概述
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 所谓鸡汤,要么蛊惑你认命,要么怂恿你拼命,但都是回避问题的根源,以现象替代逻辑,以情绪代替思考,把消极接受现实的懦弱,伪装成乐观面对不幸的…...

SpringAI从入门到熟练
学习SpringAI的记录情况 文章目录 前言 因公司需要故而学习SpringAI文档,故将自己所见所想写成文章,供大佬们参考 主要是为什么这么写呢,为何不抽出来呢,还是希望可以用的时候更加方便一点,如果大家有需求可以自行去…...

[算法] [leetcode-20] 有效的括号
20 有效的括号 给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合…...

R语言入门笔记:第一节,快速了解R语言——文件与基础操作
关于 R 语言的简单介绍 上一期 R 语言入门笔记里面我简单介绍了 R 语言的安装和使用方法,以及各项避免踩坑的注意事项。我想把这个系列的笔记持续写下去。 这份笔记只是我的 R 语言入门学习笔记,而不是一套 R 语言教程。换句话说:这份笔记不…...