《JavaSE》---17.<String 类的常见操作>

目录

前言

一、String类的常见用法

1.1 字符串构造(常见三种)

①使用常量串构造

②直接newString对象

③ 使用字符数组进行构造

 注意:

1.2 String对象的比较 

1. ==比较是否引用同一个对象

2. boolean equals(Object anObject) 方法:

3. int compareTo(String s) 方法:

4. int compareToIgnoreCase(String str) 方法:

1.3 字符串查找

1.4 四种转化 

①数值和字符串转化

②大小写转换

③字符串转数组

④格式化

1.5字符串替换

 1.6 字符串拆分

1.7 字符串截取

1.8 其他操作方法

1.9 字符串的不可变性

为什么 String 要设计成不可变的?(了解)

1.10 字符串修改

二、StringBuilder和StringBuffer

2.1 StringBuilder的介绍

 面试题:

 三、 String类编程题练习(leetcode)

1.字符串相加

2.字符串中第一个唯一字符 

3.最后一个单词的长度 

 4.验证回文串


前言

本篇博客主要讲解Java基础语法中的

认识 String 类 ,了解 String 类的基本用法,知道字符串的三种常见构造方法。

会使用String对象的比较,知道==、equals、compareTo、compareToIgnoreCase比较的用法和区别。等String类常见用法。 熟练掌握 String 类的常见操作 、认识字符串常量池、

认识 StringBuffer 和 StringBuilder、最后是String类编程题的练习。


      大家好,本人是普通一本的在校大学生一枚,目前在学习java。之前也学了一段时间,但是没有发布博客。本人现在已经大二结束了,开学就大三了,时间过的真的很快。我会利用好这个暑假,来复习之前学过的内容,并整理好之前写过的博客进行发布。如果博客中有错误或者没有读懂的地方。热烈欢迎大家在评论区进行讨论!!!

      喜欢我文章的兄弟姐妹们可以点赞,收藏和评论我的文章。喜欢我的兄弟姐妹们以及也想复习一遍java知识的兄弟姐妹们可以关注我呦,我会持续更新滴,并且追求完整。
望支持!!!!!!一起加油呀!!!!

语言只是工具,不能决定你好不好找工作,决定你好不好找工作的是你的能力!!!!!

学历本科及以上就够用了!!!!!!!!!!!!!!!!!!!!!!!!!!!!

话不多说,直接上干货 


一、String类的常见用法

我们都知道String是字符串类型,是引用类型。在java中String也是一个类。

1.1 字符串构造(常见三种)

①使用常量串构造

// 使用常量串构造String s1 = "hello bit";System.out.println(s1);

②直接newString对象

     // 直接newString对象String s2 = new String("hello bit");System.out.println(s1);

③ 使用字符数组进行构造

     // 使用字符数组进行构造char[] array = {'h','e','l','l','o','b','i','t'};String s3 = new String(array);System.out.println(s1);

 注意:

1. String是引用类型,内部并不存储字符串本身,在String类的实现源码中,String类实例变量如下:

public static void main(String[] args) {// s1和s2引用的是不同对象 s1和s3引用的是同一对象String s1 = new String("hello");String s2 = new String("world");String s3 = s1;System.out.println(s1.length());   // 获取字符串长度---输出5System.out.println(s1.isEmpty());  // 如果字符串长度为0,返回true,否则返回false
}

代码图解: 

 

 s1和s2引用的是不同对象 s1和s3引用的是同一对象

2. 在Java中“”引起来的也是String类型对象。

// 打印"hello"字符串(String对象)的长度
System.out.println("hello".length());

1.2 String对象的比较 

字符串的比较是常见操作之一,比如:字符串排序。Java中总共提供了4种方式:

1. ==比较是否引用同一个对象

  • 对于基本类型,==比较的是变量中的值;
  • 对于引用类型==比较的是引用中的地址。
public static void main(String[] args) {int a = 10;int b = 20;int c = 10;// 对于基本类型变量,==比较两个变量中存储的值是否相同System.out.println(a == b);    // falseSystem.out.println(a == c);    // true// 对于引用类型变量,==比较两个引用变量引用的是否为同一个对象String s1 = new String("hello");String s2 = new String("hello");String s3 = new String("world");String s4 = s1;System.out.println(s1 == s2);   // falseSystem.out.println(s2 == s3);   // falseSystem.out.println(s1 == s4);   // true
}

2. boolean equals(Object anObject) 方法:

按照字典序比较

字典序:字符大小的顺序

String类重写了父类Object中equals方法,Object中equals默认按照==比较,

String重写equals方法后,按照 如下规则进行比较,

比如: s1.equals(s2)

public boolean equals(Object anObject) {// 1. 先检测this 和 anObject 是否为同一个对象比较,如果是返回trueif (this == anObject) {return true;}// 2. 检测anObject是否为String类型的对象,如果是继续比较,否则返回falseif (anObject instanceof String) {// 将anObject向下转型为String类型对象String anotherString = (String)anObject;int n = value.length;// 3. this和anObject两个字符串的长度是否相同,是继续比较,否则返回falseif (n == anotherString.value.length) {char v1[] = value;char v2[] = anotherString.value;int i = 0;// 4. 按照字典序,从前往后逐个字符进行比较while (n-- != 0) {if (v1[i] != v2[i])return false;i++;}return true;}}return false;
}
public static void main(String[] args) {String s1 = new String("hello");String s2 = new String("hello");String s3 = new String("Hello");// s1、s2、s3引用的是三个不同对象,因此==比较结果全部为falseSystem.out.println(s1 == s2);       // falseSystem.out.println(s1 == s3);       // false// equals比较:String对象中的逐个字符// 虽然s1与s2引用的不是同一个对象,但是两个对象中放置的内容相同,因此输出true// s1与s3引用的不是同一个对象,而且两个对象中内容也不同,因此输出falseSystem.out.println(s1.equals(s2));  // trueSystem.out.println(s1.equals(s3));  // false
}
  • ==比较结果全部为false,因为s1、s2、s3引用的是三个不同对象

        equals比较:String对象中的逐个字符

  • 两个对象中放置的内容相同,因此输出true虽然s1与s2引用的不是同一个对象
  • s1与s3引用的不是同一个对象,而且两个对象中内容也不同,因此输出false

3. int compareTo(String s) 方法:

按照字典序进行比较

与equals不同的是

equals返回的是boolean类型,而compareTo返回的是int类型。具体比较方式: 

1. 先按照字典次序大小比较,如果出现不等的字符,直接返回这两个字符的大小差值

2. 如果前k个字符相等(k为两个字符长度最小值),返回值两个字符串长度差值

public static void main(String[] args) {String s1 = new String("abc");String s2 = new String("ac");String s3 = new String("abc");String s4 = new String("abcdef");System.out.println(s1.compareTo(s2));   // 不同输出字符差值-1System.out.println(s1.compareTo(s3));   // 相同输出 0System.out.println(s1.compareTo(s4));   // 前k个字符完全相同,输出长度差值 -3
}

4. int compareToIgnoreCase(String str) 方法:

与compareTo方式相同,但是忽略大小写比较 

public static void main(String[] args) {String s1 = new String("abc");String s2 = new String("ac");String s3 = new String("ABc");String s4 = new String("abcdef");System.out.println(s1.compareToIgnoreCase(s2));   // 不同输出字符差值-1System.out.println(s1.compareToIgnoreCase(s3));   // 相同输出 0System.out.println(s1.compareToIgnoreCase(s4));   // 前k个字符完全相同,输出长度差值 -3
}

1.3 字符串查找

String类提供的常用查找的方法:

public static void main(String[] args) {String s = "aaabbbcccaaabbbccc";System.out.println(s.charAt(3));                             // 'b'System.out.println(s.indexOf('c'));                          // 6System.out.println(s.indexOf('c', 10));                      // 15System.out.println(s.indexOf("bbb"));                        // 3System.out.println(s.indexOf("bbb", 10));                    // 12System.out.println(s.lastIndexOf('c'));                      // 17System.out.println(s.lastIndexOf('c', 10));                  // 8System.out.println(s.lastIndexOf("bbb"));                    // 12System.out.println(s.lastIndexOf("bbb", 10));                // 3
}

注意:上述方法都是实例方法。

1.4 四种转化 

①数值和字符串转化

数字转字符串:

String.valueOf(1234);

字符串转数字:

Integer.parseInt("1234");

    public static void main(String[] args) {// 数字转字符串String s1 = String.valueOf(1234);String s2 = String.valueOf(12.34);String s3 = String.valueOf(true);String s4 = String.valueOf(new Student("Hanmeimei", 18));System.out.println(s1);System.out.println(s2);System.out.println(s3);System.out.println(s4);System.out.println("=================================");// 字符串转数字// 注意:Integer、Double等是Java中的包装类型,这个后面会讲到int data1 = Integer.parseInt("1234");double data2 = Double.parseDouble("12.34");System.out.println(data1);System.out.println(data2);}

运行结果 

 

②大小写转换

s1.toUpperCase();

s2.toLowerCase();

    public static void main(String[] args) {String s1 = "hello";String s2 = "HELLO";System.out.println(s1.toUpperCase()); // 小写转大写System.out.println(s2.toLowerCase()); // 大写转小写}

运行结果

 

③字符串转数组

s.toCharArray();

    public static void main(String[] args) {String s = "hello"; // 字符串转数组char[] ch = s.toCharArray();for (int i = 0; i < ch.length; i++) {System.out.print(ch[i]);}System.out.println(); // 数组转字符串String s2 = new String(ch);System.out.println(s2);}

 

④格式化

String.format();

public static void main(String[] args) {String s = String.format("%d-%d-%d", 2019, 9,14);System.out.println(s);
}

2019-9-14 

1.5字符串替换

使用一个指定的新的字符串替换掉已有的字符串数据,可用的方法如下:

代码示例: 字符串的替换处理

        String str = "helloworld" ;System.out.println(str.replaceAll("l", "_"));System.out.println(str.replaceFirst("l", "_"));

运行结果

 

注意事项: 由于字符串是不可变对象, 替换不修改当前字符串, 而是产生一个新的字符串.

 1.6 字符串拆分

可以将一个完整的字符串按照指定的分隔符划分为若干个子字符串。

代码示例:

实现字符串的拆分处理

String str = "hello world hello bit" ; 
String[] result = str.split(" ") ; // 按照空格拆分
for(String s: result) {System.out.println(s);
}

 

代码示例:

字符串的部分拆分

String str = "hello world hello bit" ; 
String[] result = str.split(" ",2) ; 
for(String s: result) {System.out.println(s);
}

 

拆分是特别常用的操作. 一定要重点掌握.

另外有些特殊字符作为分割符可能无法正确切分, 需要加上转义.  

代码示例:

拆分IP地址

String str = "192.168.1.1" ; 
String[] result = str.split("\\.") ; 
for(String s: result) {System.out.println(s);
}

 

代码示例:

多次拆分  

String str = "name=zhangsan&age=18" ; 
String[] result = str.split("&") ;
for (int i = 0; i < result.length; i++) {String[] temp = result[i].split("=") ; System.out.println(temp[0]+" = "+temp[1]);
}

 

1.7 字符串截取

从一个完整的字符串之中截取出部分内容。可用方法如下:

 代码示例: 

String str = "helloworld" ; 
System.out.println(str.substring(5));
System.out.println(str.substring(0, 5));

 

注意事项:

1. 索引从0开始

2. 注意前闭后开区间的写法, substring(0, 5) 表示包含0号下标的字符, 不包含5号下标

1.8 其他操作方法

代码示例:

观察trim()方法的使用

        String str = "  hello world  " ;System.out.println("["+str+"]");System.out.println("["+str.trim()+"]");

 

trim 会去掉字符串开头和结尾的空白字符(空格, 换行, 制表符等).

代码示例:

大小写转换  

        String str = "  hello%$$%@#$%world 哈哈哈 " ;System.out.println(str.toUpperCase());System.out.println(str.toLowerCase());

 

这两个函数只转换字母。

1.9 字符串的不可变性

String是一种不可变对象. 字符串中的内容是不可改变。

1. String类在设计时就是不可改变的,String类实现描述中已经说明了

被源码中final修饰

  • 1. String类被final修饰,表明该类不能被继承
  • 2. value被修饰被final修饰,表明value自身的值不能改变,即不能引用其它字符数组
  • 但是value引用空间中的内容可以修改。

 2. 所有涉及到可能修改字符串内容的操作都是创建一个新对象,改变的是新对象

比如replace方法:

【纠正】

网上有些人说:字符串不可变是因为其内部保存字符的数组被final修饰了,因此不能改变。这种说法是错误的,不是因为String类自身,或者其内部value被final修饰而不能被修改。 

final修饰类表明该类不想被继承,

final修饰引用类型表明该引用变量不能引用其他对象,但是其引用对象中的内容是可以修改的。

    public static void main(String[] args) {final int array[] = {1, 2, 3, 4, 5};array[0] = 100;System.out.println(Arrays.toString(array));}

 

我们可以看到是可以被修改的。

只是不能引用其他对象

为什么 String 要设计成不可变的?(了解)

  1. 方便实现字符串对象池. 如果 String 可变, 那么对象池就需要考虑写时拷贝的问题了.
  2. 不可变对象是线程安全的.
  3. 不可变对象更方便缓存 hash code, 作为 key 时可以更高效的保存到 HashMap 中.

1.10 字符串修改

注意:尽量避免直接对String类型对象进行修改,因为String类是不能修改的,

所有的修改都会创建新对象,效率非常低下。

public static void main(String[] args) {String s = "hello";s += " world";System.out.println(s);  // 输出:hello world
}

但是这种方式不推荐使用,因为其效率非常低,中间创建了好多临时对象。

 

在对String类进行修改时,效率是非常慢的,因此:尽量避免对String的直接修改,

如果要修改建议尽量 使用StringBuffer或者StringBuilder。  

二、StringBuilder和StringBuffer

2.1 StringBuilder的介绍

由于String的不可更改特性,为了方便字符串的修改,Java中又提供StringBuilder和StringBuffer类。这两个类大 部分功能是相同的,这里介绍 StringBuilder常用的一些方法

    public static void main(String[] args) {StringBuilder sb1 = new StringBuilder("hello");StringBuilder sb2 = sb1;// 追加:即尾插-->字符、字符串、整形数字sb1.append(' ');// hellosb1.append("world"); // hello worldsb1.append(123); // hello world123System.out.println(sb1); // hello world123System.out.println(sb1 == sb2);  // trueSystem.out.println(sb1.charAt(0));  // 获取0号位上的字符 hSystem.out.println(sb1.length()); // 获取字符串的有效长度14System.out.println(sb1.capacity()); // 获取底层数组的总大小sb1.setCharAt(0, 'H');   // 设置任意位置的字符 Hello world123sb1.insert(0, "Hello world!!!");    // Hello world!!!Hello world123System.out.println(sb1);System.out.println(sb1.indexOf("Hello")); // 获取Hello第一次出现的位置System.out.println(sb1.lastIndexOf("hello")); // 获取hello最后一次出现的位置sb1.deleteCharAt(0); // 删除首字符sb1.delete(0, 5);  // 删除[0, 5)范围内的字符String str = sb1.substring(0, 5); // 截取[0, 5)区间中的字符以String的方式返回System.out.println(str);sb1.reverse(); // 字符串逆转str = sb1.toString();  // 将StringBuffer以String的方式返回System.out.println(str);}

String和StringBuilder最大的区别在于String的内容无法修改,而StringBuilder的内容可 以修改。频繁修改字符串的情况考虑使用StringBuilder。 

 注意:

String和StringBuilder类不能直接转换。

如果要想互相转换,可以采用如下原则:

  • String变为StringBuilder: 利用StringBuilder的构造方法或append()方法
  • StringBuilder变为String: 调用toString()方法。

 面试题:

1.String、StringBuff和StringBulider之间的区别

  •  String的内容不可修改,StringBuffer与StringBuilder的内容可以修改.
  • StringBuffer与StringBuilder大部分功能是相似的
  • StringBuffer采用同步处理,属于线程安全操作;而StringBuilder未采用同步处理,属于线程不安全操作

2. 以下总共创建了多少个String对象【前提不考虑常量池之前是否存在】

String str = new String("ab");
  1. "ab":一个 String 对象存储在常量池中。
  2. new String("ab"):一个新的 String 对象在堆中。

总共:2 个对象

 

String str = new String("a") + new String("b");

这行代码的解析较为复杂,因为涉及到字符串连接操作。

  1. "a":一个 String 对象存储在常量池中。
  2. "b":一个 String 对象存储在常量池中。
  3. new String("a"):一个新的 String 对象在堆中。
  4. new String("b"):一个新的 String 对象在堆中。
  5. 字符串连接的结果:连接操作会创建一个新的 String 对象在堆中,结果为 "ab"

总共:5 个对象

 三、 String类编程题练习(leetcode)

1.字符串相加

class Solution {public String addStrings(String num1, String num2) {int i = num1.length() - 1, j = num2.length() - 1, add = 0;StringBuffer ans = new StringBuffer();while (i >= 0 || j >= 0 || add != 0) {int x = i >= 0 ? num1.charAt(i) - '0' : 0;int y = j >= 0 ? num2.charAt(j) - '0' : 0;int result = x + y + add;ans.append(result % 10);add = result / 10;i--;j--;}// 计算完以后的答案需要翻转过来ans.reverse();return ans.toString();}
}作者:力扣官方题解
链接:https://leetcode.cn/problems/add-strings/solutions/357938/zi-fu-chuan-xiang-jia-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 将两个字符串表示的非负整数相加,并返回它们的和。
  • 首先令i和j分别为字符串num1和num2的最后一个字符。
  • 新建一个ans字符串。用于构建结果字符串。
  • 循环处理每一位。当i和j非负或者add不为0.那么x和y就分别取num1和num2当前位的数字,如果超出范围则取0。result是当前位的和包括进位。result%10是当前位的数字放进ans中。更新add为result/10就是新的位。移动指针i和j减减
  • 反转结果并返回,由于结果是从低位到高位追加的,需要反转。将 StringBuffer 转换为字符串并返回。

2.字符串中第一个唯一字符 

class Solution {public int firstUniqChar(String s) {Map<Character, Integer> frequency = new HashMap<Character, Integer>();for (int i = 0; i < s.length(); ++i) {char ch = s.charAt(i);frequency.put(ch, frequency.getOrDefault(ch, 0) + 1);}for (int i = 0; i < s.length(); ++i) {if (frequency.get(s.charAt(i)) == 1) {return i;}}return -1;}
}
  • 创建一个 HashMap 变量 frequency 用于存储每个字符的出现次数。
  • 遍历字符串,统计字符出现次数
  • 再次遍历字符串,找到第一个唯一字符 

自己用String写的

class Solution {public int firstUniqChar(String s) {int[] count = new int[256];// 统计每个字符出现的次数for (int i = 0; i < s.length(); ++i) {count[s.charAt(i)]++;}// 找第一个只出现一次的字符for (int i = 0; i < s.length(); ++i) {if (1 == count[s.charAt(i)]) {return i;}}return -1;}
}
  • 首先创建一个整型数组。其实就是哈希表
  • 遍历字符串中的每一个字符。并且每出现一次这个字母将字母对应的ascii码值在哈希表中+1
  • 最后再次遍历这个字符串中的每一个字符。找到第一个在哈希表是1的字符。返回对应的下标。得到答案

3.最后一个单词的长度 

    public static void main(String[] args) {Scanner sc = new Scanner(System.in);// 获取一行单词String s = sc.nextLine();// 1. 找到最后一个空格// 2. 获取最后一个单词:从最后一个空格+1位置开始,一直截取到末尾// 3. 打印最后一个单词长度int len = s.substring(s.lastIndexOf(' ') + 1, s.length()).length();System.out.println(len);}
  •  首先获取到这一个字符串。
  • 使用
  • s.substring(s.lastIndexOf(' ') + 1, s.length()).length()
  • 截取字符串最后一个空格后面的字符串。
  • 再计算这串字符串的长度。得到答案。

 4.验证回文串

class Solution {public boolean isPalindrome(String s) {StringBuffer sgood = new StringBuffer();int length = s.length();for (int i = 0; i < length; i++) {char ch = s.charAt(i);if (Character.isLetterOrDigit(ch)) {sgood.append(Character.toLowerCase(ch));}}StringBuffer sgood_rev = new StringBuffer(sgood).reverse();return sgood.toString().equals(sgood_rev.toString());}
}
  •  创建一个 StringBuffer 来存储经过处理后的字符串
  • 用length获取字符串长度。
  • 通过循环遍历每一个字符,如果这个字符是字母或者数字,则添加到sgood字符串中
  • 最后通过StringBuffer翻转这个字符串。如果两者相等那么他就是回文串。
    public static boolean isValidChar(char ch) {if ((ch >= 'a' && ch <= 'z') ||(ch >= '0' && ch <= '9')) {return true;}return false;}public boolean isPalindrome(String s) {s = s.toLowerCase();int left = 0, right = s.length() - 1;while (left < right) {// 1. 从左侧找到一个有效的字符while (left < right && !isValidChar(s.charAt(left))) {left++;}// 2. 从右侧找一个有效的字符while (left < right && !isValidChar(s.charAt(right))) {right--;}if (s.charAt(left) != s.charAt(right)) {return false;} else {left++;right--;}}return true;}
  • 先判断是否是合法的字符,是否只包含字母和数字,如果是返回true,不是返回false
  • 再验证是否是回文串。将所有字母全部转换成小写。
  • 通过双指针循环,left从左边开始,right从右边开始循环。
  • 从左边找到第一个有效字符,从右边找到第一个有效字符
  • 再比较两个字符是否相等,如果不相等返回false,如果相等left++,right++。继续判断
  • 直到left不小于right
  • 最终返回true。 

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

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

相关文章

Activiti7实战

Activiti7与SpringBoot 整合开发 介绍 流程定义如下&#xff1a; 流程如下&#xff1a;申请人提出请假申请后&#xff0c;上级领导看到进行审批&#xff0c;如果时间超过三天&#xff0c;需要校长复审&#xff0c;三天之内直接人事存档。 进入开发工作&#xff0c;具体步骤如…

【数据结构】:时间和空间复杂度在这篇里面一点都不复杂

目录 如何衡量一个代码的好坏 时间复杂度 概念 计算方法 实例计算 【实例1】 【实例2】 【实例3】 【实例4】&#xff1a;冒泡排序的时间复杂度 【实例5】&#xff1a;二分查找的时间复杂度 【实例6】&#xff1a;阶乘递归的时间复杂度 【实例7】&#xff1a;斐波那契…

独立游戏《星尘异变》UE5 C++程序开发日志5——实现物流系统

目录 一、进出口清单 二、路径计算 三、包裹 1.包裹的数据结构 2.包裹在场景中的运动 四、道路 1.道路的数据结构 2.道路的建造 3.道路的销毁 4.某个有道路连接的建筑被删除 作为一个工厂类模拟经营游戏&#xff0c;各个工厂之间的运输必不可少&#xff0c;本游戏采用的…

SQLite数据库在Android中的使用

目录 一&#xff0c;SQLite简介 二&#xff0c;SQLIte在Android中的使用 1&#xff0c;打开或者创建数据库 2&#xff0c;创建表 3&#xff0c;插入数据 4&#xff0c;删除数据 5&#xff0c;修改数据 6&#xff0c;查询数据 三&#xff0c;SQLiteOpenHelper类 四&…

学习008-02-01-05 Configure a One-to-Many Relationship(配置一对多关系)

Configure a One-to-Many Relationship&#xff08;配置一对多关系&#xff09; This lesson explains how to create a One-to-Many relationship between two entities and how XAF generates the UI for such a relationship. 本课介绍如何在两个实体之间创建一对多关系以及…

nginx高可用实例

什么是nginx高可用 为什么需要高可用 正常情况下使用nginx&#xff0c;浏览器访问网址到nginx服务器&#xff0c;nginx再发送到目标服务器&#xff0c;获取资源返回。 但是会有一个问题&#xff1a;当nginx进程发生宕机&#xff0c;此时目标服务器存在&#xff0c;但是浏览器访…

Vue入门之v-for、computed、生命周期和模板引用

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

Linux系统下U-Boot基本操作——UBoot基础知识

个人名片&#xff1a; &#x1f393;作者简介&#xff1a;嵌入式领域优质创作者&#x1f310;个人主页&#xff1a;妄北y &#x1f4de;个人QQ&#xff1a;2061314755 &#x1f48c;个人邮箱&#xff1a;[mailto:2061314755qq.com] &#x1f4f1;个人微信&#xff1a;Vir2025WB…

React基础学习-Day08

React基础学习-Day08 React生命周期&#xff08;旧&#xff09;&#xff08;新&#xff09;&#xff08;函数组件&#xff09; &#xff08;旧&#xff09; 在 React 16 版本之前&#xff0c;React 使用了一套不同的生命周期方法。这些生命周期方法在 React 16 中仍然可以使用…

django报错(二):NotSupportedError:MySQL 8 or later is required (found 5.7.43)

执行python manage.py runserver命令时报版本不支持错误&#xff0c;显示“MySQL 8 or later is required (found 5.7.43)”。如图&#xff1a; 即要MySQL 8或更高版本。但是企业大所数用的还是mysql5.7相关版本。因为5.7之后的8.x版本是付费版本&#xff0c;贸然更新数据库肯定…

RK3562 NPU开发环境搭建

如何在Ubuntu系统&#xff08;PC&#xff09;上搭建RK3562 Buildroot Linux的NPU开发环境&#xff1f;即电脑端运行Ubuntu系统&#xff0c;而RK3562板卡运行Buildroot Linux系统的情况下&#xff0c;搭建RK3562 NPU开发环境。 下面是相应的步骤&#xff08;对应的命令&#xf…

DICOM CT\MR片子免费在线查看工具;python pydicom包加载查看;mayavi 3d查看

DICOM CT\MR片子免费在线查看工具 参考&#xff1a; https://zhuanlan.zhihu.com/p/668804209 dicom格式&#xff1a; DICOM&#xff08;Digital Imaging and Communications in Medicine&#xff09;是医学数字成像和通信的标准。它定义了医学图像&#xff08;如CT、MRI、X…

蓝桥 双周赛算法赛【小白场】

博客主页&#xff1a;誓则盟约系列专栏&#xff1a;IT竞赛 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 蓝桥第14场小白入门赛T1/T2/T3 题目&#xff1a; T1照常还是送分题无需多…

ChatTTS超强的真人AI语音助手下载使用教程

简介 ChatTTS是专门为对话场景设计的文本转语音模型&#xff0c;支持多人同时对话&#xff0c;适用的场景非常丰富&#xff0c;比如LLM助手对话任务&#xff0c;视频配音、声音克隆等。同时支持英文和中文两种语言。最大的模型使用了10万小时以上的中英文数据进行训练&#xf…

AI 基于病理图像分析揭示了一种不同类型的子宫内膜癌| 文献速递-基于人工智能(AI base)的医学影像研究与疾病诊断

Title 题目 AI-based histopathology image analysisreveals a distinct subset of endometrialcancers AI 基于病理图像分析揭示了一种不同类型的子宫内膜癌。 01 文献速递介绍 子宫内膜癌&#xff08;EC&#xff09;有四种分子亚型&#xff0c;具有很强的预后价值和治疗…

如何安装Visual Studio Code

Visual Studio Code&#xff08;简称 VS Code&#xff09; Visual Studio Code 是一款由微软开发的免费、开源的现代化轻量级代码编辑器。 主要特点包括&#xff1a; 跨平台&#xff1a;支持 Windows、Mac 和 Linux 等主流操作系统&#xff0c;方便开发者在不同平台上保持一…

二叉树 初阶 总结

树的基础认知 结点的度&#xff1a;一个结点含有的子树的个数称为该结点的度&#xff1b; 如上图&#xff1a;A的为6 叶结点或终端结点&#xff1a;度为0的结点称为叶结点&#xff1b; 如上图&#xff1a;B、C、H、I...等结点为叶结点 非终端结点或分支结点&#xff1a;度不为0…

采用T网络反馈电路的运算放大器(运放)反相放大器

运算放大器(运放)反相放大器电路 设计目标 输入电压ViMin输入电压ViMax输出电压VoMin输出电压VoMaxBW fp电源电压Vcc电源电压Vee-2.5mV2.5mV–2.5V2.5V5kHz5V–5V 设计说明1 该设计将输入信号 Vin 反相并应用 1000V/V 或 60dB 的信号增益。具有 T 反馈网络的反相放大器可用…

【鸿蒙学习笔记】位置设置・position・绝对定位・子组件相对父组件

官方文档&#xff1a;位置设置 目录标题 position・绝对定位・子组件相对父组件Row Text position position・绝对定位・子组件相对父组件 正→ ↓ Row Text position Entry Component struct Loc_position {State message: string Hello World;build() {Column() {Co…

【Neural signal processing and analysis zero to hero】- 1

The basics of neural signal processing course from youtube: 传送地址 Possible preprocessing steps Signal artifacts (not) to worry about doing visual based artifact rejection so that means that before you start analyzing, you can identify those data epic…