第七章:Java常用类

news2025/8/6 6:27:34

第七章:Java常用类

7.1:字符串相关的类

  1. String的特性

    • String表示是字符串,使用一对""引起来表示。

    • String声明为final的,不可被继承。

    • String实现了Serializable、Comparable接口,表示字符是支持序列化和比较大小。

    • String内部定义了final char[] value用于存储字符串数据。

    • String代表不可变的字符串序列。简称:不可变性。

    • 通过字面量的方式(区别于new)给一个字符串赋值,此时的字符串值声明在字符串常量池中。

    • 字符串常量池中是不会存储相同内容的字符串的。

    • 通过new String()的方式创建一个字符串,是数据在堆空间中开辟空间以后对应的地址值。

      //字面量的定义方式
      String s1 = "abc"; 
      String s2 = "abc";
      System.out.println(s1 == s2); //true
      
      String s3 = "abc";
      s3 += "def";
      System.out.println(s3); //abcdef
      System.out.println(s2); //abc
      
    • 常量与常量的拼接结果在常量池。

    • 只要其中有一个是变量,结果就在堆中。

    • 如果拼接的结果调用intern()方法,返回值就在常量池中。

      String s1 = "javaEE";
      String s2 = "hadoop";
      String s3 = "javaEEhadoop";
      
      String s4 = "javaEE" + "hadoop";
      String s5 = s1 + "hadoop";
      
      System.out.println(s3 == s4);//true
      System.out.println(s3 == s5);//false
      
      String s6 = s5.intern();
      System.out.println(s3 == s6);//true
      
  2. 字符串常用方法

    • int length():返回字符串的长度。

    • char cahrAt(int index):返回某索引出的字符。

    • boolean isEmpty():判断是否是空字符串。

    • String toLowerCase():使用默认语言环境,将String中的所有字符转换为小写。

    • String toUpperCase():使用默认语言环境,将String中的所有字符转换为大写。

    • String trim():返回字符串的副本,忽略前导空白和尾部空白。

      String s1 = "HelloWorld";
      System.out.println(s1.length()); //10
      System.out.println(s1.charAt(9)); //d
      System.out.println(s1.isEmpty()); // false
      
      String s2 = s1.toLowerCase();
      System.out.println(s2); //helloworld
      
      String s3 = "   he  llo   world   ";
      String s4 = s3.trim();
      System.out.println("-----" + s4 + "-----"); //----he   llo    world----
      
    • boolean equals(Object obj):比较字符串的内容是否相同。

    • boolean equalsIgnoreCase(String anotherString):与equals方法类似,忽略大小写。

    • String concat(String str):将指定字符串连接到此字符串的结尾。

    • int compareTo(String anotherString):比较两个字符串的大小。

    • String substring(int beginIndex):返回一个新的字符串,从beginIndex开始截取到最后的一个子字符串。

    • String substring(int beginIndex, int endIndex):从beginIndex开始截取到endIndex(不包含)的一个字符串

      String s1 = "HelloWorld";
      String s2 = "helloworld";
      System.out.println(s1.equals(s2)); // false
      System.out.println(s1.equalsIgnoreCase(s2)); // true
      
      String s3 = "abc";
      String s4 = s3.concat("def");
      System.out.println(s4); //abcdef
      
      String s5 = "abc";
      String s6 = new String("abe");
      System.out.println(s5.compareTo(s6)); //-2
      
      String s7 = "小王同学要加油";
      String s8 = s7.substring(2);
      System.out.println(s8); //同学要加油
      String s9 = s7.substring(2, 5);
      System.out.println(s9); //同学要
      
    • boolean endsWith(String suffix):测试此字符串是否以指定的后缀结束。

    • boolean startsWith(String prefix):测试此字符串是否以指定的前缀开始。

    • boolean startWith(String prefix, int toffset):测试此字符串从指定索引开始的字符串是否以指定前缀开始

      String str1 = "hellowworld";
      boolean b1 = str1.endsWith("rld");
      System.out.println(b1); //true
      
      boolean b2 = str1.startsWith("He");
      System.out.println(b2); //false
      
      boolean b3 = str1.startsWith("ll",2);
      System.out.println(b3); //true
      
    • boolean contains(CharSequence s):当且仅当此字符串包含指定的char值序列时,返回true

    • int indexOf(String str):返回指定字符串在此字符串中第一次出现处的索引。

    • int indexOf(String str, int fromIndex)

      返回指定字符串在此字符串中第一次出现的索引,从指定的索引开始

    • int lastIndexOf(String str):返回指定字符串在此字符串中最右边出现的索引。

    • int lastIndexOf(String str, int fromIndex)

      返回指定字符串在此字符串中最后一次出现的索引,从指定的索引开始反向搜索。

      String str1 = "hellowworld";
      String str2 = "wor";
      System.out.println(str1.contains(str2)); //true 
      
      System.out.println(str1.indexOf("lol")); //-1(表示没有找到)
      System.out.println(str1.indexOf("lo",5)); //-1
      
      String str3 = "hellorworld";
      System.out.println(str3.lastIndexOf("or")); //6
      System.out.println(str3.lastIndexOf("or",6)); //6
      
    • String replace(char oldChar, char newChar):返回一个新的字符串,它是通过newChar替换此字符串中出现的所有orlChar得到的。

    • String replace(CharSequence target, CharSequence reqlacement):使用指定的字面值替换序列替换此字符串所有匹配字面值目标序列的字符串。

    • String replaceAll(String regex, String replacement):使用给定的reqlacement替换此字符串所有匹配给定的正则表达式的字符串。

    • String replaceFirst(String regex, String replacement):使用给定的replacement替换此字符串匹配给定的正则表达式的第一个字符串。

      String str1 = "小王同学要加油小王";
      String str2 = str1.replace('王', '胡');
      System.out.println(str2); //小胡同学要加油小胡
      
      String str3 = str1.replace("小王", "小胡");
      System.out.println(str3); //小胡同学要加油小胡
      
      String str = "12hello34world5java7891mysql456";
      String string = str.replaceAll("\\d+", ",").replaceAll("^,|,$", "");
      System.out.println(string); //hello,world,java,mysql
      
    • boolean matches(String regex):告知此字符串是否匹配给定的正则表达式。

    • String[] split(String regex):根据给定正则表达式的匹配拆分此字符串

    • String[] split(String regex, int limit):根据匹配给定的正则表达式来拆分此字符串,最多不超过limit个,如果超过了,剩下的全部都放到最后一个元素中

      String str = "12345";
      boolean matches = str.matches("\\d+");
      System.out.println(matches); //true
      
      str = "hello|world|java";
      String[] strs = str.split("\\|");
      for (int i = 0; i < strs.length; i++) {
          System.out.print(strs[i] + "\t"); //hello	world	java
      }
      
  3. String与基本数据类型转换

    • 字符串 ———— 基本数据类型、包装类

      String str1 = "123";
      // 字符串 转 基本数据类型、包装类
      int num = Integer.parseInt(str1);
      // 基本数据类型、包装类 转 字符串
      String str2 = String.valueOf(num);
      
    • 字符数组 ———— 字符串

      String str1 = "abc123";  
      // 字符串  转  字符数组
      char[] charArray = str1.toCharArray();
      // 字符数组  转  字符串
      char[] arr = new char[]{'h','e','l','l','o'};
      String str2 = new String(arr);
      
    • 字节数组 ———— 字符串

      String str1 = "abc123中国";
      // 字符串  转  字节数组
      byte[] bytes = str1.getBytes(); //使用默认字符集将字符串转字节数组
      byte[] gbks = str1.getBytes("gbk"); //使用gbk格式的字符集将字符串转字符数组,此处会有异常
      // 字符数组  转  字符串
      String str2 = new String(bytes);//使用默认字符集将字符数组转字节串
      String str4 = new String(gbks, "gbk");//使用gbk格式的字符集将字符数组转字符串
      
  4. StringBufferStringBuilder

    • StringBuffer、StringBuilder代表可变的字符序列,可以对字符串内容进行增删,此时不会产生新的对象。

    • StringBuffer、StringBuilder底层使用char[]存储。

    • StringBufferJDK 1.0中声明的,是线程安全的可变字符序列。

    • StringBuilderJDK 5.0中声明的,是线程不安全的可变字符序列。

    • StringBuffer、StringBuilder使用空参构造器时,底层创建了一个长度是16的数组。

      public StringBuffer() {
          super(16);
      }
      
    • 如果要添加的数据底层数组盛不下了,那就需要扩容底层的数组。默认情况下,扩容为原来容量的2倍+2,同时将原有数组中的元素复制到新数组中。

      // StringBuffer类的append方法
      public synchronized StringBuffer append(String str) {
          toStringCache = null;
          super.append(str);
          return this;
      }
      // StringBuffer类父类AbstractStringBuilder类的append方法
      public AbstractStringBuilder append(String str) {
          if (str == null)
              return appendNull();
          int len = str.length();
          ensureCapacityInternal(count + len);
          str.getChars(0, len, value, count);
          count += len;
          return this;
      }
      // AbstractStringBuilder类的ensureCapacityInternal方法
      private void ensureCapacityInternal(int minimumCapacity) {
          if (minimumCapacity - value.length > 0) {
              value = Arrays.copyOf(value, newCapacity(minimumCapacity));
          }
      }
      // AbstractStringBuilder类的newCapacity方法
      private int newCapacity(int minCapacity) {
          int newCapacity = (value.length << 1) + 2;
          if (newCapacity - minCapacity < 0) {
              newCapacity = minCapacity;
          }
          return (newCapacity <= 0 || MAX_ARRAY_SIZE - newCapacity < 0)
              ? hugeCapacity(minCapacity)
              : newCapacity;
      }
      
    • 开发中建议使用StringBuffer(int capacity)StringBuilder(int capacity)指定数组的长度。

  5. StringBufferStringBulider常用方法

    • StringBuffer append(xxx):提供了很多的append()方法,用于进行字符串拼接。
    • StringBuffer delete(int start, int end):删除指定位置的内容。
    • StringBuffer replace(int start, int end, String str):把[start, end)位置替换为str
    • StringBuffer insert(int offset, xxx):在指定位置插入xxx。
    • StringBuffer reverse():把当前字符序列逆转。

7.2:JDK8之前日期时间API

  1. java.lang.System

    • public static long currentTimeMillis():返回当前时间与1970年1月1日0时之间以毫秒为单位的时间差。

      long time = System.currentTimeMillis();
      System.out.println(time);
      
  2. java.util.Date

    • 构造器
      1. Date():使用无参构造器创建的对象可以获取本地当前时间。
      2. Date(long date):创建指定毫秒数的Date对象。
    • 方法
      1. toString():显示当前的年、月、日、时、分、秒。
      2. getTime():获取当前Date对象对应的毫秒数
    //构造器一:Date():创建一个对应当前时间的Date对象
    Date date1 = new Date();
    System.out.println(date1.toString());
    System.out.println(date1.getTime());
    //构造器二:创建指定毫秒数的Date对象
    Date date2 = new Date(155030620410L);
    System.out.println(date2.toString());
    // 将java.util.Date对象转换为java.sql.Date对象
    Date date6 = new Date();
    java.sql.Date date7 = new java.sql.Date(date6.getTime());
    
  3. java.text.SimpleDateFormat

    Date类的API不易于国际化,大部分被废弃了。java.text.SimpleDateFormat类是一个不与语言环境有关的方式来格式化和解析日期的具体类。

    • 构造器

      1. SimpleDateFormat():默认的模式和语言环境创建对象。
      2. SimpleDateFormat(String pattern):该构造方法可以用参数pattern指定的格式创建对象
    • 格式化

      1. public String format(Date date):格式化时间对象date
    • 解析

      1. public Date parse(String source):给定字符串的开始解析文本,以生成一个日期。
    • 按照指定的方式格式化和解析
      在这里插入图片描述

    //实例化SimpleDateFormat:使用默认的构造器
    SimpleDateFormat sdf = new SimpleDateFormat();
    //格式化:日期 --->字符串
    Date date = new Date();
    String format = sdf.format(date);
    System.out.println(format);
    //解析:格式化的逆过程,字符串 ---> 日期
    //要求字符串必须是符合SimpleDateFormat识别的格式(通过构造器参数体现)。否则,抛异常。
    String str = "22-12-18 上午11:43";
    Date date1 = sdf.parse(str);
    System.out.println(date1);
    //按照指定的方式格式化和解析:调用带参的构造器
    SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    //格式化
    String format1 = sdf1.format(date);
    System.out.println(format1);
    //解析
    Date date2 = sdf1.parse("2020-02-18 11:48:27");
    System.out.println(date2);
    
  4. java.util.Calendar(日历)

    • Calendar是一个抽象基类,主用用于完成日期字段之间相互操作的功能。
    • 获取Calendar实例
      1. 使用Calendar.getInstance()方法。
      2. 调用它的子类GregorianCalendar的构造器。
    • 常用方法
      1. public int get(int field):获取想要的时间信息。
      2. public void set(int field, int amount):设置想要的时间信息。
      3. public void add(int field, int amount):在现在的时间增加到想要的时间。
      4. public final Date getTime():日期转为时间。
      5. public final void setTime(Date date):时间转为日期。
    • 注意
      1. 获取月份时:一月是0,二月是1,以此类推,12月是11。
      2. 获取星期时:周日是1,周二是2,以此类推,周六是7。
    //实例化
    Calendar calendar = Calendar.getInstance();
    
    //get()
    int days = calendar.get(Calendar.DAY_OF_MONTH);
    System.out.println(days);
    
    //set()
    calendar.set(Calendar.DAY_OF_MONTH,22);
    days = calendar.get(Calendar.DAY_OF_MONTH);
    System.out.println(days);
    
    //add()
    calendar.add(Calendar.DAY_OF_MONTH,-3);
    days = calendar.get(Calendar.DAY_OF_MONTH);
    System.out.println(days);
    
    //getTime():日历类---> Date
    Date date = calendar.getTime();
    System.out.println(date);
    
    //setTime():Date ---> 日历类
    Date date1 = new Date();
    calendar.setTime(date1);
    days = calendar.get(Calendar.DAY_OF_MONTH);
    System.out.println(days);
    

7.3:JDK8中新日期时间API

  1. LocalDate、LocalTime、LocalDateTime

    LocalDate、LocalTime、LocalDateTime类的实例对象是不可变对象。

    • LocalDate代表IOS格式(yyyy-MM-dd)的日期,可以存储生日、纪念日等日期。

    • LocalTime表示一个时间,而不是日期。

    • LocalDateTime是用来表示日期和时间的。

    • 相关方法
      在这里插入图片描述

    //now():获取当前的日期、时间、日期+时间
    LocalDate localDate = LocalDate.now();
    LocalTime localTime = LocalTime.now();
    LocalDateTime localDateTime = LocalDateTime.now();
    
    System.out.println(localDate);
    System.out.println(localTime);
    System.out.println(localDateTime);
    //of():设置指定的年、月、日、时、分、秒。没有偏移量
    LocalDateTime localDateTime1 = LocalDateTime.of(2020, 10, 6, 13, 23, 43);
    System.out.println(localDateTime1);
    //getXxx():获取相关的属性
    System.out.println(localDateTime.getDayOfMonth());
    System.out.println(localDateTime.getDayOfWeek());
    System.out.println(localDateTime.getMonth());
    System.out.println(localDateTime.getMonthValue());
    System.out.println(localDateTime.getMinute());
    //体现不可变性
    //withXxx():设置相关的属性
    LocalDate localDate1 = localDate.withDayOfMonth(22);
    System.out.println(localDate);
    System.out.println(localDate1);
    
    LocalDateTime localDateTime2 = localDateTime.withHour(4);
    System.out.println(localDateTime2);
    //plusXxx():增加相关属性
    LocalDateTime localDateTime3 = localDateTime.plusMonths(3);
    System.out.println(localDateTime3);
    //minuXxx():减少相关属性
    LocalDateTime localDateTime4 = localDateTime.minusDays(6);
    System.out.println(localDateTime4);
    
  2. 瞬时Instant

    • Instant时间线上的一个瞬时点。这可能被用来记录应用程序中的事件时间戳。

    • 时间线中的一个点表示一个很大的数,这有利于计算机处理。在java中,也是从1970年开始,但以毫秒为单位

    • 因为java.time包是基于纳秒计算的,所以Instant的精度可以达到纳秒级。

    • 1秒 = 1000毫秒 = 10 − 6 ^{-6} 6微秒 = 1 0 − 9 10^{-9} 109纳秒

    • 相关方法
      在这里插入图片描述

    //now()
    Instant instant = Instant.now();
    System.out.println(instant);
    //添加时间的偏移量
    OffsetDateTime offsetDateTime = instant.atOffset(ZoneOffset.ofHours(8));
    System.out.println(offsetDateTime);
    //toEpochMilli()
    long milli = instant.toEpochMilli();
    System.out.println(milli);
    //ofEpochMilli()
    Instant instant1 = Instant.ofEpochMilli(1550475314878L);
    System.out.println(instant1);
    
  3. 格式化与解析日期或时间

    java.time.format.DateTimeFormatter类:该类提供了三种格式化方法

    • 预定义的标准格式:ISO_LOCAL_DATE_TIME、ISO_LOCAL_DATE、ISO_LOCAL_TIME

    • 本地化相关格式:ofLocalizedDateTime()、ofLocalizedDate()

    • 自定义格式

    • 相关方法
      在这里插入图片描述

    // 方式一:预定义的标准格式。如:ISO_LOCAL_DATE_TIME;ISO_LOCAL_DATE;ISO_LOCAL_TIME
    DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
    //格式化:日期-->字符串
    LocalDateTime localDateTime = LocalDateTime.now();
    String str1 = formatter.format(localDateTime);
    System.out.println(str1);
    //解析:字符串 -->日期
    TemporalAccessor parse = formatter.parse("2019-02-18T15:42:18.797");
    System.out.println(parse);
    
    //方式二:
    //FormatStyle.LONG / FormatStyle.MEDIUM / FormatStyle.SHORT :适用于LocalDateTime
    DateTimeFormatter formatter1 = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.LONG);
    //格式化
    String str2 = formatter1.format(localDateTime);
    System.out.println(str2);
    //FormatStyle.FULL / FormatStyle.LONG / FormatStyle.MEDIUM / FormatStyle.SHORT : 适用于LocalDate
    DateTimeFormatter formatter2 = DateTimeFormatter.ofLocalizedDate(FormatStyle.MEDIUM);
    //格式化
    String str3 = formatter2.format(LocalDate.now());
    System.out.println(str3);//2019-2-18
    
    //方式三:自定义的格式
    DateTimeFormatter formatter3 = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
    //格式化
    String str4 = formatter3.format(LocalDateTime.now());
    System.out.println(str4);
    //解析
    TemporalAccessor accessor = formatter3.parse("2019-02-18 03:52:09");
    System.out.println(accessor);
    
  4. 其他API

    • Zoneld:该类中包含了所有的时区信息,一个时区的ID

    • ZonedDateTime:一个在ISO-8601日历系统时区的日期时间。

    • Clock:使用时区提供对当前即时、日期和时间的访问的时钟。

    • Duration:持续时间,用于计算两个时间间隔。

    • Period:日期间隔,用于计算两个日期间隔。

    • TemporalAdjuster:时间校正器。

    • TemporalAdjusters

      该类通过静态方法firstDayOfXxx()/lastDayOfXxx()/nextXxx()提供了大量的常用TemporalAdjuster的实现。

  5. 与传统日期处理的转换
    在这里插入图片描述

7.4:java比较器

Java中经常会设计到对象数组的排序问题,那么就涉及到对象之间的比较问题。

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

    • Comparable接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序。
    • 实现Comparable的类必须实现compareTo(Object obj)方法,两个对象即通过compareTo()方法的返回值来比较大小。
      1. 如果当前对象this大于形参对象obj,则返回正整数。
      2. 如果当前对象this小于形参对象obj,则返回负整数。
      3. 如果当前对象this等于形参对象obj,则返回0。
    • Comparable默认都是从小到大排列的。
  2. 定制排序:java.util.Comparator

    • 当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码,或者实现java.lang.Comparable接口的排序规则不适合当前的操作。那么可以考虑使用Comparator的对象来排序,强行对多个对象进行整体排序的比较
    • 重写compare(Object o1, Object o2)方法比较o1o2的大小。
      1. 如果方法返回正整数,则表示o1大于o1
      2. 如果方法返回0,则表示相等。
      3. 如果方法返回负整数,则表示o1小于o2
  3. 自然排序和定值排序的对比

    • Comparable接口的方式一旦一定,保证Comparable接口实现类的对象在任何位置都可以比较大小。

    • Comparator接口属于临时性的比较。

7.5:System类

System类代表系统,系统级的很多属性和控制方法都防止在该类的内部。该类位于java.lang包。

​ 由于该类的构造器是private的,所以无法创建该类的对象,也就是无法实例化该类。其内部成员变量和成员方法都是static的,所以也可以很方便的进行调用。

  1. 成员变量
    • in:标准输入流(键盘输入)。
    • out:标准输出流(显示器)。
    • orr:标准错误输出流(显示器)。
  2. 成员方法
    • native long currentTimeMillis():返回当前计算机时间和1970年1月1日0时所差的毫秒数。
    • void exit(int status):退出程序。其中status的值为0代表正常退出,非零代表异常退出。
    • void gc():是请求系统进行垃圾回收。
    • String getProperty(String key):获取系统中属性名为key的属性对应的值。
      1. java.version:java运行时环境版本。
      2. java.homejava安装目录。
      3. os.name:操作系统的名称。
      4. os.version:操作系统的版本。
      5. user.name:用户的账户名称。
      6. user.home:用户的主目录。
      7. user.dir:用户的当前工作目录。

7.6:Math类

java.lang.Math提供了一系列静态方法用于科学计算。其方法的参数和返回值类型一般为double型。

  1. abs:绝对值
  2. acos、asin、atan、cos、sin、tan:三角函数
  3. sqrt:平方根
  4. pow(double a, double b):a的b次幂
  5. log:自然对数
  6. exp:e为底指数
  7. max(double a, double b):两个数中找较大的数
  8. min(double a, double b):两个数中找较小的数
  9. random():返回0.0到1.0的随机数
  10. long round(double a)doubel型数据a转换为long型。(四舍五入)
  11. toDegrees(double angrad):弧度转角度
  12. toRadians(double angdeg):角度转弧度

7.7:BigInteger和BigDecimal

  1. BigInteger
    • java.math包的BigInteger可以表示不可变的任意精度的整数。
    • BigInteger提供所有java基本整数操作符的对应物,并提供java.lang.Math的所有相关方法。
    • BigInteger还提供模算术、GCD计算、质数测试、素数生成、位操作以及一些其他操作。
    • 构造器
      1. BigInteger(String val):根据字符串构建BigInteger对象。
    • 常用方法
      1. public BigInteger abs():返回此BigInteger的绝对值的BigInteger
      2. BigInteger add(BigInteger val):返回其值为this + valBigInteger
      3. BigInteger subtract(BigInteger val):返回其值为this - valBigInteger
      4. BigInteger multiply(BigInteger val):返回其值为this * valBigInteger
      5. BigInteger divide(BigInteger val):返回其值为this / valBigInteger。整数相除只保留整数部分。
      6. BigInteger remainder(BigInteger val):返回其值为this % valBigInteger
      7. BigInteger[] divideAndRemainder(BigInteger val):返回包含this / val后跟this % val的两个BigInteger的数组。
      8. BigInteger pow(int exponent):返回其值为this 的 exponent次幂BigInteger
  2. BigDecimal
    • 一般的Float类和Double类可以用来做科学计算或工程计算,但是在商业计算中,要求数字精度比较高,故用到java.math.BigDecimal类。
    • BigDecimal类支持不可变的、任意精度的有符号十进制定点数。
    • 构造器
      1. public BigDecimal(double val)
      2. public BigDecimal(String val)
    • 常用方法
      1. public BigDecimal add(BigDecimal augend)
      2. public BigDecimal subtract(BigDecimal subtrahend)
      3. public BigDecimal multiply(BigDecimal multiplicand)
      4. public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)

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

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

相关文章

【WPF 值转换器】ValueConverter 进阶用法

【WPF 值转换器】ValueConverter 进阶用法介绍基类实现子类实现效果介绍 值转换器在WPF开发中是非常常见的&#xff0c;当然不仅仅是在WPF开发中。值转换器可以帮助我们很轻松地实现&#xff0c;界面数据展示的问题&#xff0c;如&#xff1a;模块隐藏显示、编码数据展示为可读…

拼多多跨境电商业务将正式登陆澳洲,持续助力中国制造业开拓全球市场

配图来自Canva可画 拼多多出海又有新进展。据最新消息&#xff0c;拼多多跨境电商业务将于3月13日正式进入澳大利亚、新西兰&#xff0c;持续推动中国制造业直连澳洲以及全球市场。 去年9月&#xff0c;拼多多正式在北美地区上线跨境电商平台TEMU。自上线至今&#xff0c;TEM…

硬件设备二 调试分类、软/硬件断点、OpenOCD、JLink、STLink 使用

近期工作开始主用 OpenOCD 来进行相关开发工作的调试&#xff0c;因此本文重点来学习一下&#xff01;本文以 OpenOCD 为重点&#xff0c;辅以 JLink、STLink 作为对比来进行学习。 调试 本地调试 本地调试通常指调试使用的环境与调试的目标运行环境一致的调试方法&#xff0…

linux软件管理

软件管理 1、rpm管理工具 RPM是(Redhat Package Manager) 的缩写&#xff0c;由Red Hat公司提出的一种软件包管理标准 &#xff08;1&#xff09;rpm软件包的典型命名格式&#xff1a; 例&#xff1a;zsh-5.0.2-14.el8.x86_64.rpm zsh-50214el8x8664软件名主版本号次版本号…

day26_HTML

今日内容 上课同步视频:CuteN饕餮的个人空间_哔哩哔哩_bilibili 同步笔记沐沐霸的博客_CSDN博客-Java2301 零、 复习昨日 一、二阶段介绍 二、HTML 零、 复习昨日 见代码 一、二阶段介绍 第一阶段: 基础入门 java基本语法编程基础(方法,数组)面向对象编程常用类高级(IO,线程,新…

新增 IEC61850、Profinet 驱动

2 月&#xff0c;Neuron 团队主要侧重于开发新的驱动&#xff0c;新增了南向 IEC61850 驱动、南向 Allen-Bradley DF1 驱动、Profinet 驱动支持以及静态点位等功能&#xff0c;这些新驱动和新功能将在 2.4 版本中正式发布。 IEC61850 驱动 IEC61850 标准是电力系统自动化领域…

网络基础(2)

目录1. 端口号2. 套接字socket3. 网络通信3.1 sockaddr与sockaddr_in3.2 接口服务端3.2.1 创建套接字&#xff0c;打开网络文件3.2.2 给该服务器绑定端口和ip&#xff08;特殊处理&#xff09;3.2.3 初始化相关服务器3.2.4 提供服务客户端3.2.5 绑定3.2.6 使用服务4. makefile实…

关于 JavaScript 中的 Promises

在 JavaScript 中&#xff0c;Promise 是一个对象&#xff0c;它表示一个可能还不可用&#xff0c;但会在未来解决的值。Promises 用于处理异步操作&#xff0c;例如发出网络请求或访问数据库&#xff0c;其中结果不是立即可用的。如果你准备好了&#xff0c;我想开始我们的冒险…

基于SpringBoot+SpringCloud+Vue前后端分离项目实战 --开篇

本文目录前言做项目的三大好处强强联手(天狗组合)专栏作者简介专栏的优势后端规划1. SpringBoot 和 SpringCloud 的选择2. Mybatis 和 MybatisPlus 和 JPA 的选择3. MySQL 和 Mongodb 的选择4. Redis 和 RocketMQ5. 后端规划小总结后端大纲提前掌握的知识点一期SpringBoot二期S…

EventLoop机制

JavaScript 是单线程的语言 JavaScript 是一门单线程执行的编程语言。也就是说&#xff0c;同一时间只能做一件事情。 单线程执行任务队列的问题&#xff1a; 如果前一个任务非常耗时&#xff0c;则后续的任务就不得不一直等待&#xff0c;从而导致程序假死的问题。 同步任…

机器学习和深度学习的综述

机器学习和深度学习的综述 1.1.1人工智能、机器学习、深度学习的关系 人工智能&#xff08;Artificial Intelligence&#xff0c;AI&#xff09;是最宽泛的概念&#xff0c;是研发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。由于这个定义…

代码随想录算法训练营第二十一天打卡 | 530.二叉搜索树的最小绝对差、501.二叉搜索树中的众数、236. 二叉树的最近公共祖先

打卡第21天&#xff0c;继续二叉树&#xff0c;前几天终于补完了&#xff0c;感觉难度上来了。 今日任务 530.二叉搜索树的最小绝对差501.二叉搜索树中的众数 二叉树的最近公共祖先 530.二叉搜索树的最小绝对差 给你一个二叉搜索树的根节点 root &#xff0c;返回 树中任意两不…

计算机网络——路由、交换、子网篇

子网掩码 解释1 作者&#xff1a;纪言 链接&#xff1a;https://www.zhihu.com/question/56895036/answer/447915532 来源&#xff1a;知乎 著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。 仅限ip4首先子网掩码这名字取得很好&#xff0c…

Java创建线程的方式只有一种:Thread+Runnable

Java创建线程的方式其实只有一种&#x1f468;‍&#x1f393;一、继承Thread&#x1f468;‍&#x1f393;二、实现Runnable接口&#x1f468;‍&#x1f393;三、实现Callable接口&#x1f468;‍&#x1f393;四、通过线程池创建&#x1f468;‍&#x1f393;五、总结一般我…

SOLID 原则要这么理解!

什么是 SOLID 原则 SOLID 原则其实是用来指导软件设计的&#xff0c;它一共分为五条设计原则&#xff0c;分别是&#xff1a; 单一职责原则&#xff08;SRP&#xff09;开闭原则&#xff08;OCP&#xff09;里氏替换原则&#xff08;LSP&#xff09;接口隔离原则&#xff08;…

Matter 系列 #9|乐鑫 Matter 预配置服务加速设备生产

乐鑫 Matter 系列文章 #9 目录 Matter 预配置服务 1. 设备认证 (Device Attestation) 2. 独特性 (Uniqueness) 3. 安全性 (Security) 联系我们​​​​​​​ 如今&#xff0c;物联网行业蓬勃发展&#xff0c;大量市场参与者正在积极地构建 Matter 智能设备。 乐鑫一直致…

盲盒开发:多元化设计、数字化销售、可持续发展

随着互联网的发展&#xff0c;盲盒成为了一种新型文化现象和玩具消费方式。它不仅满足了人们的消费需求&#xff0c;也引发了人们对玩具和收藏品的热爱和追求。目前&#xff0c;盲盒市场已经逐渐发展成为一个庞大的产业&#xff0c;其中海外盲盒市场更是异彩纷呈&#xff0c;备…

Git安装初始化及Gitee上传提交步骤

一、git安装git下载https://git-scm.com/download/win直接点击下一步“next”安装即可在桌面右键&#xff0c;选择 Git Bash Here 在 Git Bash Here 终端里输入 git --version 查看 git 版本&#xff0c;如图所示&#xff0c;说明 Git 安装成功。在终端设置用户签名邮箱git con…

windows7安装sql server 2000安装步骤 及安装过程中遇到的问题和解决方式

提示&#xff1a;文章写完后windows7安装sql server 2000安装步骤 及安装过程中遇到的问题和解决方式&#xff0c; 文章目录一、ms sql server 2000是什么&#xff1f;版本简介&#xff1a;**特点&#xff1a;****优点&#xff1a;**二、步骤1.下载安装包及Sq4补丁包2.安装 ms …

淘宝 APP 网络架构演进与弱网破障实践

作者&#xff1a;沈良炜 阿里大淘宝终端体验平台团队 面对移动互联网络下复杂多变的网络环境&#xff0c;如何提供更稳定可靠的请求性能&#xff0c;保障用户的加载浏览体验&#xff1f;本文将为大家分享淘宝APP统一网络库的演进。 一、引言 自2013年ALLIN无线到今天&#xff0…