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

news2025/1/15 23:48:00

Java基础系列文章

Java基础(一):语言概述

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

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

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

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

Java基础(六):数组

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

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

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

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

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

Java基础(十二):枚举类

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

Java基础(十四):包装类

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

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


目录

  • 一、构造器方法
  • 二、String与字节数组的转换(编码与解码)
    • 1、字符串 --> 字节数组:(编码)
    • 2、字节数组 --> 字符串:(解码)
    • 3、iso-8859-1的特殊用法
    • 4、byte数组的数字表示
  • 三、常用API
    • 1、常用方法
    • 2、查找
    • 3、字符串截取
    • 4、和字符/字符数组相关
    • 5、开头与结尾
    • 6、替换
  • 四、常见算法题
    • 1、模拟一个trim方法,去除字符串两端的空格
    • 2、将一个字符串进行反转。将字符串中指定部分进行反转。比如“ab`cdef`g”反转为”ab`fedc`g”
    • 3、获取一个字符串在另一个字符串中出现的次数。比如:获取“ ab”在 “abkkcadkabkebfkabkskab” 中出现的次数
    • 4、获取两个字符串中最大相同子串。比如:str1 = "abcwerthelloyuiodef“;str2 = "cvhellobnm"
  • 五、StringBuffer和StringBuilder
    • 1、StringBuffer与StringBuilder的理解
    • 2、StringBuilder、StringBuffer的API
    • 3、效率测试


一、构造器方法

  • public String() :初始化新创建的 String对象,以使其表示空字符序列
  • String(String original): 初始化一个新创建的 String 对象,使其表示一个与参数相同的字符序列;换句话说,新创建的字符串是该参数字符串的副本
  • public String(char[] value) :通过当前参数中的字符数组来构造新的String
  • public String(char[] value,int offset, int count) :通过字符数组的一部分来构造新的String

举例:

//字面量定义方式:字符串常量对象
String str = "hello";

//构造器定义方式:无参构造
String str1 = new String();

//构造器定义方式:创建"hello"字符串常量的副本
String str2 = new String("hello");

//构造器定义方式:通过字符数组构造
char chars[] = {'a', 'b', 'c','d','e'};     
String str3 = new String(chars); // abcde
String str4 = new String(chars,0,3); // abc

二、String与字节数组的转换(编码与解码)

1、字符串 --> 字节数组:(编码)

  • public byte[] getBytes() :使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中
  • public byte[] getBytes(String charsetName) :使用指定的字符集将此 String 编码到 byte 序列,并将结果存储到新的 byte 数组

2、字节数组 --> 字符串:(解码)

  • String(byte[]):通过使用平台的默认字符集解码指定的 byte 数组,构造一个新的 String
  • String(byte[],int offset,int length) :用指定的字节数组的一部分,即从数组起始位置offset开始取length个字节构造一个字符串对象
  • String(byte[], String charsetName ) 或 new String(byte[], int, int,String charsetName ):解码,按照指定的编码方式进行解码

举例:

byte[] b_gbk = "中".getBytes("gbk");
byte[] b_utf8 = "中".getBytes("utf-8");
byte[] b_iso88591 = "中".getBytes("iso-8859-1");
  • 将返回"中"这个汉字分别在gbk、utf-8、iso-8859-1编码下的字节数组表示
  • 此时b_gbk的长度为2,b_utf8的长度为3,b_iso88591的长度为1
  • 与getBytes()方法相反,可以通过new String(byte[], charsetName)方法用指定的字符集来还原这个"中"字,如:
String s_gbk = new String(b_gbk, "gbk");
String s_utf8 = new String(b_utf8, "utf-8");
String s_iso88591 = new String(b_iso88591, "iso-8859-1");
  • 打印出s_gbk、s_utf8、s_iso88591可以看到,s_gbk和s_utf8都是"中",而s_iso88591是一个乱码
  • 这是因为iso-8859-1的编码表中,根本就没有包含汉字
  • 因此"中".getBytes(“iso-8859-1”)得到的是"?“的字节数组表示
  • 再通过new String(b_iso88591, “iso-8858-1”)还原得到的是”?"

3、iso-8859-1的特殊用法

  • 有时候,为了让中文字符适应某些特殊要求(如http header要求其内容必须是iso-8859-1编码)
  • 可能会通过将中文字符按照字节方式来编码的情况,如:
String s_iso88591 = new String("中".getBytes("utf-8"), "iso-8859-1");
  • 得到的字符串s_iso88591实际上是三个在iso-8859-1中的字符,在将这些字符传送到目的地后,再通过相反的方式,即:
String s_utf8 = new String(s_iso88591.getBytes("iso-8859-1"), "utf-8");
  • 从而得到正确的中文汉字"中",这样就既保证了遵守协议规定,也支持了中文

4、byte数组的数字表示

byte[] b = "中".getBytes("utf-8");
for(int i=0; i<b.length; i++) {
  System.out.println(b[i]);
}

输出:

-28 
-72 
-83
  • 因为"中"的utf-8编码为三个字节,分别是E4 B8 AD
  • 以E4为例,换成二进制即为:1110 0100
    • 该二进制数将以补码存储在内存中,最高位被视为符号位
    • 因此原码是:1110 0100(补码) -> 1001 1011(反码) -> 1001 1100(原码)
    • 即-(16+8+4)=-28

三、常用API

1、常用方法

  • boolean isEmpty():字符串是否为空
  • int length():返回字符串的长度
  • String concat(xx):拼接
  • boolean equals(Object obj):比较字符串是否相等,区分大小写
  • boolean equalsIgnoreCase(Object obj):比较字符串是否相等,不区分大小写
  • int compareTo(String other):比较字符串大小,区分大小写,按照Unicode编码值比较大小
  • int compareToIgnoreCase(String other):比较字符串大小,不区分大小写
  • String toLowerCase():将字符串中大写字母转为小写
  • String toUpperCase():将字符串中小写字母转为大写
  • String trim():去掉字符串前后空白符
  • public String intern():结果在常量池中共享
@Test
public void test1(){
    String s1 = "hello";
    String s2 = "HellO";
    System.out.println(s1.equals(s2));
    System.out.println(s1.equalsIgnoreCase(s2));

    String s3 = "abcd";
    String s4 = "adef";
    System.out.println(s3.compareTo(s4));

    String s5 = "abcd";
    String s6 = "aBcd";
    System.out.println(s5.compareTo(s6));
    System.out.println(s5.compareToIgnoreCase(s6));

    String s7 = "张ab";
    String s8 = "李cd";
    System.out.println(s7.compareTo(s8));

    String s9 = " he  llo   ";
    System.out.println("****" + s9.trim() + "*****");
}

2、查找

  • boolean contains(xx):是否包含xx
  • int indexOf(xx):从前往后找当前字符串中xx,即如果有返回第一次出现的下标,要是没有返回-1
  • int indexOf(String str, int fromIndex):返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始
  • int lastIndexOf(xx):从后往前找当前字符串中xx,即如果有返回最后一次出现的下标,要是没有返回-1
  • int lastIndexOf(String str, int fromIndex):返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索
@Test
public void test2(){
    String s1 = "教育尚硅谷教育";
    System.out.println(s1.contains("硅谷")); // true

    System.out.println(s1.indexOf("教育")); // 0
    System.out.println(s1.indexOf("教育",1)); // 5

    System.out.println(s1.lastIndexOf("教育")); // 5
    System.out.println(s1.lastIndexOf("教育",4)); // 0
}

3、字符串截取

  • String substring(int beginIndex) :返回一个新的字符串,它是此字符串的从beginIndex开始截取到最后的一个子字符串
  • String substring(int beginIndex, int endIndex) :返回一个新字符串,它是此字符串从beginIndex开始截取到endIndex(不包含)的一个子字符串
@Test
public void test3(){
    String s1 = "教育尚硅谷教育";
    System.out.println(s1.substring(2)); // 尚硅谷教育
    System.out.println(s1.substring(2,5));//[2,5) // 尚硅谷
}

4、和字符/字符数组相关

  • char charAt(index):返回[index]位置的字符
  • char[] toCharArray(): 将此字符串转换为一个新的字符数组返回
  • static String valueOf(char[] data) :返回指定数组中表示该字符序列的 String
  • static String valueOf(char[] data, int offset, int count) : 返回指定数组中表示该字符序列的 String
@Test
public void test4(){
    String s1 = "教育尚硅谷教育";
    System.out.println(s1.charAt(2)); // 尚
	// valueOf和copyValueOf源码一模一样的,就是用char数组new String(char[] ch)
    String s2 = String.valueOf(new char[]{'a', 'b', 'c'}); // abc
    String s3 = String.copyValueOf(new char[]{'a', 'b', 'c'}); // abc
}

5、开头与结尾

  • boolean startsWith(xx):测试此字符串是否以指定的前缀开始
  • boolean startsWith(String prefix, int toffset):测试此字符串从指定索引开始的子字符串是否以指定前缀开始
  • boolean endsWith(xx):测试此字符串是否以指定的后缀结束
@Test
public void test5(){
    String s1 = "教育尚硅谷教育";
    System.out.println(s1.startsWith("教育a")); // false
    System.out.println(s1.startsWith("教育",5)); // true
}

6、替换

  • String replace(char oldChar, char newChar):返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的。 不支持正则
  • String replace(CharSequence target, CharSequence replacement):使用指定的字面值替换序列替换此字符串所有匹配字面值目标序列的子字符串
  • String replaceAll(String regex, String replacement):使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串
  • String replaceFirst(String regex, String replacement):使用给定的 replacement 替换此字符串匹配给定的正则表达式的第一个子字符串
@Test
public void test6(){
    String s1 = "hello";
    String s2 = s1.replace('l', 'w');
    System.out.println(s1); // hello
    System.out.println(s2); // hewwo

    String s3 = s1.replace("ll", "wwww");
    System.out.println(s3); // hewwwwo
}

四、常见算法题

1、模拟一个trim方法,去除字符串两端的空格

思路:查看字符串前缀后缀是否存在“ ”,去除后继续判断

public static String trimStr(String str) {
    while (str.startsWith(" ") || str.endsWith(" ")) {
        if (str.startsWith(" ")) {
            str = str.substring(1);
        }
        if (str.endsWith(" ")) {
            str = str.substring(0, str.length() - 1);
        }
    }
    return str;
}

2、将一个字符串进行反转。将字符串中指定部分进行反转。比如“abcdefg”反转为”abfedcg”

方法一思路:字符串转换为字符数组,从指定角标到结束角标,互换数据

public static String reversalStr(String str, int fromIndex, int toIndex) {
    char[] charArray = str.toCharArray();
    for (int i = fromIndex, j = toIndex; i < j; i++, j--) {
        char temp = charArray[i];
        charArray[i] = charArray[j];
        charArray[j] = temp;
    }
    return new String(charArray);
}

方法二思路:截取前中后三个字符串,中是需要反转的,从新拼接,拼接中字符串时候,从后开始拼接

public static String reversalStr2(String str, int fromIndex, int toIndex) {
    String strReturn = str.substring(0, fromIndex);
    for (int i = toIndex; i >= fromIndex; i--) {
        strReturn += str.charAt(i);
    }
    strReturn += str.substring(toIndex + 1);
    return strReturn;
}

3、获取一个字符串在另一个字符串中出现的次数。比如:获取“ ab”在 “abkkcadkabkebfkabkskab” 中出现的次数

思路:获取字符首次出现的角标,然后从出现的位置继续向后找

public static int getCount(String str, String subStr) {
    int count = 0;
    int index = str.indexOf(subStr);
    while (index != -1) {
        index = str.indexOf(subStr, index + subStr.length());
        count++;
    }
    return count;
}

4、获取两个字符串中最大相同子串。比如:str1 = "abcwerthelloyuiodef“;str2 = “cvhellobnm”

思路:从小字符串下手,通过不同长度截取

public static String getMaxStr(String str1, String str2) {
    for (int i = 0; i < str2.length(); i++) {
        for (int x = 0, y = str2.length() - i - x; y <= str2.length(); x++, y++) {
            String substring = str2.substring(x, y);
            if (str1.contains(substring)) {
                return substring;
            }
        }
    }
    return null;
}

五、StringBuffer和StringBuilder

  • 因为String对象是不可变对象,虽然可以共享常量对象,但是对于频繁字符串的修改和拼接操作,效率极低,空间消耗也比较高
  • 因此,JDK又在java.lang包提供了可变字符序列StringBuffer和StringBuilder类型

1、StringBuffer与StringBuilder的理解

  • java.lang.StringBuffer代表可变的字符序列,JDK1.0中声明
  • 可以对字符串内容进行增删,此时不会产生新的对象
//情况1:
String s = new String("我喜欢学习"); 
//情况2:
StringBuffer buffer = new StringBuffer("我喜欢学习"); 
buffer.append("数学"); 

在这里插入图片描述
在这里插入图片描述

  • StringBuilder 和 StringBuffer 非常类似,均代表可变的字符序列,而且提供相关功能的方法也一样
  • 区分String、StringBuffer、StringBuilder
    • String:不可变的字符序列; 底层使用char[]数组存储(JDK8.0中)
    • StringBuffer:可变的字符序列;线程安全(方法有synchronized修饰),效率低;底层使用char[]数组存储 (JDK8.0中)
    • StringBuilder:可变的字符序列; jdk1.5引入,线程不安全的,效率高;底层使用char[]数组存储(JDK8.0中)

2、StringBuilder、StringBuffer的API

StringBuilder、StringBuffer的API是完全一致的,并且很多方法与String相同

常用API

  • StringBuffer append(xx):提供了很多的append()方法,用于进行字符串追加的方式拼接
  • StringBuffer delete(int start, int end):删除[start,end)之间字符
  • StringBuffer deleteCharAt(int index):删除[index]位置字符
  • StringBuffer replace(int start, int end, String str):替换[start,end)范围的字符序列为str
  • void setCharAt(int index, char c):替换[index]位置字符
  • char charAt(int index):查找指定index位置上的字符
  • StringBuffer insert(int index, xx):在[index]位置插入xx
  • int length():返回存储的字符数据的长度
  • StringBuffer reverse():反转
@Test
public void test1(){
    StringBuilder  sBuilder = new StringBuilder();
    sBuilder.append("abc").append("123").append("def"); //方法链的调用
    System.out.println(sBuilder); 
    
    StringBuilder sBuilder = new StringBuilder("hello");
    sBuilder.insert(2, "中");
    System.out.println(sBuilder); // he中llo

    StringBuilder sBuilder1 = sBuilder.reverse();

    System.out.println("反转字符串:" + sBuilder); // oll中eh
    System.out.println("反转返回字符串:" + sBuilder1); // oll中eh

    System.out.println("反转字符串是否与返回字符串是同一个对象:" + (sBuilder == sBuilder1)); // true

    System.out.println("字符串长度:" + sBuilder.length()); //实际存储的字符的个数  // 6
}

其它API

  • int indexOf(String str):在当前字符序列中查询str的第一次出现下标
  • int indexOf(String str, int fromIndex):在当前字符序列[fromIndex,最后]中查询str的第一次出现下标
  • int lastIndexOf(String str):在当前字符序列中查询str的最后一次出现下标
  • int lastIndexOf(String str, int fromIndex):在当前字符序列[fromIndex,最后]中查询str的最后一次出现下标
  • String substring(int start):截取当前字符序列[start,最后]
  • String substring(int start, int end):截取当前字符序列[start,end)
  • String toString():返回此序列中数据的字符串表示形式
  • void setLength(int newLength) :设置当前字符序列长度为newLength

3、效率测试

测试String、StringBuffer、StringBuilder在操作数据方面的效率

@Test
public void test4() {
    //初始设置
    long startTime = 0L;
    long endTime = 0L;

    String text = "";
    StringBuffer buffer = new StringBuffer("");
    StringBuilder builder = new StringBuilder("");

    //开始对比
    startTime = System.currentTimeMillis();
    for (int i = 0; i < 20000; i++) {
        buffer.append(String.valueOf(i));
    }
    endTime = System.currentTimeMillis();
    System.out.println("StringBuffer的执行时间:" + (endTime - startTime));

    startTime = System.currentTimeMillis();
    for (int i = 0; i < 20000; i++) {
        builder.append(String.valueOf(i));
    }
    endTime = System.currentTimeMillis();
    System.out.println("StringBuilder的执行时间:" + (endTime - startTime));

    startTime = System.currentTimeMillis();
    for (int i = 0; i < 20000; i++) {
        text = text + i;
    }
    endTime = System.currentTimeMillis();
    System.out.println("String的执行时间:" + (endTime - startTime));
}

输出结果:

StringBuffer的执行时间:14
StringBuilder的执行时间:2
String的执行时间:264

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

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

相关文章

Serilog介绍

SerilogSerilogSerilog是.net 下的新兴的日志框架&#xff0c;本文这里简单的介绍一下它的用法。 首先安装Nuget包&#xff1a; Install-Package SerilogInstall-Package Serilog.Sinks.Console 其中包Serilog是Log核心库&#xff0c;Serilog.Sinks.Console是Log的控制台输出…

云安全问题及其解决方案

随着云计算技术的快速发展&#xff0c;云计算已经成为了企业和个人的首选。云计算在提高了企业的效率和降低了成本的同时&#xff0c;也带来了一系列的安全问题。本篇博客将深入讨论云安全问题&#xff0c;并提出相应的解决方案&#xff0c;以帮助企业和个人更好地保护自己的云…

【C++学习笔记】对象的特性

深拷贝与浅拷贝 浅拷贝&#xff1a;简单的赋值拷贝操作 深拷贝&#xff1a;在堆区重新申请空间&#xff0c;进行拷贝 利用编译器提供的拷贝构造函数&#xff0c;会做浅拷贝操作&#xff1b;会导致堆区的内存重复释放 ![[Pasted image 20221216213144.png]] 解决方法&#xff…

Qt/QML编程学习之心得:跨平台(一)

Qt作为Cross-platform的一种开发语言,在GUI界面设计上俘获了大批开发者。 Qt很年轻但是也不年轻,看下它创作公司的历史就知道了: › 1994: Troll Tech. First public release in 1995 › 2008: Nokia acquires Troll Tech › 2012: Digia buys Qt from Nokia › 01.05.2016:…

有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊

文章目录 一、从用户请求的Headers反爬虫二、基于用户行为反爬虫&#xff08;1&#xff09;方法1&#xff08;2&#xff09;方法2 三、动态页面的反爬虫四.总结 不知道你们在用爬虫爬数据的时候是否有发现&#xff0c;越来越多的网站都有自己的反爬机制&#xff0c;抓取数据已经…

Cloud Storage .NET Crack

Cloud Storage .NET Crack 现在包括对Microsoft SharePoint Online的支持。 用于与流行的云存储库集成的存储组件。 云存储使您可以轻松地从任何受支持的平台或开发技术集成基于云的文件存储。这些易于使用的组件可用于与流行的云存储提供商集成&#xff0c;如Amazon S3、Googl…

ESP32使用ESP-NOW协议实现一对多通信和MAC地址存储

目录 介绍ESP-NOW 协议概述在 ESP32 上配置 ESP-NOW使用 ESP-NOW 进行一对多通信在 ESP32 上存储发件人的 MAC 地址代码结论 介绍 ESP32 是一款功能强大的 Wi-Fi 和蓝牙双模模块&#xff0c;可用于使用 ESP-NOW 协议实现低功耗、高效率的一对多通信。本文将介绍如何使用ESP-NO…

【数据分析实战】基于python对酒店预订需求进行分析

文章目录 &#x1f4da;引言&#x1f4d6;数据加载以及基本观察&#x1f4d1;缺失值观察及处理&#x1f516;缺失值观察以及可视化&#x1f516;缺失值处理 &#x1f4d6;用户数据探索&#x1f4d1;什么时间预定酒店将会更经济实惠&#xff1f;&#x1f4d1;哪个月份的酒店预订…

centos8 mysql 主从复制

♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维课堂笔记,努力不一定有收获,但一定会有收获加油!一起努力,共赴美好人生! ♥️夕阳下,是最美的绽放,树高千尺,落叶归根人生不易,人间真情 目录 Linux centos8

机器学习入门实例-MNIST手写数据集-多分分类错误分析多标签分类多输出分类

多分类 随机梯度下降、随机森林和朴素贝叶斯都可以处理多分类问题&#xff0c;而logistic回归、支持向量机是严格的二分类分类器&#xff0c;但是可以用一些方法将多个二分类分类器组合在一起完成多分类任务。 1. OvR&#xff08;one-versus-the-rest、one-versus-all&#x…

webp格式怎么转换成jpg,3种常用工具方法

在日常办公中&#xff0c;我们经常需要在网上找到一些图片进行编辑。但有时候我们会遇到Webp格式的图片&#xff0c;而有些软件无法直接编辑它们。Webp是一种由谷歌开发的图像文件格式&#xff0c;它提供了有损压缩和无损压缩(可逆压缩)的功能&#xff0c;近年来&#xff0c;它…

Kafka基础篇学习笔记整理

Kafka基础篇学习笔记整理 生产者数据发送流程批量与定时发送缓冲区大小send发送消息消息可靠性发布确认机制重试机制 消息顺序性问题如何避免重试导致消息顺序错乱自定义拦截器自定义序列化器自定义分区器幂等与事务kafka实现幂等kafka实现事务事务的隔离级别使用演示 消费者重…

【状态估计】用于描述符 LTI 和 LPV 系统的分析、状态估计和故障检测的算法(Matlab代码实现)

&#x1f4a5; &#x1f4a5; &#x1f49e; &#x1f49e; 欢迎来到本博客 ❤️ ❤️ &#x1f4a5; &#x1f4a5; &#x1f3c6; 博主优势&#xff1a; &#x1f31e; &#x1f31e; &#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 …

免费文案生成器-免费文案改写神器

推荐一款高效免费自动写作软件&#xff0c;让你的写作效率飞升&#xff01; 写作&#xff0c;对于众多的从业者或学生来说都是必不可少的工作内容。然而&#xff0c;许多人在写作时遇到了各种各样的困难&#xff0c;例如缺乏灵感、引用不足、缺乏逻辑性等等。为了解决这些问题…

Linux DHCP服务

DHCP 作用 DHCP动态主机配置协议作为服务端负责集中给客户端分配各种网络地址参数(主要包括IP地址、子网掩码、广播地址、默认网关地址、DNS服务器地址) 传输协议端口 服务端 UDP 67端口 客户端 UDP 68端口 工作原理 1) 客户端广播发送DISCOVER报文寻找服务端 2) 服务端广播发…

Unity - 带耗时 begin ... end 的耗时统计的Log - TSLog

CSharp Code // jave.lin 2023/04/21 带 timespan 的日志 &#xff08;不帶 log hierarchy 结构要求&#xff0c;即&#xff1a; 不带 stack 要求&#xff09;using System; using System.Collections.Generic; using System.IO; using UnityEditor; using UnityEngine;public…

Qt 学生信息数据库管理

1 添加样式表 我们采用了样式表 通过添加Qt resources文件 添加前缀 添加文件&#xff0c;将我们的图标进行添加 2 拖动部件 用到的部件 Label 标签Pushbutton 按钮table view 视图LineEdit 输入框 3 程序编写 1 配置sql环境 在 pro文件中 添加 连接数据库跟访问数据…

Qt模型视图结构

一.模型视图介绍 1.Model/View(模型/视图结构) 视图(View)是显示和编辑数据的界面组件&#xff0c; 模型(Model)是视图和原始数据之间的接口 2.视图组件有:QListView QTreeView QTableView&#xff0c;QColumnView&#xff0c;QHeaderView 模型组件有:QStringListM…

MyBatis详解(2)

8、自定义映射resultMap 8.1、resultMap处理字段和属性的映射关系 若字段名和实体类中的属性名不一致&#xff0c;则可以通过resultMap设置自定义映射 <!--resultMap&#xff1a;设置自定义映射属性&#xff1a;id&#xff1a;表示自定义映射的唯一标识type&#xff1a;查询…

PCIE_DMA实例二:xapp1052的EDK仿真

目录 一&#xff1a;前言 二&#xff1a;前期准备 三&#xff1a;操作步骤 四&#xff1a;仿真结果 五&#xff1a;总结 一&#xff1a;前言 对于有的同学&#xff0c;想要学习基于FPGA的PCIe DMA控制器设计&#xff0c;但是手上没有合适的Xilinx开发板&#xff0c;而且xap…