62-Java-面试专题(1)__基础

62-Java-面试专题(1)__基础-- 笔记

笔记内容来源与黑马程序员教学视频


文章目录

  • 62-Java-面试专题(1)__基础-- 笔记
  • Java-面试专题(1)
    • 笔记中涉及资源:
  • 一、二分查找
    • ①:代码实现
      • 1. 流程
      • 2. 代码实现
      • 3. 测试
    • ②:解决整数溢出(方法一)
    • ③:解决整数溢出(方法二)
    • ③:选择题目
    • ④:注意事项
  • 二、冒泡排序
    • ①:初步实现
    • ②:减少冒泡次数
    • ③:进一步优化
    • ④:总结
  • 三、选择排序
    • ①:代码实现
    • ②:总结
  • 四、插入排序
    • ①:代码实现
    • ②:总结
    • ③:插入和选择推到某一论排序结果
  • 五、快速排序
    • ①:文字描述
    • ②:单边循环
    • ③:双边循环
      • 1. 代码实现
      • 2. 注意事项
    • ④:特点
  • 六、ArrayList扩容规则
  • 七、Iterator_FailFast_FailSafe
  • 八、LinkedList
  • 九、HashMap


Java-面试专题(1)

笔记中涉及资源:

一、二分查找

①:代码实现

1. 流程

  • 前提:有已排序数组A(假设已经做好)

  • 定义左边界L、右边界R,确定搜索范围,循环执行二分查找(3、4两步)

  • 获取中间索引M=Floor(L+R)/2)

  • 中间索引的值A[M]与待搜索的值T进行比较

    • ① A[M]==T表示找到,返回中间索引
    • ② A[M>T,中间值右侧的其它元素都大于T,无需比较,中间索引左边去找,M-1设置为右边界,重新查找
    • ③ A[M]<T,中间值左侧的其它元素都小于T,无需比较,中间索引右边去找,M+1设置为左边界,重新查找
  • 当L>R时,表示没有找到,应结束循环

2. 代码实现

    /*** 数据准备初始化一个排好序的数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 10;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}// 排序Arrays.sort(array);return array;}/*** 二分查找代码实现*/public static void testBinarySearch() {int[] array = initArray();System.out.println(Arrays.toString(array));System.out.println("请输入您要查找的数据:");int number = scanner.nextInt();// 初始化 开头 结尾 中间的下标int start = 0, end = array.length -1, middle;while (start <= end) {middle = (start + end) >>1;if (array[middle] == number){System.out.println("您要查找的数字下标为:" + middle);return;}else if (array[middle] > number){end = middle - 1;}else {start = middle +1;}}System.err.println("您要查找的数字不存在!");}public static void main(String[] args) {testBinarySearch();}

3. 测试

在这里插入图片描述
在这里插入图片描述

②:解决整数溢出(方法一)

在这里插入图片描述

③:解决整数溢出(方法二)

在这里插入图片描述

③:选择题目

  • 1.有一个有序表为1,5,8,11,19,22,31,35,40,45,48,49,50当二分查找值为48的结点时,查找成功需要比较的次数
4
  • 奇数二分取中间

  • 偶数二分取中间靠左

  • 2.使用二分法在序列1,4,6,7,15,33,39,50,64,78,75,81,89,96中查找元素81时,需要经过()次比较

4
  • 3.在已经的128个数组中二分查找一个数,需要比较的次数最多不超过多少次
7
  • 2n=128或128/2/2…直到1
  • 问题转化log^2 128,如果手边有计算器,用log10 128/log10 2
    • 是整数,则该整数即为最终结果
    • 是小数,则舍去小数部分,整数加一为最终结果

④:注意事项

  • 1.目前介绍的二分查找是以jdk中Arrays.binarySearch的实现作为讲解示范,后续选择题的解答思路也是以此为准
  • 2.但实际上,二分查找有诸多变体,一旦使用变体的实现代码,则左右边界的选取会有变化,进而会影响之前选择题的答案选择

二、冒泡排序

①:初步实现

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}public static void main(String[] args) {// 调用方法获取一个无序的数组int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));for (int i = 0; i < array.length -1; i++) {for (int j = 0; j < array.length - 1 - i; j++) {if (array[j] > array[j + 1]){array[j + 1] = array[j + 1] + array[j];array[j] = array[j + 1] - array[j];array[j + 1] = array[j + 1] - array[j];}}}System.out.println("排序后 :" + Arrays.toString(array));}

在这里插入图片描述

②:减少冒泡次数

在这里插入图片描述

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}public static void main(String[] args) {// 调用方法获取一个无序的数组int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));for (int i = 0; i < array.length -1; i++) {// 是否发生交换boolean swapped = false;for (int j = 0; j < array.length - 1 - i; j++) {System.out.println("比较次数:" + j);if (array[j] > array[j + 1]){array[j + 1] = array[j + 1] + array[j];array[j] = array[j + 1] - array[j];array[j + 1] = array[j + 1] - array[j];swapped = true;}}if (!swapped) {break;}System.out.println("第" + (i+1) + "排序 :" + Arrays.toString(array));}}

在这里插入图片描述

③:进一步优化

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}public static void main(String[] args) {// 调用方法获取一个无序的数组int[] array = initArray();int n = array.length - 1;System.out.println("排序前 :" + Arrays.toString(array));for (int i = 0; i < n; i++) {int last = 0;for (int j = 0; j < n; j++) {System.out.println("比较次数:" + j);if (array[j] > array[j + 1]){array[j + 1] = array[j + 1] + array[j];array[j] = array[j + 1] - array[j];array[j + 1] = array[j + 1] - array[j];last = j;}}n = last;System.out.println("第" + (i+1) + "排序 :" + Arrays.toString(array));}}

在这里插入图片描述

④:总结

  • 文字描述
    (以升序为例)

    • 1.依次比较数组中相邻两个元素大小,若[a]>a[+1],则交换两个元素,两两都比较一遍称为一轮冒泡,结果是让最大的元素排至最后
    • 2.重复以上步骤,直到整个数组有序
  • 优化方式:

    • 每轮冒泡时,最后一次交换索引可以作为下一轮冒泡的比较次数,如果这个值为零,表示整个数组有序,直接退出外层循环即可

三、选择排序

①:代码实现

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}public static void main(String[] args) {int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));for (int i = 0; i < array.length - 1; i++) {// 每轮最小值对应的下标int minIndex = i;for (int j = i + 1; j < array.length; j++) {if (array[minIndex] > array[j]){minIndex = j;}}if (minIndex != i) {array[i] = array[minIndex] + array[i];array[minIndex] = array[i] - array[minIndex];array[i] = array[i] - array[minIndex];}System.out.println("第" + (i+1) + "次排序 :" + Arrays.toString(array));}}

②:总结

文字描述(以升序为例)

  • 1.将数组分为两个子集,排序的和未排序的,每一轮从未排序的子集中选出最小的元素,放入排序子集
  • 2.重复以上步骤,直到整个数组有序

优化方式

  • 1.为减少交换次数,每一轮可以先找最小的索引,在每轮最后再交换元素

与冒泡排序比较

  • 1.二者平均时间复杂度都是0(n2)
  • 2.选择排序一般要快于冒泡,因为其交换次数少
  • 3.但如果集合有序度高,冒泡优于选择
  • 4.冒泡属于稳定排序算法,而选择属于不稳定排序

四、插入排序

①:代码实现

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}public static void main(String[] args) {int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));for (int i = 1; i < array.length; i++) {// 假设最小值int minNum = array[i];int j = i-1;while (j >= 0) {if (minNum < array[j]) {array[j + 1] = array[j];}else {break;}j--;}array[j + 1] = minNum;System.out.println("第" + (i) + "次排序 :" + Arrays.toString(array));}}

②:总结

文字描述(以升序为例)

  • 1.将数组分为两个区域,排序区域和未排序区域,每一轮从未排序区域中取出第一个元素,插入到排序区域(需保证顺序)
  • 2.重复以上步骤,直到整个数组有序
    优化方式
  • 1.待插入元素进行比较时,遇到比自己小的元素,就代表找到了插入位置,无需进行后续比较
  • 2.插入时可以直接移动元素,而不是交换元素
    与选择排序比较
  • 1.二者平均时间复杂度都是0(n2)
  • 2.大部分情况下,插入都略优于选择
  • 3.有序集合插入的时间复杂度为O(m)公
  • 4.插入属于稳定排序算法,而选择属于不稳定排序

③:插入和选择推到某一论排序结果

1. 使用直接插入排序算法对序列18,23,19,9,23,15进行排序,第三趟排序后的结果为()

  • A.9,18,15,23,19,23
  • B.18,23,19,9,23,15
  • C.18,19,23,9,23,15
  • D.9,18,19,23,23,15

2. 使用直接选择排序算法对序列18,23,19,9,23,15进行排序,第3趟排序后的结果为()

  • A.9,23,19,18,23,15
  • B.9,15,18,19,23,23
  • C.18,19,23,9,23,15
  • D.18,19,23,9,15,23

五、快速排序

①:文字描述

  • 每一轮排序选择一个基准点(pivot)进行分区

    • 1.让小于基准点的元素的进入一个分区,大于基准点的元素的进入另一个分区
    • 2.当分区完成时,基准点元素的位置就是其最终位置
  • 在子分区内重复以上过程,直至子分区元素个数少于等于1,这体现的是分而治之的思想(divide-and-conquer)

②:单边循环

单边循环快排(lomuto洛穆托分区方案)

  • 选择最右元素作为基准点元素
  • j指针负责找到比基准点小的元素,一旦找到则与ⅰ进行交换
  • ⅰ指针维护小于基准点元素的边界,也是每次交换的目标索引
  • 最后基准点与ⅰ交换,ⅰ即为分区位置

在这里插入图片描述

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}/*** 选择一个基准点(pivot)进行分区* @param array 排序数组* @param l 左边界* @param pivot 基准点* @return 返回值 = 分区后中间索引值*/public static int  partition(int[] array, int l, int pivot){// 右侧基准点(值)int pivotNum = array[pivot];int i = l;for (int j = l; j < pivot; j++) {if (array[j] < pivotNum) {if (i != j){swap(array, i, j);}i ++;}}if (i != pivot){swap(array, i, pivot);}return i;}/*** 交换位置* @param array 数组* @param i 位置1* @param j 位置2*/private static void swap(int[] array, int i, int j) {int temp = array[j];array[j] = array[i];array[i] = temp;}/*** 递归排序* @param array 排序数组* @param l 左边界* @param pivot 基准点*/public static void quick(int[] array, int l, int pivot){if (l >= pivot){return;}int index = partition(array, l, pivot);quick(array,l, index -1);quick(array,index +1,pivot);}public static void main(String[] args) {int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));quick(array, 0, array.length - 1);System.out.println("排序后 :" + Arrays.toString(array));}

在这里插入图片描述

③:双边循环

双边循环快排(并不完全等价于hoare霍尔分区方案)

  • 选择最左元素作为基准点元素
  • j指针负责从右向左找比基准点小的元素,ⅰ指针负责从左向右
    找比基准点大的元素,一旦找到二者交换,直至ⅰ,j相交
  • 最后基准点与ⅰ(此时ⅰ与j相等)交换,ⅰ即为分区位置

1. 代码实现

    /*** 数据准备初始化一个数组*/public static int[] initArray(){Random random = new Random();// 创建一个数组,长度在10-20之间int len = random.nextInt(10) + 5;int[] array = new int[len];// 遍历添加数据for (int i = 0; i < array.length; i++) {array[i] = random.nextInt(100);}return array;}/*** 选择一个基准点(pivot)进行分区* @param array 排序数组* @param l 左边界* @param r 右边界* @return 返回值 = 分区后中间索引值*/public static int  partition(int[] array, int l, int r){// 左侧基准点(值)int pivotNum = array[l];int i = l;int j = r;while (i < j) {// j从右边找比基准点小的值while (i < j && array[j] > pivotNum){j--;}// i 从左边找比基准点大的值while (i < j && array[i] <= pivotNum){i++;}swap(array, i, j);}swap(array, i, l);return i;}/*** 交换位置* @param array 数组* @param i 位置1* @param j 位置2*/private static void swap(int[] array, int i, int j) {int temp = array[j];array[j] = array[i];array[i] = temp;}/*** 递归排序* @param array 排序数组* @param l 左边界* @param pivot 基准点*/public static void quick(int[] array, int l, int pivot){if (l >= pivot){return;}int index = partition(array, l, pivot);quick(array,l, index -1);quick(array,index +1,pivot);}public static void main(String[] args) {int[] array = initArray();System.out.println("排序前 :" + Arrays.toString(array));quick(array, 0, array.length - 1);System.out.println("排序后 :" + Arrays.toString(array));}

2. 注意事项

  • 1.基准点在左边,并且要先 j 后 i (先从右边找在从左边找)

  • 2.while ( i < j && array[ j ] > pivotNum)

// j从右边找比基准点小的值
while (i < j && array[j] > pivotNum){j--;
}
  • 3.while (i < j && array[i] <= pivotNum)
// i 从左边找比基准点大的值
while (i < j && array[i] <= pivotNum){i++;
}

④:特点


附绿

  • 洛穆托vs霍尔 https:/qastack.cn/cs/11458/quicksort-partitioning-hoare-Vs-lomuto

六、ArrayList扩容规则

可以看看这位博主的:https://www.cnblogs.com/ruoli-0/p/13714389.html

  • ArrayList()会使用长度为零的数组
    • 直接调用无参方法初始容量为0(空数组)
  • ArrayList(int initialCapacity)会使用指定容量的数组
    • 调用有参方法数组容量为传入的容量值
  • public ArrayList(Collection<?extends E>c)会使用c的大小作为数组容量
    • 传入的是一个集合使用的是集合的大小
  • add(0 bject o)首次扩容为10,再次扩容为上次容量的1.5倍
  • addAll(Collection c)没有元素时,扩容为Math.max(10,实际元素个数),有元素时为Math.max(原容量1.5倍,实际元素个数)
    • 如过集合中没有元素 扩容会在(10和实际元素个数)中选择一个大的,有元素时扩容会在(原容量1.5倍和实际元素个数)选择一个大的

ArrayList的特点:

  • 1.ArrayList的底层数据结构是数组,所以查找遍历快,增删慢。

  • 2.ArrayList可随着元素的增长而自动扩容,正常扩容的话,每次扩容到原来的1.5倍。

  • 3.ArrayList的线程是不安全的。

ArrayList的扩容:

扩容可分为两种情况:

第一种情况,当ArrayList的容量为0时,此时添加元素的话,需要扩容,三种构造方法创建的ArrayList在扩容时略有不同:

  • 1.无参构造,创建ArrayList后容量为0,添加第一个元素后,容量变为10,此后若需要扩容,则正常扩容。

  • 2.传容量构造,当参数为0时,创建ArrayList后容量为0,添加第一个元素后,容量为1,此时ArrayList是满的,下次添加元素时需正常扩容。

  • 3.传列表构造,当列表为空时,创建ArrayList后容量为0,添加第一个元素后,容量为1,此时ArrayList是满的,下次添加元素时需正常扩容。

第二种情况,当ArrayList的容量大于0,并且ArrayList是满的时,此时添加元素的话,进行正常扩容,每次扩容到原来的1.5倍。

七、Iterator_FailFast_FailSafe

  • ArrayList是fail-fast的典型代表,遍历的同时不能修改,尽快失败
  • CopyOnWriteArrayList是fail-safe的典型代表,遍历的同时可以修改,原理是读写分离

并发篇-32-ConcurrentHashMap

八、LinkedList

九、HashMap

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

解决CORS (跨源资源共享) 错误

问题引入 前端代码 <template><div id"hello-vue" class"demo">{{ message }}</div><el-button type"primary" click"handleClick">我是一个按钮</el-button></template><script setup>//加…

微信小程序 uniapp网络记账设计个人理财系统

文章目录 项目介绍具体实现截图技术介绍mvc设计模式小程序框架以及目录结构介绍错误处理和异常处理java类核心代码部分展示详细视频演示源码获取 项目介绍 aa账簿 (自动编号、用户id、用户账号、备注、登记时间、消费类型、创建时间、消费金额)&#xff1b; 配置文件 (自动编…

【SQL Server】华中农业大学空间数据库实验报告 实验一 数据库

实验目的 熟悉了解掌握SQL Server软件的基本操作与使用方法&#xff0c;认识界面&#xff0c;了解其两个基本操作系统文件&#xff0c;并能熟练区分与应用交互式与T-SQL式两种方法在SQL Server中如何进行操作&#xff1b;学习有关数据库的基本操作&#xff0c;包括&#xff1a…

大腾智能3D一览通携手飞书,实现高效设计协同

设计生产作为制造业的核心环节&#xff0c;其效率与协同性直接关系到企业的市场竞争力和响应速度。 在设计部门内部&#xff0c;虽然可以直接发送3D格式的文件进行沟通和评审&#xff0c;但当涉及到跨部门甚至是跨企业的协作时&#xff0c;情况就变得复杂。通常需要大量的多角…

Java项目实战II基于Spring Boot的药店管理系统的设计与实现(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。 一、前言 随着医疗行业的快速发展和人们对健康需…

qt QHeaderView详解

1、概述 QHeaderView 是 Qt 框架中的一个类&#xff0c;它通常作为 QTableView、QTreeView 等视图类的一部分&#xff0c;用于显示和管理列的标题&#xff08;对于水平头&#xff09;或行的标题&#xff08;对于垂直头&#xff09;。QHeaderView 提供了对这些标题的排序、筛选…

【Android】使用productFlavors构建多个变体

项目需求 在一个设备上安装两个一样的程序app 需求解决 我们知道每一个app都有一个包名的&#xff0c;如果一个app在Android设备上安装之后&#xff0c;再安装这个app的话会进行覆盖安装&#xff0c;因为他们两个的包名是一样的&#xff0c;默认是一个app。 但是我们现在需…

AI笔筒操作说明及应用场景

AI笔筒由来&#xff1a; 在快节奏的现代办公环境中&#xff0c;我们一直在寻找既能提升效率、增添便利&#xff0c;又能融入企业文化、展现个人品味的桌面伙伴。为此&#xff0c;我们特推出专为追求卓越、注重细节的您设计的AI笔筒礼品版&#xff0c;它集高科技与实用性于一身…

【笔面试常见题:三门问题】用条件概率、全概率和贝叶斯推导

1. 问题介绍 三门问题&#xff0c;又叫蒙提霍尔问题&#xff08;Monty Hall problem&#xff09;&#xff0c;以下是蒙提霍尔问题的一个著名的叙述&#xff0c;来自Craig F. Whitaker于1990年寄给《展示杂志》&#xff08;Parade Magazine&#xff09;玛丽莲沃斯莎凡特&#x…

Elasticsearch中时间字段格式用法详解

Elasticsearch中时间字段格式用法详解 攻城狮Jozz关注IP属地: 北京 2024.03.18 16:27:51字数 758阅读 2,571 Elasticsearch&#xff08;简称ES&#xff09;是一个基于Lucene构建的开源、分布式、RESTful搜索引擎。它提供了全文搜索、结构化搜索以及分析等功能&#xff0c;广泛…

sql数据库-DQL-基本查询

目录 举例表emp 查询多个字段 查询整张表所有数据 给字段名起别名&#xff08;更方便阅读&#xff09; 去除重复的数据 举例表emp 查询多个字段 SELECT 字段1,字段2,字段3...FROM 表名; 举例查询emp表中的name&#xff0c;workno&#xff0c;age字段返回 查询整张表所有数据 …

JqGird 动态生成列使用

使用场景&#xff1a; 在工作用需要自定义动态生成列&#xff0c;通过选择下拉框&#xff0c;加载列&#xff0c;通过查询加载列对应的数据信息 当选择文件源任务显示三列 当选择数据源任务显示两列 处理方式&#xff1a; 1. 首先在刚进入界面时初始化控件 $("#pageGri…

Rust项目结构

文章目录 一、module模块1.二进制文件的cargo项目2.库的cargo项目3.文件内的module 二、模块化项目结构1.关于module2.各个模块之间互相引用 三、推荐项目结构1.实例 参考 一、module模块 crate规则&#xff1a; 规则一&#xff1a;一个包中必须至少包含一个crate规则二&#…

电能管理系统(源码+文档+部署+讲解)

本文将深入解析“电能管理系统”的项目&#xff0c;探究其架构、功能以及技术栈&#xff0c;并分享获取完整源码的途径。 系统概述 “工厂电能管理系统” 是一款集设备管理、维修管理、能耗监测、节能分析、储能管理、充电桩管理、冷源站管理、报警管理、点检管理等功能于一体…

网上纪念馆(源码+文档+部署+讲解)

最近我在挖掘一些优秀的开源项目时&#xff0c;无意间发现了一个相当给力的系统——网上纪念馆系统。这个系统不仅功能完善&#xff0c;满足了线上祭祀和纪念的需求&#xff0c;而且代码结构清晰&#xff0c;易于二次开发。作为一名技术爱好者&#xff0c;我觉得有必要把这个好…

华为HarmonyOS打造开放、合规的广告生态 - 贴片广告

场景介绍 贴片广告是一种在视频播放前、视频播放中或视频播放结束后插入的视频或图片广告。 接口说明 接口名 描述 loadAd(adParam: AdRequestParams, adOptions: AdOptions, listener: AdLoadListener): void 请求单广告位广告&#xff0c;通过AdRequestParams、AdOptions…

责任链模式 Chain of Responsibility

1 意图 使多个对象都有机会处理请求&#xff0c;从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链&#xff0c;并沿着这条链传递该请求&#xff0c;直到有一个对象处理它为止。 2 结构 Handler 定义一个处理请求的接口;(可选)实现后继链。 ConcreteHandler …

【Linux】- 权限(2)

接上一篇文章&#xff0c;继续介绍linux权限的相关知识。https://blog.csdn.net/hffh123/article/details/143432940?spm1001.2014.3001.5501j 目录 一、chown&#xff1a;修改文件的拥有者 二、chgrp&#xff1a;修改文件所属组 三、关于other的介绍 四、文件类型 1、分类…

RTX5/FreeRTOS全家桶源码工程综合实战模板集成CANopen组件(2024-10-30)

【前言】 之前的视频教程分享了两期CANopen的专题&#xff0c;配套的例子都是基于裸机的&#xff0c;为了方便大家在OS下使用&#xff0c;本期视频带OS下的支持。 CANopen协议栈专题&#xff0c;实战方式系统了解NMT&#xff0c;PDO&#xff0c;SDO&#xff0c;时间戳&#x…

vue中实现列表无缝动态滚动

要想实现列表的动态无缝滚动&#xff0c;这里推荐两款组件&#xff0c;vue-seamless-scroll和vue3-seamless-scroll&#xff0c;组件的用法也非常简单&#xff0c;以下是使用方式。 vue2 vue2版本使用vue-seamless-scroll vue-seamless-scroll文档https://chenxuan0000.gith…