13.常用类|Java学习笔记

文章目录

  • 包装类
    • 包装类型和String类型的相互转换
    • Integer类和Character类的常用方法
    • Integer创建机制&面试题
  • String类
    • 创建String对象的两种方式和区别
    • 字符串的特性
    • String类的常用方法
  • StringBuffer类
    • String和StringBuffer相互转换
    • StringBuffer常用方法
  • StringBuilder类
    • String、StringBuffer 和 StringBuilder 的比较
  • Math类
  • Arrays类
  • System类
  • BigInteger和BigDeciaml类
  • 日期类
    • 第一代日期类
    • 第二代日期类
    • 第三代日期类
      • 前两代日期类的不足分析
      • DateTimeFormatter 格式日期类
      • Instant 时间戳

包装类

针对八种基本数据类型相应的引用类型—包装类

在这里插入图片描述

java中int和integer之间的转换

jdk5之后可以直接:

int a = 1;
Integer b = a;
System.out.println(b);
int c = b;
System.out.println(c);

包装类型和String类型的相互转换

package com.fwedu.wrapper;


public class WrapperVsString {
    public static void main(String[] args) {
        // 方式一
        Integer i = 100;
        String str1 = i + "";

        // 方式二
        String str2 = i.toString();

        // 方式三
        String str3 = String.valueOf(i);

        // String -> 包装类(Integer)
        String str4 = "123456";
        Integer i2 = Integer.parseInt(str4);

        Integer i3 = new Integer(str4);     // 已经是deprecated了
    }
}

Integer类和Character类的常用方法

package com.fwedu.wrapper;

public class WrapperMethod {
    public static void main(String[] args) {
        System.out.println(Integer.MIN_VALUE);  // int最小值
        System.out.println(Integer.MAX_VALUE);  // int最大值

        System.out.println(Character.isDigit('a')); // 数字
        System.out.println(Character.isLetter('a'));    // 字母
        System.out.println(Character.isUpperCase('a')); // 大写
        System.out.println(Character.isLowerCase('a')); // 小写

        System.out.println(Character.isWhitespace('a'));    // 空格
        System.out.println(Character.toUpperCase('a')); // 变成大写
        System.out.println(Character.toLowerCase('a')); // 变成小写
    }
}

Integer创建机制&面试题

package com.fwedu.wrapper;

public class WrapperExercise02 {
    public static void main(String[] args) {
        Integer i = new Integer(1);
        Integer j = new Integer(1);
        System.out.println(i == j); //False
        //所以, 这里主要是看范围 -128 ~ 127 就是直接返回
        /*
        老韩解读
        //1. 如果 i 在 IntegerCache.low(-128)~IntegerCache.high(127),就直接从数组返回
        //2. 如果不在 -128~127,就直接 new Integer(i)
        public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
        return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
        }
        */
        Integer m = 1; //底层 Integer.valueOf(1); -> 阅读源码
        Integer n = 1;//底层 Integer.valueOf(1);
        System.out.println(m == n); //True
        //所以, 这里主要是看范围 -128 ~ 127 就是直接返回
        //, 否则, 就 new Integer(xx);
        Integer x = 128;//底层 Integer.valueOf(1);
        Integer y = 128;//底层 Integer.valueOf(1);
        System.out.println(x == y);//False
    }
}

String类

  1. String对象用于保存字符串,也就是一组字符序列
  2. 字符串常量对象是用双引号括起的字符序列。例如: “你好”、“12.97”、 "boy"等
  3. 字符串的字符使用Unicode字符编码,一个字符(不区分字母还是汉字)占两个字节。
  4. String类较常用构造器(其它看手册,有很多):
    String s1 = new String();
    String s2 = new String(String original);
    String s3 = new String(char[] a);
    String s4 = new String(char[] a, int startIndex, int count)
    

在这里插入图片描述

  1. String 类实现了接口 Serializable【String 可以串行化:可以在网络传输】
    接口 Comparable \【String 对象可以比较大小】
  2. String 是 final 类, 不能被其他的类继承
  3. String 有属性 private final char value[]; 用于存放字符串内容
  4. 一定要注意: value 是一个 final 类型, 不可以修改(需要功力): 即 value 不能指向新的地址, 但是单个字符内容是可以变化

创建String对象的两种方式和区别

方式一:直接赋值String s = “hsp”;
方式二:调用构造器String s2 = new String(“hsp”);

String s = "hsp";
String s2 = new String("hsp");
  1. 方式一:先从常量池查看是否有"hsp"数据空间,如果有,直接指向;如果没有则重新创建,然后指向。s最终指向的是常量池的空间地址。
  2. 方式二:先在堆中创建空间,里面维护了value属性,指向常量池的hsp空间。
    如果常量池没有"hsp",重新创建,如果有,直接通过value指向。 s2最终指向的是堆中的空间地址。
  3. 画出两种方式的内存分布图如下:

在这里插入图片描述

package com.fwedu.string_;

public class StringExercise01 {
    public static void main(String[] args) {
        String a = "abc";
        String b = "abc";
        System.out.println(a.equals(b));    // t
        System.out.println(a == b);         // t

        String c = new String("abc");
        String d = new String("abc");
        System.out.println(c.equals(d));    // t
        System.out.println(c == d);         // f
    }
}

当调用 intern 方法时,如果池已经包含一个等于此 String 对象的字符串(用 equals(Object)方法确定),则返回池中的字符串。否则,将此 String 对象添加到池中,并返回此 String 对象的引用。

package com.fwedu.string_;

public class StringExercise03 {
    public static void main(String[] args) {
        // a指向常量池的"abc"
        String a = "abc";
        // b指向堆中对象
        String b = new String("abc");
        System.out.println(a.equals(b));    // t
        System.out.println(a == b);         // f
        // b.intern()方法最终返回的时常量池的地址(对象)
        System.out.println(a == b.intern());    // t
        System.out.println(b == b.intern());    // f 因为返回的是常量池中"abc"的引用a

        // .intern()最终返回的是常量池的地址(对象)
        System.out.println(a.intern());     // abc
        System.out.println(b.intern());     // abc
    }
}

字符串的特性

  1. String是一个final类,代表不可变的字符序列。
  2. 字符串是不可变的。一个字符串对象一旦被分配,其内容是不可变的。
String s1 = "hello";
s1 = "haha";	// 创建了两个对象

String a = "hello" + "abc";		// 创建了一个对象(编译器等价优化String a = "helloabc";)
String c1 = "ab" + "cd";	// 常量相加,看的是池
String c1 = a + b;			// 变量相加,是在堆中

String类的常用方法

*   equals //区分大小写,判断内容是否相等
*   equalsIgnoreCase //忽略大小写的判断内容是否相等
*   length //获取字符的个数,字符串的长度
*   indexOf //获取字符在字符串中第1次出现的索引,索引从0开始,如果找不到,返回-1
*   lastIndexOf //获取字符在字符串中最后1次出现的索引,索引从开始,如找不到,返回-1
*   substring //截取指定范围的子串
*   trim //去前后空格
*   charAt	//获取某索引处的字符,注意不能使用Str[index]这种方式
toUpperCase
toLowerCase
concat
s1 = s1.concat("abc").concat("def");
replace // 替换字符串中的字符
split	// 分割字符串,返回值是String[]

String a = "jcck";
String b = "jackjk";
// 返回值是 'c' - 'a' = 2 的值
System.out.println(a.compareTo(b));	// 比较两个字符串的大小.前者大返回正数。如果前面的部分相同,就返回str1.len-str2.len

toCharArray		// 转换成字符数组
format		// 格式字符串 %s字符串 %c字符 %d整型 %.2f浮点型
String name = "john";
int age = 10;
String info = String.format("我的名字是%s 年龄是%d", name, age);
System.out.println(info);	// 输出 我的名字是john 年龄是10

concat方法和+的区别

StringBuffer类

String类是保存字符串常量的。每次更新都需要重新开辟空间,效率较低,因此java设计者还提供了StringBuilder和 StringBuffer来增强String的功能,并提高效率。

在这里插入图片描述

String VS StringBuffer

  1. String 保存的是字符串常量,里面的值不能更改,每次String类的更新实际上就是更改地址, 效率较低 //private final char value[];
  2. StringBuffer保存的是字符串变量,里面的值可以更改,每次StringBuffer的更新实际上可以更新内容,不用每次更新地址,效率较高
    //char[] value; //这个放在堆. 它的char[] value 不是final的

String和StringBuffer相互转换

package com.fwedu.stringbuffer_;

public class StringAndStringBuffer {
    public static void main(String[] args) {
        //看 String——>StringBuffer
        String str = "hello tom";
        //方式 1 使用构造器
        //注意: 返回的才是 StringBuffer 对象, 对 str 本身没有影响
        StringBuffer stringBuffer = new StringBuffer(str);
        //方式 2 使用的是 append 方法
        StringBuffer stringBuffer1 = new StringBuffer();
        stringBuffer1 = stringBuffer1.append(str);

        //看看 StringBuffer ->String
        StringBuffer stringBuffer3 = new StringBuffer("韩顺平教育");
        //方式 1 使用 StringBuffer 提供的 toString 方法
        String s = stringBuffer3.toString();
        //方式 2: 使用构造器来搞定
        String s1 = new String(stringBuffer3);
    }
}

StringBuffer常用方法

package com.fwedu.stringbuffer_;

public class StringBufferMethod {
    public static void main(String[] args) {
        StringBuffer s = new StringBuffer("hello");
        //增
        s.append(',');// "hello,"
        s.append("张三丰");//"hello,张三丰"
        s.append("赵敏").append(100).append(true).append(10.5);//"hello,张三丰赵敏 100true10.5"
        System.out.println(s);//"hello,张三丰赵敏100true10.5"
        //删
        /*
         * 删除索引为>=start && <end 处的字符
         * 解读: 删除 11~14 的字符 [11, 14)
         */
        s.delete(11, 14);
        System.out.println(s);//"hello,张三丰赵敏true10.5"
        //改
        //老韩解读, 使用 周芷若 替换 索引 9-11 的字符 [9,11)
        s.replace(9, 11, "周芷若");
        System.out.println(s);//"hello,张三丰周芷若true10.5"
        //查找指定的子串在字符串第一次出现的索引, 如果找不到返回-1
        int indexOf = s.indexOf("张三丰");
        System.out.println(indexOf);//6
        //插
        //老韩解读, 在索引为 9 的位置插入 "赵敏",原来索引为 9 的内容自动后移
        s.insert(9, "赵敏");
        System.out.println(s);//"hello,张三丰赵敏周芷若 true10.5"
        //长度
        System.out.println(s.length());//22
        System.out.println(s);
    }
}

上面代码中出现的方法有:

s.append("赵敏").append(100).append(true).append(10.5);	// 增
s.delete(11, 14);		// 删除
s.replace(9, 11, "周芷若");		// 修改
s.indexOf("张三丰");		// 查找第一次出现的索引,找不到返回-1
s.insert(9, "赵敏");	// 插入

public class StringBufferExercise01 {
    public static void main(String[] args) {
        String str = null;
        StringBuffer sb = new StringBuffer();
        sb.append(str);		// 底层调用的是AbstractStringBuilder的appendNull
        System.out.println(sb.length());

        System.out.println(sb);
        // 会抛出空指针异常NullPointerException
        StringBuffer stringBuffer = new StringBuffer(str);
        System.out.println(stringBuffer);
    }
}

上面的两个 sout 会输出:

4
null

即 str = null 被当成了 字符串"null" 加入到 sb 中了。

StringBuffer stringBuffer = new StringBuffer(str);这一行会抛出空指针异常。

StringBuilder类

  1. 一个可变的字符序列。此类提供一个与StringBuffer兼容的API,但不保证同步(StringBuilder不是线程安全)。该类被设计用作StringBuffer的一个简易替换,用在字符串缓冲区被单个线程使用的时候。如果可能,建议优先采用该类因为在大多数实现中,它比StringBuffer要快
  2. 在StringBuilder上的主要操作是append和insert方法,可重载这些方法,以接受任意类型的数据。

StringBuffer 多线程
StringBuilder 单线程

StringBuilder 的方法使用和 StringBuffer 基本一样。

String、StringBuffer 和 StringBuilder 的比较

在这里插入图片描述

使用的原则, 结论:

  1. 如果字符串存在大量的修改操作,一般使用StringBuffer或StringBuilder
  2. 如果字符串存在大量的修改操作,并在单线程的情况,使用StringBuilder
  3. 如果字符串存在大量的修改操作,并在多线程的情况,使用StringBufer
  4. 如果我们字符串很少修改,被多个对象引用,使用String,比如配置信息等

Math类

Math 类包含用于执行基本数学运算的方法,如初等指数、对数、平方根和三角函数。

https://www.apiref.com/java11-zh/java.base/java/lang/Math.html
均为静态方法。

// random 求随机数   	返回带有正号的 double值,大于或等于 0.0且小于 1.0 。
// random 返回的是 0 <= x < 1 之间的一个随机小数 [0, 1)

// 思考: 请写出获取 a-b 之间的一个随机整数,a,b 均为整数 , 比如 a = 2, b=7
// 即返回一个数 x 2 <= x <= 7
// 解读 Math.random() * (b-a) 返回的就是 0 <= 数 <= b-a
// (1) (int)(a) <= x <= (int)(a + Math.random() * (b-a +1) )
// (2) 使用具体的数给小伙伴介绍 a = 2 b = 7
// (int)(a + Math.random() * (b-a +1) ) = (int)( 2 + Math.random()*6)
// Math.random()*6 返回的是 0 <= x < 6 小数
// 2 + Math.random()*6 返回的就是 2<= x < 8 小数

// (int)(2 + Math.random()*6) = 2 <= x <= 7
// (3) 公式就是 (int)(a + Math.random() * (b-a +1) )

Arrays类

Java 自定义排序
【Java】自定义排序
【java】数组相关知识点汇总


System类

在这里插入图片描述

package com.fwedu.system_;

import java.util.Arrays;

public class System_ {
    public static void main(String[] args) {
        int[] src = {1, 2, 3};
        int[] dest = new int[3];
        System.arraycopy(src, 0, dest, 1, 2);
        System.out.println(Arrays.toString(dest));

        System.out.println(System.currentTimeMillis());

        System.out.println("ok1");
        System.exit(0);
        System.out.println("ok2");
    }
}

输出结果为:

[0, 1, 2]
1686555181555
ok1

BigInteger和BigDeciaml类

Java【大数类】整理


日期类

第一代日期类

在这里插入图片描述

使用代码示例:

package com.fwedu.date_;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * @author 冯威
 */
public class Date01 {
    public static void main(String[] args) throws ParseException {
        //老韩解读
        //1. 获取当前系统时间
        //2. 这里的 Date 类是在 java.util 包
        //3. 默认输出的日期格式是国外的方式, 因此通常需要对格式进行转换
        Date d1 = new Date(); //获取当前系统时间
        System.out.println("当前日期=" + d1);
        Date d2 = new Date(9234567); //通过指定毫秒数得到时间
        System.out.println("d2=" + d2); //获取某个时间对应的毫秒数

        //老韩解读
        //1. 创建 SimpleDateFormat 对象, 可以指定相应的格式
        //2. 这里的格式使用的字母是规定好, 不能乱写
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy 年 MM 月 dd 日 hh:mm:ss E");
        String format = sdf.format(d1); // format:将日期转换成指定格式的字符串
        System.out.println("当前日期=" + format);
        //老韩解读
        //1. 可以把一个格式化的 String 转成对应的 Date
        //2. 得到 Date 仍然在输出时, 还是按照国外的形式, 如果希望指定格式输出, 需要转换
        //3. 在把 String -> Date , 使用的 sdf 格式需要和你给的 String 的格式一样, 否则会抛出转换异常
        String s = "1996 年 01 月 01 日 10:20:30 星期一";
        Date parse = sdf.parse(s);
        System.out.println("parse=" + parse);
        System.out.println("parse=" + sdf.format(parse));
    }
}

上面代码中出现的方法有:

Date d1 = new Date(); //获取当前系统时间
Date d2 = new Date(9234567); //通过指定毫秒数得到时间


SimpleDateFormat sdf = new SimpleDateFormat("yyyy 年 MM 月 dd 日 hh:mm:ss E");
String s = "1996 年 01 月 01 日 10:20:30 星期一";
Date parse = sdf.parse(s);		// 解析
System.out.println("parse=" + parse);
System.out.println("parse=" + sdf.format(parse));	// 格式化

第二代日期类

第二代日期类,主要就是Calendar类(日历)。

public abstract class Calendar implements Serializable, Cloneable, Comparable<Calendar> {
}

Calendar类是一个抽象类,它为特定瞬间与一组诸如YEAR、MONTH、DAY_OF MONTH、HOUR等日历字段之间的转换提供了一些方法,并为操作日历字段(例如获得下星期的日期)提供了一些方法。

package com.fwedu.date_;

import java.util.Calendar;

public class Calendar01 {
    public static void main(String[] args) {
        //老韩解读
        //1. Calendar 是一个抽象类, 并且构造器是 private
        //2. 可以通过 getInstance() 来获取实例
        //3. 提供大量的方法和字段提供给程序员
        //4. Calendar 没有提供对应的格式化的类, 因此需要程序员自己组合来输出(灵活)
        //5. 如果我们需要按照 24 小时进制来获取时间, Calendar.HOUR ==改成=> Calendar.HOUR_OF_DAY
        Calendar c = Calendar.getInstance(); //创建日历类对象//比较简单, 自由    (因为是抽象类所以不能new)
        System.out.println("c=" + c);
        //2.获取日历对象的某个日历字段
        System.out.println("年: " + c.get(Calendar.YEAR));
        // 这里为什么要 + 1, 因为 Calendar 返回月时候, 是按照 0 开始编号
        System.out.println("月: " + (c.get(Calendar.MONTH) + 1));
        System.out.println("日: " + c.get(Calendar.DAY_OF_MONTH));
        System.out.println("小时: " + c.get(Calendar.HOUR));
        System.out.println("分钟: " + c.get(Calendar.MINUTE));
        System.out.println("秒: " + c.get(Calendar.SECOND));
        //Calender 没有专门的格式化方法, 所以需要程序员自己来组合显示
        System.out.println(c.get(Calendar.YEAR) + "-" + (c.get(Calendar.MONTH) + 1) + "-" +
                c.get(Calendar.DAY_OF_MONTH) +
                " " + c.get(Calendar.HOUR_OF_DAY) + ":" + c.get(Calendar.MINUTE) + ":" + c.get(Calendar.SECOND) );
    }
}

输出如下:
c=java.util.GregorianCalendar[time=1686564400356,areFieldsSet=true,areAllFieldsSet=true,lenient=true,zone=sun.util.calendar.ZoneInfo[id="Asia/Shanghai",offset=28800000,dstSavings=0,useDaylight=false,transitions=31,lastRule=null],firstDayOfWeek=1,minimalDaysInFirstWeek=1,ERA=1,YEAR=2023,MONTH=5,WEEK_OF_YEAR=24,WEEK_OF_MONTH=3,DAY_OF_MONTH=12,DAY_OF_YEAR=163,DAY_OF_WEEK=2,DAY_OF_WEEK_IN_MONTH=2,AM_PM=1,HOUR=6,HOUR_OF_DAY=18,MINUTE=6,SECOND=40,MILLISECOND=356,ZONE_OFFSET=28800000,DST_OFFSET=0]
年: 2023
月: 6
日: 12
小时: 6
分钟: 6
秒: 40
2023-6-12 18:6:40

第三代日期类

前两代日期类的不足分析

在这里插入图片描述

package com.fwedu.date_;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.format.DateTimeFormatter;


public class LocalDateTime01 {
    public static void main(String[] args) {
        //第三代日期
        //老韩解读
        //1. 使用 now() 返回表示当前日期时间的 对象
        LocalDateTime ldt = LocalDateTime.now();
        System.out.println(ldt);
        //2. 使用 DateTimeFormatter 对象来进行格式化
        // 创建 DateTimeFormatter 对象
        DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        String format = dateTimeFormatter.format(ldt);
        System.out.println("格式化的日期=" + format);
        System.out.println("年=" + ldt.getYear());
        System.out.println("月=" + ldt.getMonth());
        System.out.println("月=" + ldt.getMonthValue());
        System.out.println("日=" + ldt.getDayOfMonth());
        System.out.println("时=" + ldt.getHour());
        System.out.println("分=" + ldt.getMinute());
        System.out.println("秒=" + ldt.getSecond());

        //可以获取年月日
        LocalDate now = LocalDate.now();
        //获取到时分秒
        LocalTime now2 = LocalTime.now();
        //提供 plus 和 minus 方法可以对当前时间进行加或者减
        //看看 890 天后, 是什么时候 把 年月日-时分秒
        LocalDateTime localDateTime = ldt.plusDays(890);
        System.out.println("890 天后=" + dateTimeFormatter.format(localDateTime));
        //看看在 3456 分钟前是什么时候, 把 年月日-时分秒输出
        LocalDateTime localDateTime2 = ldt.minusMinutes(3456);
        System.out.println("3456 分钟前 日期=" + dateTimeFormatter.format(localDateTime2));
    }
}

DateTimeFormatter 格式日期类

关于 DateTimeFormatter 的各个格式参数,需要看 jdk8 的文档。

import java.time.format.DateTimeFormatter;

DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
String format = dateTimeFormatter.format(ldt);

Instant 时间戳

package com.fwedu.date_;

import java.time.Instant;
import java.util.Date;

public class Instant01 {
    public static void main(String[] args) {
        //1.通过 静态方法 now() 获取表示当前时间戳的对象
        Instant now = Instant.now();
        System.out.println(now);
        //2. 通过 from 可以把 Instant 转成 Date
        Date date = Date.from(now);
        //3. 通过 date 的 toInstant() 可以把 date 转成 Instant 对象
        Instant instant = date.toInstant();
    }
}

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

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

相关文章

安卓手机使用Termux搭建Hexo个人博客网站【内网穿透公网访问】

文章目录 1. 安装 Hexo2. 安装cpolar内网穿透3. 公网远程访问4. 固定公网地址 转载自cpolar极点云的文章&#xff1a;安卓手机使用Termux搭建Hexo个人博客网站【内网穿透公网访问】 Hexo 是一个用 Nodejs 编写的快速、简洁且高效的博客框架。Hexo 使用 Markdown 解析文章&#…

R 语言学习笔记

1. 基础语法 赋值 a 10; b <- 10;# 表示流向&#xff0c;数据流向变量&#xff0c;也可以写成10 -> b创建不规则向量 不用纠结什么是向量&#xff0c;就当作一个容器&#xff0c;数据类型要相同 a c("我","爱","沛")创建一定规则的向…

意向共享锁和意向排他锁

InnoDB表级锁 在绝大部分情况下都应该使用行锁&#xff0c;因为事务和行锁往往是选择InnoDB的理由&#xff0c;但个别情况下也使用表级锁&#xff1a; 1&#xff09;事务需要更新大部分或全部数据&#xff0c;表又比较大&#xff0c;如果使用默认的行锁&#xff0c;不仅这个事…

前端web入门-CSS-day06

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;请留下您的足迹&#xff09; 目录 一、标准流 二、Flex 布局 组成 主轴对齐方式 侧轴对齐方式 修改主轴方向 弹性伸缩比 弹性盒子换行…

uniapp中使用mixins(混入)使用

mixins 选项接收一个混入对象的数组。这些混入对象可以像正常的实例对象一样包含实例选项&#xff0c;这些选项将会被合并到最终的选项中&#xff0c;使用的是和 Vue.extend() 一样的选项合并逻辑。也就是说&#xff0c;如果你的混入包含一个 created 钩子&#xff0c;而创建组…

设计用户模块的schema

schema 在计算机科学中&#xff0c;schema通常指的是 数据结构的定义和约束。 关系型数据库 在关系型数据库中&#xff0c;schema指的是数据库中所有表格的定义和表格之间的关系约束&#xff0c;包括每个表格的列名、数据类型、主键、外键等等。 如果要对一个关系型数据库进行…

Leetcode-6425. 找到最长的半重复子字符串

题目描述 给你一个下标从 0 开始的字符串 s &#xff0c;这个字符串只包含 0 到 9 的数字字符。 如果一个字符串 t 中至多有一对相邻字符是相等的&#xff0c;那么称这个字符串是 半重复的 。 请你返回 s 中最长 半重复 子字符串的长度。 一个 子字符串 是一个字符串中一段…

力扣日记2481

1. 题目 LeetCode 2481. 分割圆的最少切割次数 1.1 题意 可以使用直接或半径切分&#xff0c;管他叫一次切分&#xff0c;求切分圆为n等份的最少次数。 1.2 分析 可以想到&#xff0c;对圆做n等分&#xff0c;然后每个半径看出一次切分&#xff0c;这是最多次数&#xff0c;…

Python3 列表与元组 | 菜鸟教程(六)

目录 一、Python3 列表 &#xff08;一&#xff09;简介相关 1、序列是 Python 中最基本的数据结构。 2、序列中的每个值都有对应的位置值&#xff0c;称之为索引&#xff0c;第一个索引是 0&#xff0c;第二个索引是 1&#xff0c;依此类推。 3、Python 有 6 个序列的内置…

算法刷题-字符串-替换空格

题目&#xff1a;剑指Offer 05.替换空格 力扣题目链接 请实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 示例 1&#xff1a; 输入&#xff1a;s “We are happy.” 输出&#xff1a;“We%20are%20happy.” 思路 如果想把这道题目做到极致&…

webpack提升开发体验SourceMap

一、开发场景介绍 开发中我们不可避免的会写一些bug出来&#xff0c;这时候要调试&#xff0c;快速定位到bug到底出现在哪尤为关键。 例如我故意在sum函数中写一个错误代码如下&#xff1a; 这时我们用前面章节已经写好的开发模式的webpack.dev.js运行&#xff0c;控制台会出…

【总结笔记】Spring

1 Spring容器加载配置文件进行初始化。 Spring容器加载配置文件进行初始化主要有两种形式&#xff1a; 加载配置文件进行初始化&#xff1a; ClassPathXmlApplicationContext ctx new ClassPathXmlApplicationContext(“ApplicationContext.xml”); 加载配置类进行初始化&…

业务流程自动化:ThinkAutomation Professional Crack

ThinkAutomation 助力您的业务流程自动化。自动执行本地和基于云的业务流程&#xff0c;以降低成本并节省时间。 自动化传入的通信渠道&#xff0c;监控数据库&#xff0c;对传入的Webhook&#xff0c;Web表单和聊天机器人做出反应。处理文档、附件、本地文件和其他邮件源。 …

基于Spark的气象数据分析

研究背景与方案 1.1.研究背景 在大数据时代背景下&#xff0c;各行业数据的规模大幅度增加&#xff0c;数据类别日益复杂&#xff0c;给数据分析工作带来极大挑战。气象行业和人们的生活息息相关&#xff0c;随着信息时代的发展&#xff0c;大数据技术的出现为气象数据的发展…

模板匹配笔记

模板匹配是一种最基本、最原始的模式识别的方法。通过对比某一特定物体的图案位于图像的什么地方&#xff0c;进而识别出物体。它是图像处理中最基本、最常用的匹配方法。它的局限性主要是它只能进行平行移动&#xff0c;若原图像中的匹配目标发生旋转或大小变化&#xff0c;该…

前端vue入门(纯代码)09

【09.vue中组件的自定义事件】 自定义组件链接 在vue中用的click【点击】、keyup【按键】……等事件&#xff0c;这些属于内置事件&#xff0c;也就是js自带的事件。 问题一&#xff1a;什么是组件自定义事件呢&#xff1f; 【内置事件】:是给html元素用的&#xff0c;比如s…

014、数据库管理之配置管理

配置管理 TiDB配置系统配置集群配置配置的存储位置区分TiDB的系统参数和集群参数 系统参数系统参数的作用域系统参数的修改 集群参数集群参数的修改配置参数的查看 实验一&#xff1a; 在不同作用域下对数据库的系统参数进行修改session级别global级别 实验二&#xff1a; 修改…

【TCP/IP】多进程服务器的实现(进阶) - 信号处理及signal、sigaction函数

目录 信号 signal函数 sigaction函数 用信号来处理僵尸进程 在之前我们学习了如何处理“僵尸进程”&#xff0c;不过可能也会有疑问&#xff1a;调用wait和waitpid函数时我们关注的始终是在子进程上&#xff0c;那么在父进程上如何实现对子进程的管控呢&#xff1f;为此&am…

零基础速成simulink代码生成——简单滤波器实现2

simulink setting 找到model settings solver求解器配置 Code Generation 代码生成配置 生成代码报告 添加stateflow注释 可以将变量保存在定义的文件(选) 实践 简单一阶滤波器

使用一键安装工具快速搭建 ESP-IDF 开发环境 (Windows)

我们收到用户对 ESP-IDF SDK 软件开发环境感到搭建难、门槛高的反馈。为解决用户在此方面的问题。为此&#xff0c;我们推出本期教程介绍在 Windows 操作系统下使用一键安装工具快速搭建 ESP-IDF 开发环境。 您可以观看下面的教程视频&#xff0c;也可以阅读接下来本篇的图文教…