Java基础(十八):java比较器、系统相关类、数学相关类

news2024/12/29 1:59:05

Java基础系列文章

Java基础(一):语言概述

Java基础(二):原码、反码、补码及进制之间的运算

Java基础(三):数据类型与进制

Java基础(四):逻辑运算符和位运算符

Java基础(五):流程控制语句

Java基础(六):数组

Java基础(七):面向对象编程

Java基础(八):封装、继承、多态性

Java基础(九):Object 类的使用

Java基础(十):关键字static、代码块、关键字final

Java基础(十一):抽象类、接口、内部类

Java基础(十二):枚举类

Java基础(十三):注解(Annotation)

Java基础(十四):包装类

Java基础(十五):异常处理

Java基础(十六):String的常用API

Java基础(十七):日期时间API

Java基础(十八):java比较器、系统相关类、数学相关类


目录

  • 一、Java比较器
    • 1、自然排序:java.lang.Comparable
    • 2、定制排序:java.util.Comparator
  • 二、系统相关类
    • 1、java.lang.System类
    • 2、java.lang.Runtime类
  • 三、数学相关的类
    • 1、java.lang.Math
    • 2、java.math.BigInteger
    • 3、java.math.BigDecimal
    • 4、java.util.Random(用于产生随机数)


一、Java比较器

1、自然排序:java.lang.Comparable

  • Comparable接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序
  • 实现 Comparable 的类必须实现 compareTo(Object obj) 方法
    • 两个对象即通过 compareTo(Object obj) 方法的返回值来比较大小
    • 如果当前对象this大于形参对象obj,则返回正整数
    • 如果当前对象this小于形参对象obj,则返回负整数
    • 如果当前对象this等于形参对象obj,则返回零
package java.lang;

public interface Comparable{
    int compareTo(Object obj);
}
  • 实现Comparable接口的对象列表(和数组)可以通过 Collections.sortArrays.sort进行自动排序
  • Comparable 的典型实现:(默认都是从小到大排列的)
    • String:按照字符串中字符的Unicode值进行比较
    • Character:按照字符的Unicode值来进行比较
    • 数值类型对应的包装类以及BigInteger、BigDecimal:按照它们对应的数值大小进行比较
    • Boolean:true 对应的包装类实例大于 false 对应的包装类实例
    • Date、Time等:后面的日期时间比前面的日期时间大

举例1:

@Test
public void test1() {
    String[] arr = new String[]{"Tom", "Jerry", "Tony", "Rose", "Jack", "Lucy"};

    Arrays.sort(arr);

    // 排序后,遍历
    for (int i = 0; i < arr.length; i++) {
        System.out.println(arr[i]);
    }
}

输出结果:

Jack
Jerry
Lucy
Rose
Tom
Tony

举例2:

public class Product implements Comparable { // 商品类

    private String name;// 商品名称
    private double price;// 价格

    public Product(String name, double price) {
        this.name = name;
        this.price = price;
    }

    public Product() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }


    @Override
    public String toString() {
        return "Product{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }

    // 比较的标准:先比较价格(从大到小),价格相同,进行名字的比较 (从小到大)
    @Override
    public int compareTo(Object o) {
        if (o == this) {
            return 0;
        }
        if (o instanceof Product) {
            Product p = (Product) o;
            int value = Double.compare(this.price, p.price);
            if (value != 0) {
                return -value;
            }
            return this.name.compareTo(p.name);
        }
        // 手动抛出一个异常类的对象
        throw new RuntimeException("类型不匹配");
    }
}
  • 排序
@Test
public void test2() {
    Product[] arr = new Product[5];
    arr[0] = new Product("HuaweiMate50pro", 6299);
    arr[1] = new Product("Xiaomi13pro", 4999);
    arr[2] = new Product("VivoX90pro", 5999);
    arr[3] = new Product("Iphone14ProMax", 9999);
    arr[4] = new Product("HonorMagic4", 6299);

    Arrays.sort(arr);
    
    // 排序后,遍历
    for (int i = 0; i < arr.length; i++) {
        System.out.println(arr[i]);
    }
}
  • 对象比较大小
@Test
public void test3() {
    Product p1 = new Product("HuaweiMate50pro", 6299);
    Product p2 = new Product("VivoX90pro", 5999);
    int compare = p1.compareTo(p2);
    if (compare > 0) {
        System.out.println("p1大");
    } else if (compare < 0) {
        System.out.println("p2大");
    } else {
        System.out.println("p1和p2一样大");
    }
}

2、定制排序:java.util.Comparator

  • 思考?
    • 当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码(例如:一些第三方的类,你只有.class文件,没有源文件)
    • 如果一个类,实现了Comparable接口,也指定了两个对象的比较大小的规则,但是此时此刻我不想按照它预定义的方法比较大小,但是我又不能随意修改,因为会影响其他地方的使用,怎么办?
  • JDK在设计类库之初,也考虑到这种情况,所以又增加了一个java.util.Comparator接口。强行对多个对象进行整体排序的比较
    • 重写compare(Object o1,Object o2)方法,比较o1和o2的大小:如果方法返回正整数,则表示o1大于o2;如果返回0,表示相等;返回负整数,表示o1小于o2
    • 可以将 Comparator 传递给 sort 方法(如 Collections.sort 或 Arrays.sort),从而允许在排序顺序上实现精确控制
package java.util;

public interface Comparator{
    int compare(Object o1,Object o2);
}

举例1:

@Test
public void test1(){
    String[] arr = new String[]{"Tom","Jerry","Tony","Rose","Jack","Lucy"};

    Arrays.sort(arr,new Comparator(){
        @Override
        public int compare(Object o1, Object o2) {
            if(o1 instanceof String && o2 instanceof String){
                String s1 =(String) o1;
                String s2 =(String) o2;

                return -s1.compareTo(s2);
            }
            throw new RuntimeException("类型不匹配");
        }
    });

    //排序后,遍历
    for (int i = 0; i < arr.length; i++) {
        System.out.println(arr[i]);
    }
}

举例2:

public class Product{ // 商品类

    private String name;// 商品名称
    private double price;// 价格

    public Product(String name, double price) {
        this.name = name;
        this.price = price;
    }

    public Product() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }


    @Override
    public String toString() {
        return "Product{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }
}
@Test
public void test2(){
    Product[] arr = new Product[5];
    arr[0] = new Product("HuaweiMate50pro",6299);
    arr[1] = new Product("Xiaomi13pro",4999);
    arr[2] = new Product("VivoX90pro",5999);
    arr[3] = new Product("Iphone14ProMax",9999);
    arr[4] = new Product("HonorMagic4",6299);

    //创建一个实现了Comparator接口的实现类的对象
    Comparator comparator = new Comparator(){
        //如果判断两个对象o1,o2的大小,其标准就是此方法的方法体要编写的逻辑。
        //比如:按照name从低到高排序
        @Override
        public int compare(Object o1, Object o2) {
            if(o1 instanceof Product && o2 instanceof Product){
                Product p1 = (Product) o1;
                Product p2 = (Product) o2;
                return p1.getName().compareTo(p2.getName());
            }
            throw new RuntimeException("类型不匹配");
        }
    };

    Arrays.sort(arr,comparator1);
    //排序后,遍历
    for (int i = 0; i < arr.length; i++) {
        System.out.println(arr[i]);
    }
}

二、系统相关类

1、java.lang.System类

  • System类代表系统,系统级的很多属性和控制方法都放置在该类的内部。该类位于java.lang包
  • 由于该类的构造器是private的,所以无法创建该类的对象
  • 其内部的成员变量和成员方法都是static的,所以也可以很方便的进行调用
  • 成员方法
    • native long currentTimeMillis()
      • 该方法的作用是返回当前的计算机时间
      • 时间的表达格式为当前计算机时间和GMT时间(格林威治时间)1970年1月1号0时0分0秒所差的毫秒数
    • void exit(int status)
      • 该方法的作用是退出程序
      • 其中status的值为0代表正常退出,非零代表异常退出
      • 使用该方法可以在图形界面编程中实现程序的退出功能等
    • void gc()
      • 该方法的作用是请求系统进行垃圾回收
      • 至于系统是否立刻回收,则取决于系统中垃圾回收算法的实现以及系统执行时的情况
    • String getProperty(String key)
      • 该方法的作用是获得系统中属性名为key的属性对应的值
      • 系统中常见的属性名以及属性的作用如下表所示
        在这里插入图片描述

举例:

@Test
public void test1() {
    String javaVersion = System.getProperty("java.version");
    System.out.println("java的version:" + javaVersion);

    String javaHome = System.getProperty("java.home");
    System.out.println("java的home:" + javaHome);

    String osName = System.getProperty("os.name");
    System.out.println("os的name:" + osName);

    String osVersion = System.getProperty("os.version");
    System.out.println("os的version:" + osVersion);

    String userName = System.getProperty("user.name");
    System.out.println("user的name:" + userName);

    String userHome = System.getProperty("user.home");
    System.out.println("user的home:" + userHome);

    String userDir = System.getProperty("user.dir");
    System.out.println("user的dir:" + userDir);
}

输出结果:

java的version:1.8.0_345
java的home:/Library/Java/JavaVirtualMachines/zulu-8.jdk/Contents/Home/jre
os的name:Mac OS X
os的version:12.5
user的name:xuchang
user的home:/Users/xuchang
user的dir:/Users/xuchang/Documents/javaCode/study/java基础/JavaSECode/chapter11_api_teacher

2、java.lang.Runtime类

  • 每个 Java 应用程序都有一个 Runtime 类实例,使应用程序能够与其运行的环境相连接
  • public static Runtime getRuntime()
    • 返回与当前 Java 应用程序相关的运行时对象
    • 应用程序不能创建自己的 Runtime 类实例
  • public long totalMemory()
    • 返回 Java 虚拟机中初始化时的内存总量
    • 此方法返回的值可能随时间的推移而变化,这取决于主机环境
    • 默认为物理电脑内存的1/64
  • public long maxMemory()
    • 返回 Java 虚拟机中最大程度能使用的内存总量
    • 默认为物理电脑内存的1/4
  • public long freeMemory()
    • 回 Java 虚拟机中的空闲内存量
    • 调用 gc 方法可能导致 freeMemory 返回值的增加

举例:

@Test
public void test2() {
    Runtime runtime = Runtime.getRuntime();
    long initialMemory = runtime.totalMemory(); //获取虚拟机初始化时堆内存总量
    long maxMemory = runtime.maxMemory(); //获取虚拟机最大堆内存总量
    String str = "";
    //模拟占用内存
    for (int i = 0; i < 10000; i++) {
        str += i;
    }
    long freeMemory = runtime.freeMemory(); //获取空闲堆内存总量

    System.out.println("总内存:" + initialMemory / 1024 / 1024 * 64 + "MB");
    System.out.println("总内存:" + maxMemory / 1024 / 1024 * 4 + "MB");
    System.out.println("空闲内存:" + freeMemory / 1024 / 1024 + "MB") ;
    System.out.println("已用内存:" + (initialMemory-freeMemory) / 1024 / 1024 + "MB");
}

输出结果:

总内存:16640MB
总内存:16384MB
空闲内存:139MB
已用内存:120MB

三、数学相关的类

1、java.lang.Math

  • java.lang.Math 类包含用于执行基本数学运算的方法
  • 如初等指数、对数、平方根和三角函数
  • 类似这样的工具类,其所有方法均为静态方法,并且不会创建对象,调用起来非常简单

  • public static double abs(double a) 返回 double 值的绝对值
double d1 = Math.abs(-5); //d1的值为5
double d2 = Math.abs(5); //d2的值为5
  • public static double ceil(double a)返回大于等于参数的最小的整数
  • ceil:天花板
double d1 = Math.ceil(3.3); //d1的值为 4.0
double d2 = Math.ceil(-3.3); //d2的值为 -3.0
double d3 = Math.ceil(5.1); //d3的值为 6.0
  • public static double floor(double a)返回小于等于参数最大的整数
  • floor:地板
double d1 = Math.ceil(3.3); //d1的值为 4.0
double d2 = Math.ceil(-3.3); //d2的值为 -3.0
double d3 = Math.ceil(5.1); //d3的值为 6.0
  • public static long round(double a)返回最接近参数的 long。(相当于四舍五入方法)
long d1 = Math.round(5.5); //d1的值为6
long d2 = Math.round(5.4); //d2的值为5
long d3 = Math.round(-3.3); //d3的值为-3
long d4 = Math.round(-3.8); //d4的值为-4
  • public static double random()返回[0,1)的double随机值
double rand = Math.random(); // 0.49063812186909517

2、java.math.BigInteger

  • Integer类作为int的包装类,能存储的最大整型值为2^31-1,Long类也是有限的,最大为2^63-1
    • 如果要表示再大的整数,不管是基本数据类型还是他们的包装类都无能为力,更不用说进行运算了
  • java.math包的BigInteger可以表示不可变的任意精度的整数
    • BigInteger 提供所有 Java 的基本整数操作符的对应物,并提供 java.lang.Math 的所有相关方法
    • BigInteger 还提供以下运算:模算术、GCD 计算、质数测试、素数生成、位操作以及一些其他操作

构造器

  • BigInteger(String val):根据字符串构建BigInteger对象

方法

  • public BigInteger abs():返回此 BigInteger 的绝对值的 BigInteger
  • BigInteger add(BigInteger val) :返回其值为 (this + val) 的 BigInteger
  • BigInteger subtract(BigInteger val) :返回其值为 (this - val) 的 BigInteger
  • BigInteger multiply(BigInteger val) :返回其值为 (this * val) 的 BigInteger
  • BigInteger divide(BigInteger val) :返回其值为 (this / val) 的 BigInteger。整数相除只保留整数部分
  • BigInteger remainder(BigInteger val) :返回其值为 (this % val) 的 BigInteger
@Test
public void test3(){
    BigInteger b1 = new BigInteger("12345678912345678912345678");
    BigInteger b2 = new BigInteger("78923456789123456789123456789");

    System.out.println("和:" + b1.add(b2)); // 78935802468035802468035802467
    System.out.println("减:" + b1.subtract(b2));// -78911111110211111110211111111
    System.out.println("乘:" + b1.multiply(b2));// 974363656170906866147450004116994361840451151863907942
    System.out.println("除:" + b2.divide(b1));// 6392
    System.out.println("余:" + b2.remainder(b1));// 9877181409877181409883013
}

3、java.math.BigDecimal

  • 一般的Float类和Double类可以用来做科学计算或工程计算
    • 但在商业计算中,要求数字精度比较高,故用到java.math.BigDecimal类
  • BigDecimal类支持不可变的、任意精度的有符号十进制定点数

构造器

  • public BigDecimal(double val)
  • public BigDecimal(String val) --> 推荐

常用方法

  • public BigDecimal add(BigDecimal augend)
  • public BigDecimal subtract(BigDecimal subtrahend)
  • public BigDecimal multiply(BigDecimal multiplicand)
  • public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
    • divisor是除数
    • scale指明保留几位小数
    • roundingMode指明舍入模式
    • ROUND_UP :向上加1、ROUND_DOWN :直接舍去、ROUND_HALF_UP:四舍五入
@Test
public void test4(){
    BigDecimal bd = new BigDecimal("12435.351");
    BigDecimal bd2 = new BigDecimal("11");
    System.out.println(bd); // 12435.351
    System.out.println(bd.divide(bd2, BigDecimal.ROUND_HALF_UP)); // 1130.486
    System.out.println(bd.divide(bd2, 15, BigDecimal.ROUND_HALF_UP)); // 1130.486454545454545
}

4、java.util.Random(用于产生随机数)

  • boolean nextBoolean():返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的 boolean 值
  • void nextBytes(byte[] bytes):生成随机字节并将其置于用户提供的 byte 数组中
  • double nextDouble():返回下一个伪随机数,它是取自此随机数生成器序列的、在 0.0 和 1.0 之间均匀分布的 double 值
  • float nextFloat():返回下一个伪随机数,它是取自此随机数生成器序列的、在 0.0 和 1.0 之间均匀分布的 float 值
  • int nextInt():返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值
  • int nextInt(int n):返回一个伪随机数,它是取自此随机数生成器序列的、在 0(包括)和指定值(不包括)之间均匀分布的 int 值
  • long nextLong():返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的 long 值
@Test
public void test5(){
    Random random = new Random();
    int i = random.nextInt();
    System.out.println(i); // -235025063

    int j = random.nextInt(10); //随机获取[0,10)范围的整数
    System.out.println(j); // 7
}

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

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

相关文章

JavaScript黑科技:隐秘执行

JavaScript黑科技&#xff1a;隐秘执行 如果能使网页中的JavaScript代码隐密的加载、隐密的执行&#xff0c;那对于保护JavaScript代码来说是很有利的。 本文将探索、演示一种隐秘执行JavaScript代码的技术。 源码如下&#xff1a; <html> <script>window.onlo…

Prometheus+node_exporter+Grafana+夜莺 监控部署

一、安装Prometheus 1.1 部署并配置Prometheus #主机基础配置 [rootnode4~]# systemctl stop firewalld && systemctl disable firewalld [rootnode4~]# sed -i s/enforcing/disabled/g /etc/selinux/config && setenforce 0#上传prometheus安装包并解压 [r…

8、ThingsBoard使用docker compose集群部署的问题以及如何解决问题

1、问题回顾 接着上一节继续讲解,上一节我们把整个服务全部都运行起来了,但是访问页面报错,最后查看的问题是前端的容易里面报错: 然后执行脚本删除所有的容器 2、问题分析 当遇到这个问题的时候,我当时真的不知道如何去解决,然后我又尝试使用官方的镜像来部署,发现官…

P75分层解耦-IOCDI详解

一、分层解耦-三层架构 Dao层&#xff1a;数据访问 1、接口 package com.itheima.service;import com.itheima.pojo.Emp;import java.util.List;/*** Description:* date: 2023/4/19 21:47** since JDK 11*/ public interface EmpService { // 获取员工列表数据public List&l…

RabbitMQ·入门·壹

文章目录 1 MQ思想1.1 相关概念&#xff1a;同步、异步通讯1.1.1 同步通讯1.1.2 异步通讯 1.2 MQ思想概述1.2.1 1 MQ思想 1.1 相关概念&#xff1a;同步、异步通讯 通讯方式举例优势劣势同步通讯就像打电话&#xff0c;需要实时响应。打电话可以立即得到响应。不能跟多人同时…

垃圾回收相关算法

标记阶段的算法 垃圾标记阶段&#xff1a;对象存货判断 在堆里存放着几乎所有的Java对象实例&#xff0c;在GC执行垃圾回收之前&#xff0c;首先需要区分出内存中哪些是存活对象&#xff0c;哪些是己经死亡的对象。只有被标记为己经死亡的对象&#xff0c;GC才会在执行垃圾回…

AutoGPT 环境搭建教程

文章目录 前言一、注册OpenAI和Pinecone的账号&#xff0c;并获取key二、下载Git和Python3&#xff08;自己网上搜&#xff0c;无脑安装&#xff09;![在这里插入图片描述](https://img-blog.csdnimg.cn/95bafd5ebe9d468cbceeacbfc0cb939b.png)三、进入GitHub&#xff0c;安装A…

Flowable从入门到源码分析

什么是工作流&#xff1f; 工作流&#xff0c;是把业务之间的各个步骤以及规则进行抽象和概括性的描述。使用特定的语言为业务流程建模&#xff0c;让其运行在计算机上&#xff0c;并让计算机进行计算和推动。 工作流解决的痛点在于&#xff0c;解除业务宏观流程和微观逻辑的…

【Linux】基础IO,详解系统文件IO

目录 C语言文件操作简单回顾 C语言相关文件接口汇总 默认打开的三个流 系统文件I/O open open的第一个参数 open的第二个参数 open的第三个参数 open的返回值 close write read 文件描述符 什么是文件描述符 文件描述符分配规则 重定向 重定向的本质 输出重定…

ETCD(一)简介

1. ETCD是什么 etcd 是一个分布式键值对存储&#xff0c;设计用来可靠而快速的保存关键数据并提供访问。和数据库一样都是用来存数据的&#xff0c;但是etcd有自己的特点&#xff0c;因此有自己的使用场景。 2. etcd 特点 完全复制&#xff0c;集群中的每个节点均拥有全量数…

跌倒检测和识别2:YOLOv5实现跌倒检测(含跌倒检测数据集和训练代码)

跌倒检测和识别2&#xff1a;YOLOv5实现跌倒检测(含跌倒检测数据集和训练代码) 目录 跌倒检测和识别2&#xff1a;YOLOv5实现跌倒检测(含跌倒检测数据集和训练代码) 1. 前言 2. 跌倒检测数据集说明 &#xff08;1&#xff09;跌倒检测数据集 &#xff08;2&#xff09;自定…

《离散数学导学》精炼——第10章(序列)

Learning never exhausts the mind. 文章目录 引言正文元包序列的定义序列与函数的关系空序列长度连接头尾运算符限制运算符逆置运算符单射序列 引言 笔者一直觉得在计算机这一学科的学习中&#xff0c;离散数学是极为重要的知识基础。离散化的思想体现在计算机学科的方方面面…

SpringDataJPA

介绍&#xff1a; spirng data jpa是spring提供的一套简化JPA开发的框架&#xff0c;按照约定好的规则进行【方法命名】去写dao层接口&#xff0c;就可以在不写接口实现的情况下&#xff0c;实现对数据库的访问和操作。同时提供了很多除了CRUD之外的功能&#xff0c;如分页、排…

剖析Linux内核—fork背后隐藏的技术细节

1、前言 全文分为两部分讲解&#xff1a;fork的内存管理部分和进程管理部分&#xff0c;内存管理主要讲解子进程如何构建自己的内存管理相关基础设施&#xff0c;父子进程如何共享地址空间的&#xff0c;写时复制如何发生&#xff0c;页表层面为我们做了哪些事情等等。而进程管…

Redis缓存雪崩、穿透、击穿

Redis缓存雪崩、穿透、击穿 解决方案正常的缓存流程Redis缓存雪崩Redis缓存雪崩解决方案 Redis缓存穿透Redis缓存穿透解决方案 Redis缓存击穿Redis缓存击穿解决方案 解决方案 布隆过滤器&#xff0c;分布式锁 正常的缓存流程 Redis缓存雪崩 Redis中的key大面积失效&#xff0…

BUUCTF-PWN-pwn1_sctf_2016

下载 放入 ubuntu里查信息 现在这些保护我都没有遇到 以后慢慢做应该是会遇到的 然后进行发现是32 所以我们记住 如果栈溢出漏洞 我们需要4个字节填满基地址 放入ida32 查看字符串 发现 cat flag 敏感字符串 然后我们就看引用 先记住地址 为 0x8048F0D 然后开始进去 发…

windows下网络聊天室项目(C++、SQLite、计算机网络)——思路+源码+解析

这里只是在windows系统下用C++做的简易聊天室,其界面比较low,不过该有的功能已基本实现。至于带界面的,QT里有封装好的QTcpSocket套接字,会在下一篇博客里予以介绍。主要的功能主要包含的功能有:查看当前在线人数、进入群聊界面、进入私聊界面、查看聊天记录、文件传输、更…

【Python小程序】纪念日礼物|恋爱一周年,送媳妇儿什么礼物浪漫又有惊喜?一键收藏,过节再也不用绞尽脑汁啦~(特别的礼物赠送)

前言 有些日子不可懒&#xff0c;指的就是纪念日。不同阶段过纪念日&#xff0c;也是不同的心境。 ——偷偷告诉你 所有文章完整的素材源码都在&#x1f447;&#x1f447; 粉丝白嫖源码福利&#xff0c;请移步至CSDN社区或文末公众hao即可免费。 作为一个编程博主&#xff0c…

爬虫学习 例子

以新能源网为例 【10-实战课】从源码获取豆瓣电影TOP250_哔哩哔哩_bilibili 1.查看网站结构 可见结构比较简单&#xff0c;直接循环爬取即可 2.代码&#xff08;无数据存储&#xff09; import requests from bs4 import BeautifulSoup headers {"User-Agent":&…

追梦之旅【数据结构篇】——看看小白试如何利用C语言“痛”撕堆排序

追梦之旅【数据结构篇】——看看小白试如何利用C语言“痛”撕堆排序 ~&#x1f60e; 前言&#x1f64c;堆的应用 —— 堆排序算法&#xff1a;堆排序算法源代码分享运行结果测试截图&#xff1a; 总结撒花&#x1f49e; &#x1f60e;博客昵称&#xff1a;博客小梦 &#x1f60…