26. 可变参数和Collection集合工具类

可变参数与`Collections`

    • 1. 可变参数
      • 1. 概述
      • 2. 格式
      • 3. 代码示例
      • 4. 注意事项
    • 2. `Collections`集合工具类
      • 2.1 概述
      • 2.2 方法
      • 2.3 代码示例
      • 2.4 注意事项

1. 可变参数

1. 概述

可变参数(Variable Arguments)是指在参数列表中允许传入不定个数的参数。在许多编程语言中,可变参数通常用于传递相同类型的参数,并且允许传入任意个数的参数。

  • 可变参数的语法通常是通过使用"..." (省略号)来表示,它可以将传递的参数打包成数组。

例如:

public void method(String... args) {
    for (String arg : args) {
        System.out.println(arg);
    }
}

method("Hello", "World");  // 打印结果:Hello World
method("a", "b", "c");  // 打印结果:a b c

2. 格式

  1. 格式:

    修饰符 返回值类型 方法名(参数类型... 形参名){  }
    
  2. 底层

    其实是一个数组,只不过是java已经创建好的

  3. 作用

    在形参中接受多个数据

  4. 注意
    ​ 1. 一个方法只能有一个可变参数
    ​ 2. 如果方法中有多个参数,可变参数要放到最后。

3. 代码示例

  • 代码示例
    需求:利用可变参数求几个数的和
    package text.text02;
    
    /*可变参数(JDK5以后):
    1.格式
        修饰符 返回值类型 方法名(参数类型... 形参名){  }
        参数类型... 形参名
        例如:int... args
    2.底层:其实是一个数组,只不过是java已经创建好的
    3.作用:在形参中接受多个数据
    4.注意事项:
        1.形参列表中可变参数只能有一个
        2.可变参数必须放在形参列表的最后面
    
    需求:利用可变参数求几个数的和
     */
    public class text55 {
        public static void main(String[] args) {
            int sum = getSum(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
            System.out.println("这几个数的和为:" + sum);       //这几个数的和为:55
        }
    
        //利用可变参数定义方法
        public static int getSum(int... args) {
            int sum = 0;
            for (int arg : args) {
                sum = sum + arg;
            }
            return sum;
        }
    }
    
    
  • 输出结果
    在这里插入图片描述

4. 注意事项

  1. 可变参数通常应该作为参数列表的最后一个参数,因为在调用函数时,可变参数后面的参数将无法被传递或者识别。

  2. 在函数内部,可变参数实际上被当作一个数组(或者其他类似的数据结构)处理。因此,可以使用数组相关的操作来处理可变参数,如索引访问、遍历等。

  3. 当没有传递任何参数时,可变参数的值将为一个空数组(或者类似结构)。在函数内部,应该适当处理这种情况,以避免出现空指针异常或其他错误。

  4. 可变参数只能用于传递相同类型的参数。如果需要传递不同类型的参数,可以考虑使用重载函数或其他方式来处理。

  5. 使用可变参数时,需要注意参数的顺序。如果同时使用可变参数和其他类型的参数,需要确保传递参数时的顺序是正确的。

2. Collections集合工具类

2.1 概述

Collections 是 Java 编程语言中提供的一个集合工具类,位于 java.util 包中。它提供了一系列静态方法,用于对集合进行常见的操作和算法实现。

Collections 类的主要功能:

  1. 创建不可变集合:Collections 提供了一系列的 emptyXxx() 方法,用于创建不可变的空集合(如 emptyList()emptySet() 等)。

  2. 创建单元素集合:提供了一系列的 singletonXxx() 方法,用于创建只包含一个元素的不可变集合。

  3. 集合操作:提供了一系列的静态方法用于对集合进行操作,如排序、反转、查找、填充等。这些方法包括:sort()shuffle()reverse()binarySearch()fill() 等。

  4. 同步集合:提供了一系列的线程安全的集合类的静态方法(如 synchronizedList()synchronizedSet() 等),用于将现有的集合转换为线程安全的集合,以便在多线程环境下使用。

2.2 方法

方法描述
public static <T> boolean addAll(Collection<T> c, T ... elements)批量添加元素
public static void shuffle(List<?> list)打乱集合顺序
public static <T> void sort(List<T> list)将集合中元素按照默认规则排序(默认规则:需要重写Comparable接口compareTo方法,默认按照从小到大的顺序排列)
public static <T> void sort(List<T> list, Comparator<? super T> c)将集合中元素按照指定规则排序(指定规则在创建对象时指定比较器规则)(自定义对象,需要自己指定规则)
public static <T> int binarySearch(List<? super T> list, T key)以二分查找法查找元素
public static void fill(List<? super T> list, T obj)使用指定元素填充集合
public static <T> T max(Collection<? extends T> coll)返回指定 collection 中的最大元素
public static <T> T min(Collection<? extends T> coll)返回指定 collection 中的最小元素
public static void swap(List<?> list, int i, int j)交换指定列表中指定位置的元素

详细描述

  1. public static <T> boolean addAll(Collection<T> c, T ... elements)

    • 描述:批量添加元素到指定集合中。
    • 参数:
      • c:目标集合
      • elements:要添加的元素数组
    • 返回值:如果集合发生更改,则返回 true;否则返回 false
  2. public static void shuffle(List<?> list)

    • 描述:打乱指定列表中元素的顺序。
    • 参数:
      • list:要进行打乱顺序操作的列表。
  3. public static <T> void sort(List<T> list)

    • 描述:将集合中的元素按照默认规则排序。
    • 参数:
      • list:要排序的列表
    • 默认规则:集合中的元素必须实现 Comparable 接口,并重写 compareTo 方法来定义排序规则。默认按照从小到大的顺序排列。
  4. public static <T> void sort(List<T> list, Comparator<? super T> c)

    • 描述:将集合中的元素按照指定规则排序。
    • 参数:
      • list:要排序的列表
      • c:比较器规则,需要在创建对象时指定比较器规则。对于自定义对象,需要自己指定排序规则。
  5. public static <T> int binarySearch(List<? super T> list, T key)

    • 描述:使用二分查找法在指定列表中搜索指定的元素。
    • 参数:
      • list:要进行搜索的有序列表
      • key:要搜索的元素
    • 返回值:如果找到元素,则返回其在列表中的位置;否则返回负数。
  6. public static void fill(List<? super T> list, T obj)

    • 描述:使用指定元素填充列表中的所有元素。
    • 参数:
      • list:要进行填充操作的列表
      • obj:要填充的元素
  7. public static <T> T max(Collection<? extends T> coll)

    • 描述:返回指定 collection 中的最大元素。
    • 参数:
      • coll:要进行查找最大元素的集合
    • 返回值:集合中的最大元素。
  8. public static <T> T min(Collection<? extends T> coll)

    • 描述:返回指定 collection 中的最小元素。
    • 参数:
      • coll:要进行查找最小元素的集合
    • 返回值:集合中的最小元素。
  9. public static void swap(List<?> list, int i, int j)

    • 描述:交换指定列表中指定位置的元素。
    • 参数:
      • list:要进行元素交换的列表
      • ij:要交换的元素索引位置。

2.3 代码示例

  • 代码示例
package text.text02;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.function.Consumer;

/*Collections:集合工具类
1.java.util.Collections:是集合的工具类
2.作用:Collections不是集合,而是集合的工具类
3.方法:
public static <T> boolean addAll(Collection <T> c,T ... elements)`:批量添加元素
public static void shuffle(List<?> list) `:打乱集合顺序
public static <T> void sort(List<T> list)`:将集合中元素按照默认规则排序
    默认规则:需要重写Comparable接口compareTo方法,默认按照从小到大的顺序排列

public static <T> void sort(List<T> list,Comparator<? super T> )`:将集合中元素按照指定规则排序
   指定规则:在创建对象时,指定比较器规则(自定义对象,需要自己指定规则)

public static <T> int binarySearch(List<? super T> list, T key)` :以二分查找法查找元素
   前提元素必须有序,该方法返回的是该元素所在的索引


public static void fill(List<? super T> list, T obj)`: 使用指定元素填充集合
public static <T> T max(Collection<? extends T> coll)` : 返回指定 Collection 中的最大元素
public static <T> T min(Collection<? extends T> coll)` : 返回指定 Collection 中的最小元素
public static void swap(List<?> list, int i, int j)` :交换指定列表中指定位置的元素

 */
public class text56 {
    public static void main(String[] args) {
        //1.public static <T> boolean addAll(Collection <T> c,T ... elements)`:批量添加元素
        System.out.println("===================== 1.批量添加元素 =====================");
        //创建集合
        Collection<String> list1 = new ArrayList<>();
        //添加元素
        Collections.addAll(list1, "abc", "def", "ghi", "jkl", "mno", "por");
        //遍历集合
        list1.forEach(new Consumer<String>() {
            @Override
            public void accept(String str) {
                System.out.print(str + "  ");      //abc  def  ghi  jkl  mno  por
            }
        });

        System.out.println();

        //2.public static void shuffle(List<?> list) `:打乱集合顺序
        System.out.println("===================== 2.打乱集合顺序 =====================");
        //创建集合
        ArrayList<String> list2 = new ArrayList<>();
        //添加元素
        Collections.addAll(list2, "abc", "def", "ghi", "jkl", "mno", "por");
        //打乱元素
        Collections.shuffle(list2);
        //遍历集合
        for (String str : list2) {
            System.out.print(str + "  ");     //打乱顺序了,每次输出结果都不一样
        }

        System.out.println();

        //3.public static <T> void sort(List<T> list)`:将集合中元素按照默认规则排序
        System.out.println("===================== 3.将集合中元素按照默认规则排序 =====================");
        //默认规则:需要重写Comparable接口compareTo方法,默认按照从小到大的顺序排列
        //创建集合
        ArrayList<String> list3 = new ArrayList<>();
        //添加元素
        Collections.addAll(list3, "0004", "0002", "0006", "0001", "0003", "0005");
        //默认规则排序(即从小到大排列)
        Collections.sort(list3);
        //遍历集合
        for (String str : list3) {
            System.out.print(str + "  ");       //0001  0002  0003  0004  0005  0006

        }

        System.out.println();

        //4.public static <T> void sort(List<T> list,Comparator<? super T> )`:将集合中元素按照指定规则排序
        System.out.println("===================== 4.将集合中元素按照指定规则排序 =====================");
        //指定规则:在创建对象时,指定比较器规则(自定义对象,需要自己指定规则)
        //创建集合
        ArrayList<String> list4 = new ArrayList<>();
        //添加元素
        Collections.addAll(list4, "0004", "0002", "0006", "0001", "0003", "0005");
        //指定规则排序
        Collections.sort(list4, new Comparator<String>() {
            @Override
            public int compare(String o1, String o2) {
                return o2.compareTo(o1);
            }
        });
        //遍历集合
        for (String str : list4) {
            System.out.print(str + "  ");       //0006  0005  0004  0003  0002  0001

        }

        System.out.println();

        //5.public static <T> int binarySearch(List<? super T> list, T key)` :以二分查找法查找元素
        System.out.println("===================== 5.以二分查找法查找元素 =====================");
        //前提元素必须有序
        //创建集合
        ArrayList<Integer> list5 = new ArrayList<>();
        //添加元素
        Collections.addAll(list5, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10);
        //二分查找法查找元素
        //该方法返回的是该元素所在的索引
        int binarySearch = Collections.binarySearch(list5, 6);
        System.out.println("该元素所在的索引为:" + binarySearch);       //该元素所在的索引为:5
        //遍历集合
        for (Integer str : list5) {
            System.out.print(str + "  ");       //1  2  3  4  5  6  7  8  8  9  10

        }

        System.out.println();

        //6.public static void fill(List<? super T> list, T obj)`: 使用指定元素填充集合
        System.out.println("===================== 6.使用指定元素填充集合 =====================");
        //创建集合
        ArrayList<Integer> list6 = new ArrayList<>();
        //添加元素
        Collections.addAll(list6, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10);
        //指定元素填充集合
        Collections.fill(list6, 1314);
        //遍历集合
        for (Integer str : list6) {
            System.out.print(str + "  ");       //1314  1314  1314  1314  1314  1314  1314  1314  1314  1314  1314

        }

        System.out.println();

        //7.public static <T> T max(Collection<? extends T> coll)`:返回指定Collection 中的最大元素
        System.out.println("===================== 7.返回指定Collection 中的最大元素 =====================");
        //创建集合
        ArrayList<Integer> list7 = new ArrayList<>();
        //添加元素
        Collections.addAll(list7, 1, 2, 3, 4, 5, 1314, 520, 6, 7, 8, 8, 9, 10);
        //返回指定Collection 中的最大元素
        Integer max = Collections.max(list7);
        System.out.println("最大元素为:" + max);        //最大元素为:1314
        //遍历集合
        for (Integer str : list7) {
            System.out.print(str + "  ");       //1  2  3  4  5  1314  520  6  7  8  8  9  10
        }

        System.out.println();

        //8.public static <T> T min(Collection<? extends T> coll)`:返回指定 Collection 中的最小元素
        System.out.println("===================== 8.返回指定 Collection 中的最小元素 =====================");
        //创建集合
        ArrayList<Integer> list8 = new ArrayList<>();
        //添加元素
        Collections.addAll(list8, 1, 2, 3, 4, 5, 0, -1, 6, 7, 8, 8, 9, 10);
        //返回指定Collection 中的最小元素
        Integer min = Collections.min(list8);
        System.out.println("最小元素为:" + min);        //最小元素为:-1
        //遍历集合
        for (Integer str : list8) {
            System.out.print(str + "  ");       //1  2  3  4  5  0  -1  6  7  8  8  9  10
        }

        System.out.println();

        //9.public static void swap(List<?> list, int i, int j)` :交换指定列表中指定位置的元素
        System.out.println("===================== 9.交换指定列表中指定位置的元素 =====================");
        //创建集合
        ArrayList<Integer> list9 = new ArrayList<>();
        //添加元素
        Collections.addAll(list9, 1, 2, 3, 4, 5, 0, -1, 6, 7, 8, 8, 9, 10);
        //交换指定列表中指定位置的元素
        Collections.swap(list9, 0, 12);
        //遍历集合
        for (Integer str : list9) {
            System.out.print(str + "  ");       //10  2  3  4  5  0  -1  6  7  8  8  9  1  
        }
    }
}

  • 输出结果
    • 1.批量添加元素
      在这里插入图片描述

    • 2.打乱集合顺序
      在这里插入图片描述

    • 3.将集合中元素按照默认规则排序
      在这里插入图片描述

    • 4.将集合中元素按照指定规则排序
      在这里插入图片描述

    • 5.以二分查找法查找元素
      在这里插入图片描述

    • 6.使用指定元素填充集合
      在这里插入图片描述

    • 7.返回指定Collection 中的最大元素
      在这里插入图片描述

    • 8.返回指定 Collection 中的最小元素
      在这里插入图片描述

    • 9.交换指定列表中指定位置的元素
      在这里插入图片描述

2.4 注意事项

  1. 集合的同步性:Collections 类提供了一些线程安全的集合方法,如 synchronizedList()synchronizedSet() 等。但是需要注意,这些方法只是将现有的集合转换为线程安全的集合,并不能保证对集合中的元素的操作是原子性的。如果需要在多线程环境下对集合进行并发操作,建议使用并发集合类 (如 ConcurrentHashMapCopyOnWriteArrayList 等)来代替。

  2. 不可变集合: Collections 类提供了创建不可变集合的方法(如 unmodifiableList()unmodifiableSet()),返回的不可变集合不允许对其进行修改操作。需要注意的是,如果原始的集合发生了变化,不可变集合可能会反映这些变化。因此,当需要确保集合不会被修改时,应该使用不可变集合。

  3. 自然排序和自定义排序:Collections.sort() 方法用于对集合进行排序,默认使用集合元素的自然顺序,即元素的类必须实现 Comparable 接口并重写 compareTo() 方法。如果需要使用自定义排序规则,可以使用重载的 sort() 方法,其中传入一个自定义的比较器 Comparator。

  4. 对象的比较和相等:在使用排序或查找方法时,需要确保集合中的元素正确地实现了 equals()compareTo() 方法,以保证比较和查找的准确性。

  5. 注意泛型的使用:Collections 类中的方法通常使用了泛型来增加灵活性和类型安全性。在使用这些方法时,需要注意传入的集合类型和元素类型需要匹配。

  6. 注意性能和效率:某些 Collections 方法的实现可能会产生额外的开销,比如排序方法可能需要额外的内存空间。在处理大量数据时,需要考虑这些性能和效率因素。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux操作系统基础(十三):Linux安装、卸载MySQL

文章目录 Linux安装、卸载MySQL 一、卸载系统自带的mariadb-lib 二、上传安装包并解压 三、按顺序安装 错误1: 错误2: 错误3: 错误4: 四、初始化数据库 五、目录授权&#xff0c;否则启动失败 六、启动msyql服务 七、查看msyql服务的状态 八、在/var/log/mysqld.l…

【大厂AI课学习笔记】1.5 AI技术领域(6)目标检测

目标检测是CV中的重要场景。 在图像中定位感兴趣的目标&#xff0c;准确判断每个目标的类别&#xff0c;并给出每个目标的边界框。 上图是目标检测的典型应用案例。 目标检测的难点是小目标的高精度检测。 目前主要的应用领域是机器人导航、自动驾驶、智能视频监督、工业检测…

【客户端】聊聊卸载安装测试、新安装测试和覆盖安装测试(持续更新中)

程序安装一般会有&#xff1a;全新安装、卸载安装、覆盖安装这几种&#xff0c;那么安装渠道和方式就非常的多样化了。iOS可以商店安装、文件安装&#xff0c;安卓有商店安装、渠道安装、APK安装 等等。 一、不同安装方式 通常来说&#xff0c;大部分用户都会走到覆盖安装&…

基于python混沌系统敏感文本信息加密算法的研究与实现,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

IM聊天系统为什么需要做消息幂等?如何使用Redis以及Lua脚本做消息幂等【第12期】

0前言 消息收发模型 第一张图是一个时序图&#xff0c;第二张图是一个标清楚步骤的流程图&#xff0c;更加清晰。消息的插入环节主要在2步。save部分。主要也是对这个部分就行消息幂等的操作。 前情提要&#xff1a;使用Redis发布 token 以及lua脚本来共同完成消息的幂等 目…

面试经典150题——长度最小的子数组

​"In the midst of winter, I found there was, within me, an invincible summer." - Albert Camus 1. 题目描述 2. 题目分析与解析 首先理解题意&#xff0c;题目要求我们找到一个长度最小的 连续子数组 满足他们的和大于target&#xff0c;需要返回的是子数组的…

利用路由懒加载和CDN分发策略对极客园项目进行性能优化

文章目录 前言1.配置路由懒加载2.项目资源打包3.包体积可视化分析4.cdn配置 总结 前言 极客园项目的完成之后&#xff0c;我们需要对项目进行打包以及性能优化&#xff0c;优化用户体验以及加快响应时间&#xff0c;本文只列举了路由懒加载和cdn分发的策略 1.配置路由懒加载 …

盘点数据可视化大屏焦点图十种样式

所谓焦点图就是大屏中居于中心位置的图&#xff0c;是视觉的中心&#xff0c;本位列举了十种焦点图样式供大家参考。 地球作为焦点图 图片来自网络 地图作为焦点图 图片来自网络 城市作为焦点图 图片来自网络 园区做焦点图 图片来自网络 建筑做焦点图 图片来自网络 生产线…

数据链路层DoS

图9-14 集线器应用原理 数据链路层中拒绝服务攻击的方式一般很少为人所熟知。数据链路层拒绝服 务攻击的主要目标为二层交换机。在早期网络中&#xff0c;通常都会使用集线器作为中间 处理设备。集线器属于纯硬件网络底层设备&#xff0c;没有任何“ 智能记忆” 能力和“学 …

12.状态模式

文章目录 状态模式总结 状态模式 介绍 状态模式它允许一个对象在其内部状态改变时改变其行为&#xff0c;使对象看起来似乎修改了其类。状态模式的主要目的是将对象的状态封装成不同的类&#xff0c;并将对象的行为委托给当前状态。 组成 Context&#xff08;环境&#xff09;&…

GAMES101-Assignment3

GAMES101-Assignment3 参考文章&#xff1a; 1.《GAMES101》作业框架问题详解 2. Games101&#xff1a;作业3&#xff08;管线分析、深度插值、libpng warning、双线性插值等&#xff09; 3.【GAMES101】作业3&#xff08;提高&#xff09;与法线贴图原理和渲染管线框架分析 …

vue3 腾讯tdesign 后台管理框架的使用

1.介绍 TDesign 是具有包容性的设计体系&#xff0c;它强调为业务提供产品、服务等过程中&#xff0c;追求以人为本、人人受益的包容性&#xff0c;要求搭建过程中&#xff0c;了解业务底层&#xff0c;理解业务场景的多样性&#xff0c;并在繁杂的业务场景中寻找共性和特性&a…

ubuntu快速安装miniconda

ubuntu快速安装miniconda 环境 ubuntu.22.04 显卡 RTX 3050 关于选择Miniconda还是Anaconda的问题&#xff0c;Anaconda安装包比较大&#xff0c;耗时比较长&#xff0c;如果你是绝对的初学者&#xff0c;选择Anaconda会比较稳妥一些&#xff1b;否则建议你还是选择Miniconda安…

[算法学习] 逆元与欧拉降幂

费马小定理 两个条件&#xff1a; p为质数a与p互质 逆元 如果要求 x^-1 mod p &#xff0c;用快速幂求 qmi(x,p-2) 就好 欧拉函数 思路&#xff1a;找到因数 i&#xff0c;phi / i * (i-1)&#xff0c;除干净&#xff0c;判断最后的n 欧拉降幂 欧拉定理 应用示例 m! 是一个…

无人机飞行控制系统功能,多旋翼飞行控制系统概述

飞行控制系统存在的意义 行控制系统通过高效的控制算法内核&#xff0c;能够精准地感应并计算出飞行器的飞行姿态等数据&#xff0c;再通过主控制单元实现精准定位悬停和自主平稳飞行。 在没有飞行控制系统的情况下&#xff0c;有很多的专业飞手经过长期艰苦的练习&#xff0…

npm config set registry https://registry.npm.taobao.org 这个设置了默认的镜像源之后如何恢复默认的镜像源

要恢复npm默认的镜像源&#xff0c;你可以使用以下命令将registry设置回npm的官方源&#xff1a; npm config set registry https://registry.npmjs.org/这个命令会修改你的全局npm配置&#xff0c;将包的下载源改回npm官方的源。这样做之后&#xff0c;任何后续的npm install…

docker本地目录挂载

小命令 1、查看容器详情 docker inspect 容器名称 还是以nginx为例&#xff0c;上篇文章我们制作了nginx静态目录的数据卷&#xff0c;此时查看nginx容器时会展示出来&#xff08;docker inspect nginx 展示信息太多&#xff0c;这里只截图数据卷挂载信息&#xff09;&#…

20240212请问如何将B站下载的软字幕转换成为SRT格式?

20240212请问如何将B站下载的软字幕转换成为SRT格式&#xff1f; 2024/2/12 12:47 百度搜索&#xff1a;字幕 json 转 srt json srt https://blog.csdn.net/a_wh_white/article/details/120687363?share_token2640663e-f468-4737-9b55-73c808f5dcf0 https://blog.csdn.net/a_w…

Pandas从基础统计到高级分析的完整指南【第77篇—Pandas高级分析】

Pandas从基础统计到高级分析的完整指南 在数据科学和分析领域中&#xff0c;Pandas是Python中最受欢迎的数据处理库之一。它提供了丰富而强大的功能&#xff0c;其中包括各种统计方法&#xff0c;用于更好地理解和分析数据。本文将介绍Pandas中常用的统计方法&#xff0c;通过…

Github 2024-02-07 开源项目日报 Top9

根据Github Trendings的统计&#xff0c;今日(2024-02-07统计)共有9个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Rust项目2TypeScript项目2Python项目2Ruby项目1HTML项目1NASL项目1Go项目1C项目1Svelte项目1C项目1 React Nat…