《C++11》深入剖析正则表达式库:解锁文本处理的高效之道

news2025/1/16 21:10:15

生成卡通图片 (1).png

在现代编程领域,文本处理是一项不可或缺的任务,而正则表达式无疑是这一领域的强大利器。C++11标准库的引入,为C++开发者带来了正则表达式库,极大地丰富了C++在文本处理方面的能力。本文将全方位、多角度地深入探讨C++11正则表达式库,从基本概念到高级应用,从理论到实践,助你彻底掌握这一高效工具。

一、正则表达式的基本概念与构成要素

正则表达式,英文名为Regular Expression,简称regex,是一种用于匹配字符串中字符组合的模式。它由普通字符(例如字母和数字)以及特殊字符(元字符)组成,这些元字符赋予了正则表达式强大的模式描述能力。

(一)元字符详解

元字符是正则表达式的核心组成部分,它们具有特殊的含义,用于定义复杂的匹配规则。以下是一些常见的元字符及其功能:

  • .(点):匹配除换行符\n之外的任何单个字符。例如,正则表达式a.b可以匹配"acb"、“a2b”、"a*b"等,其中的.可以是任意字符。
  • *(星号):表示前面的字符可以出现0次或多次。比如,a*可以匹配""(空字符串)、“a”、"aa"等。
  • +(加号):表示前面的字符可以出现1次或多次。与*不同,+要求至少出现一次前面的字符。例如,a+可以匹配"a"、“aa”,但不能匹配空字符串。
  • ?(问号):表示前面的字符可以出现0次或1次,即前面的字符是可选的。如a?可以匹配"“和"a”。
  • [](方括号):用于定义一个字符类,匹配方括号内的任意一个字符。例如,[abc]可以匹配"a"、“b"或"c”;[a-z]可以匹配任意一个小写字母。
  • ()(圆括号):用于分组,将多个字符组合成一个逻辑单元,常用于捕获匹配的子串或改变运算优先级。比如,(ab)+可以匹配"ab"、"abab"等。
  • {n,m}(花括号):表示前面的字符可以出现n到m次。例如,a{2,4}可以匹配"aa"、“aaa”、“aaaa”。
  • ^(脱字符):在方括号内表示否定,匹配不在方括号内的任意字符;在正则表达式开头表示匹配字符串的开始。如[^abc]可以匹配除"a"、“b”、"c"之外的任意字符;^hello表示匹配以"hello"开头的字符串。
  • $(美元符号):表示匹配字符串的结尾。例如,world$表示匹配以"world"结尾的字符串。
  • |(竖线):表示逻辑“或”关系,用于匹配多个表达式中的任意一个。比如,a|b可以匹配"a"或"b"。

(二)转义序列

在正则表达式中,某些字符具有特殊含义,如上述元字符。当我们需要匹配这些特殊字符本身时,就需要使用转义序列。转义序列以反斜杠\开头,后跟需要转义的字符。例如,要匹配一个实际的点字符.,就需要写作\.;要匹配一个星号*,就需要写作\*

此外,正则表达式还提供了一些特殊的转义序列,用于匹配常见的字符类别:

  • \d:匹配任意一个数字,等价于[0-9]
  • \w:匹配任意一个字母或数字或下划线,等价于[a-zA-Z0-9_]
  • \s:匹配任意一个空白字符,包括空格、制表符、换行符等。
  • \D:匹配任意一个非数字字符,等价于[^0-9]
  • \W:匹配任意一个非字母数字下划线字符,等价于[^a-zA-Z0-9_]
  • \S:匹配任意一个非空白字符。

二、正则表达式的优势与应用场景

正则表达式相较于传统的字符串匹配方法,具有诸多显著优势,使其在多种场景下大放异彩。

(一)正则表达式的优势

  • 灵活性:正则表达式能够描述极其复杂的文本模式。无论是匹配简单的单词,还是复杂的电子邮件地址、URL、IP地址等格式,正则表达式都能轻松应对。例如,一个简单的正则表达式[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}就能准确匹配大多数电子邮件地址格式,而传统的字符串匹配方法则需要编写大量繁琐的代码来实现类似功能。
  • 效率:C++11正则表达式库在内部进行了诸多优化,使得匹配操作的执行速度远超普通的字符串匹配算法。它采用了高效的搜索策略和数据结构,能够快速定位和匹配目标字符串,尤其在处理大规模文本数据时,性能优势更为明显。
  • 可读性与可维护性:虽然正则表达式初看起来可能有些晦涩难懂,但一旦掌握其语法和规则,编写出的正则表达式代码往往比传统的字符串处理代码更加简洁、易读。一个精炼的正则表达式就能清晰地表达复杂的匹配逻辑,便于代码的维护和更新。而且,正则表达式在不同的编程语言和工具中具有高度的一致性,熟悉了C++中的正则表达式,就能很容易地将其应用到其他语言中,大大提高了开发效率。

(二)正则表达式的应用场景

  • 数据验证:在用户输入数据或从外部系统接收数据时,正则表达式是验证数据格式的强大工具。例如,验证用户输入的手机号码是否符合特定国家或地区的格式,如中国的手机号码通常为11位数字,以131415171819开头,就可以使用正则表达式^1[3-9]\d{9}$来进行验证;验证电子邮件地址的格式是否正确,确保其包含用户名、"@"符号、域名等必要部分,如前文提到的电子邮件地址正则表达式。
  • 数据提取:从大量文本中提取有价值的信息是正则表达式的另一大强项。比如,在日志文件中提取错误代码、时间戳、用户操作等关键信息;从网页源代码中提取标题、链接、图片地址等元素。通过精心设计的正则表达式,可以快速准确地定位并提取出所需的数据,为进一步的数据分析和处理提供便利。
  • 数据替换:在文本编辑和数据清洗过程中,正则表达式可以方便地替换字符串中的特定部分。例如,将文档中的所有"旧产品名称"替换为"新产品名称";将文本中的日期格式从"日/月/年"统一替换为"年-月-日";去除字符串中的多余空格、特殊符号等。利用正则表达式的替换功能,可以高效地完成复杂的文本替换任务,节省大量人工操作时间。

三、C++11正则表达式库的深入使用

C++11正则表达式库为开发者提供了一套完整的工具,用于定义、搜索、匹配和替换正则表达式。要使用该库,首先需要包含<regex>头文件。接下来,我们将详细介绍库中的关键类和函数,并通过丰富的示例展示其使用方法。

(一)关键类与函数

  • std::regex:这是定义正则表达式的类。通过将正则表达式字符串传递给std::regex的构造函数,可以创建一个正则表达式对象。例如,std::regex e("\\d{3}-\\d{2}-\\d{4}");定义了一个用于匹配美国社会安全号码(格式为123-45-6789)的正则表达式。
  • std::smatch:用于存储匹配结果的类。它是一个匹配结果容器,可以存储正则表达式匹配到的子串以及捕获组等内容。在进行匹配操作时,将std::smatch对象作为参数传递给相关函数,匹配成功后,就可以通过该对象获取详细的匹配信息。
  • std::regex_search:用于在字符串中搜索正则表达式匹配项的函数。它从给定的字符串开始,查找第一个与正则表达式匹配的子串,并将匹配结果存储在std::smatch对象中。如果找到匹配项,函数返回true;否则返回false。例如,std::regex_search(s, m, e)会在字符串s中搜索与正则表达式e匹配的内容,并将结果存储在m中。
  • std::regex_match:与std::regex_search类似,但它要求整个字符串必须与正则表达式匹配才算成功。如果整个字符串符合正则表达式定义的模式,函数返回true;否则返回false。这在需要验证字符串整体格式时非常有用,如验证一个字符串是否完全符合日期格式YYYY-MM-DD
  • std::regex_replace:用于在字符串中替换正则表达式匹配项的函数。它可以将匹配到的子串替换为指定的新字符串,并返回替换后的结果。例如,std::regex_replace(s, e, r)会将字符串s中所有与正则表达式e匹配的部分替换为字符串r

(二)示例详解

1. 匹配电话号码
#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "Hello, my phone number is 123-456-7890.";
    std::regex e("\\d{3}-\\d{3}-\\d{4}");  // 定义正则表达式,匹配格式为123-456-7890的电话号码
    std::smatch m;  // 用于存储匹配结果

    if (std::regex_search(s, m, e)) {
        std::cout << "Match: " << m.str() << std::endl;  // 输出匹配到的电话号码
    } else {
        std::cout << "No match" << std::endl;
    }

    return 0;
}

在这个示例中,我们定义了一个正则表达式\\d{3}-\\d{3}-\\d{4},用于匹配常见的电话号码格式,即三组数字,每组之间用短横线连接。通过std::regex_search函数在字符串s中搜索匹配项,如果找到匹配项,就将匹配结果存储在std::smatch对象m中,并输出匹配到的电话号码。

2. 提取电子邮件地址
#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "My email is john.doe@example.com.";
    std::regex e("\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{2,}\\b");  // 定义正则表达式,匹配电子邮件地址
    std::smatch m;  // 用于存储匹配结果

    if (std::regex_search(s, m, e)) {
        std::cout << "Email: " << m.str() << std::endl;  // 输出匹配到的电子邮件地址
    }

    return 0;
}

电子邮件地址的匹配相对复杂,需要考虑用户名部分的各种字符组合以及域名的结构。在这个正则表达式中,\\b表示单词边界,确保电子邮件地址是一个独立的单词;[A-Za-z0-9._%+-]+匹配用户名部分,允许出现字母、数字、点、下划线、百分号、加号和减号;@是电子邮件地址的固定分隔符;[A-Za-z0-9.-]+匹配域名部分,允许出现字母、数字、点和减号;\\.[A-Za-z]{2,}匹配顶级域名,要求至少有两个字母。通过std::regex_search函数,我们可以在字符串s中提取出符合格式的电子邮件地址。

3. 替换字符串
#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "Hello, Mr. John Doe.";
    std::regex e("Mr\\.");  // 定义正则表达式,匹配"Mr."
    std::string r = "Mr";  // 替换后的字符串

    std::string result = std::regex_replace(s, e, r);  // 替换操作
    std::cout << result << std::endl;  // 输出替换后的结果 "Hello, Mr John Doe."

    return 0;
}

在这个示例中,我们使用std::regex_replace函数将字符串s中的所有"Mr.“替换为"Mr”。正则表达式"Mr\\."中的\\.用于匹配实际的点字符,因为点在正则表达式中是元字符,需要转义。替换后的结果存储在字符串result中,并输出显示。

(三)高级应用技巧

1. 捕获组的使用

捕获组是正则表达式中一个非常强大的功能,它允许我们将匹配到的子串分组,并在后续操作中引用这些组。捕获组通过圆括号()定义,在匹配结果中可以通过组的索引来访问对应的子串。

#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "Hello, my name is John and my email is john.doe@example.com.";
    std::regex e("my name is ([A-Za-z]+) and my email is ([\\w.]+@[\\w.-]+\\.[A-Za-z]{2,})");  // 定义正则表达式,使用捕获组
    std::smatch m;  // 用于存储匹配结果

    if (std::regex_search(s, m, e)) {
        std::cout << "Name: " << m[1].str() << std::endl;  // 输出捕获组1的内容,即名字
        std::cout << "Email: " << m[2].str() << std::endl;  // 输出捕获组2的内容,即电子邮件地址
    }

    return 0;
}

在这个示例中,正则表达式"my name is ([A-Za-z]+) and my email is ([\\w.]+@[\\w.-]+\\.[A-Za-z]{2,})"中定义了两个捕获组。第一个捕获组([A-Za-z]+)用于匹配名字,第二个捕获组([\\w.]+@[\\w.-]+\\.[A-Za-z]{2,})用于匹配电子邮件地址。匹配成功后,可以通过std::smatch对象m的索引访问器m[1]m[2]分别获取名字和电子邮件地址这两个捕获组的内容。

2. 非贪婪匹配

在默认情况下,正则表达式中的量词(如*+{n,}等)都是贪婪的,它们会尽可能多地匹配字符。但在某些情况下,我们希望进行非贪婪匹配,即尽可能少地匹配字符。这可以通过在量词后面添加一个问号?来实现。

#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "<div>Hello, <span>world</span></div>";
    std::regex e("<.*?>");  // 定义正则表达式,使用非贪婪匹配
    std::smatch m;  // 用于存储匹配结果

    while (std::regex_search(s, m, e)) {
        std::cout << "Match: " << m.str() << std::endl;  // 输出匹配到的标签
        s = m.suffix().str();  // 更新字符串,继续查找下一个匹配项
    }

    return 0;
}

在这个示例中,正则表达式"<.*?>"中的.*?表示非贪婪匹配任意字符,尽可能少地匹配,直到遇到第一个闭合的尖括号>。这样,我们可以匹配到字符串中的每个单独的HTML标签,而不是贪婪地匹配整个<div>标签及其内部内容。

3. 条件替换

在使用std::regex_replace进行替换操作时,除了可以指定一个固定的替换字符串外,还可以使用格式化字符串进行条件替换。格式化字符串中可以包含特殊标记,如$&表示整个匹配的子串,$1$2等表示捕获组的内容。

#include <iostream>
#include <regex>
#include <string>

int main() {
    std::string s = "The price is $100.";
    std::regex e("\\$(\\d+)");  // 定义正则表达式,匹配价格
    std::string result = std::regex_replace(s, e, "Only $1 dollars");  // 条件替换

    std::cout << result << std::endl;  // 输出 "Only 100 dollars"

    return 0;
}

在这个示例中,正则表达式"\\$(\\d+)"匹配以美元符号开头后跟一个或多个数字的价格。在替换字符串"Only $1 dollars"中,$1表示第一个捕获组的内容,即价格数字。因此,替换后的结果是将原字符串中的价格部分替换为带有文字描述的格式。

四、性能优化与注意事项

虽然C++11正则表达式库功能强大,但在使用过程中也需要注意一些性能优化技巧和潜在的陷阱,以确保代码的高效运行和正确性。

(一)性能优化技巧

  • 预编译正则表达式:如果需要多次使用同一个正则表达式进行匹配或替换操作,建议将正则表达式预编译为std::regex对象。预编译可以避免每次使用时都重新解析正则表达式字符串,从而提高性能。例如,std::regex e("\\d+");可以被重复用于多个std::regex_searchstd::regex_replace操作。
  • 选择合适的匹配函数:根据实际需求选择std::regex_searchstd::regex_match。如果只需要在字符串中查找匹配项,而不需要整个字符串完全匹配,使用std::regex_search更为高效;如果需要验证整个字符串的格式,确保其完全符合正则表达式定义的模式,应使用std::regex_match
  • 避免过度使用捕获组:虽然捕获组功能强大,但过多的捕获组会增加匹配过程中的开销。如果不需要在后续操作中引用捕获组的内容,可以考虑使用非捕获组(在圆括号前加?:,如(?:...))来分组,这样可以提高匹配性能。
  • 合理设计正则表达式:尽量避免使用过于复杂的正则表达式,尤其是包含大量嵌套量词和捕获组的表达式,这可能导致回溯过多,严重影响性能。在设计正则表达式时,应尽量使其简洁明了,能够准确描述所需的匹配模式,同时避免不必要的复杂性。

(二)注意事项

  • 特殊字符处理:在正则表达式中,一些特殊字符(如.*+?[]()等)具有特殊含义。如果需要匹配这些特殊字符本身,必须使用反斜杠\进行转义。例如,要匹配一个实际的点字符.,需要写作\\.;要匹配一个星号*,需要写作\\*。在C++字符串中,反斜杠本身也需要转义,因此在定义正则表达式字符串时,通常需要使用双反斜杠\\来表示一个反斜杠。
  • 字符编码问题:C++11正则表达式库默认使用UTF-8编码处理字符串。如果处理的文本数据采用其他编码(如GBK、UTF-16等),在使用正则表达式之前,可能需要先将文本转换为UTF-8编码,以确保匹配结果的准确性。此外,在处理多字节字符(如中文字符)时,要注意正则表达式中字符类(如\\w\\s等)的匹配行为可能与预期不同,因为这些字符类是基于ASCII字符定义的,对于非ASCII字符的支持可能有限。
  • 匹配结果的边界问题:在使用std::regex_search进行匹配时,要注意匹配结果的边界。匹配成功后,std::smatch对象中的prefix()suffix()成员函数可以分别获取匹配项之前的前缀字符串和之后的后缀字符串。如果需要继续在剩余字符串中查找下一个匹配项,应使用suffix().str()作为新的搜索起点,而不是简单地使用原始字符串的子串。
  • 异常处理:在使用C++11正则表达式库时,可能会抛出异常,如std::regex_error。当正则表达式语法错误、匹配操作失败或其他异常情况发生时,应通过异常处理机制(如try-catch块)捕获并处理这些异常,以确保程序的健壮性和稳定性。

五、总结与展望

C++11正则表达式库为C++开发者提供了一个强大、灵活且高效的文本处理工具。通过深入理解正则表达式的基本概念、优势、应用场景以及C++11库的使用方法,我们可以在实际编程中轻松应对各种复杂的文本匹配、提取和替换任务。无论是在数据验证、数据清洗、文本分析还是其他需要处理文本的领域,正则表达式都能发挥重要作用。

然而,正则表达式并非万能的。在面对一些极端复杂的文本处理需求时,如深度语义分析、自然语言处理等,可能需要借助更专业的工具和算法。但无论如何,掌握C++11正则表达式库无疑将为我们的编程工作增添一份强大的助力,使我们能够更加高效、优雅地解决文本处理相关的问题。在未来的学习和实践中,我们可以继续探索正则表达式的更多高级技巧和优化方法,不断提升自己在文本处理领域的专业能力,为开发出更优质、高效的软件系统奠定坚实基础。

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

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

相关文章

c语言----------内存管理

内存管理 目录 一。作用域1.1 局部变量1.2 静态(static)局部变量1.3 全局变量1.4 静态(static)全局变量1.5 extern全局变量声明1.6 全局函数和静态函数1.7 总结 二。内存布局2.1 内存分区2.2 存储类型总结2.3内存操作函数1) memset()2) memcpy()3) memmove()4) memcmp() 2.4 堆…

机器学习-归一化

文章目录 一. 归一化二. 归一化的常见方法1. 最小-最大归一化 (Min-Max Normalization)2. Z-Score 归一化&#xff08;标准化&#xff09;3. MaxAbs 归一化 三. 归一化的选择四. 为什么要进行归一化1. 消除量纲差异2. 提高模型训练速度3. 增强模型的稳定性4. 保证正则化项的有效…

STC的51单片机LED点灯基于KEIL

前言&#xff1a; 该文源于回答一个朋友的问题&#xff0c;代码为该朋友上传&#xff0c;略作修改&#xff0c;在此说明问题以及解决问题的思路&#xff0c;以减少新手错误。 电路图&#xff1a; 该位朋友未上传电路图&#xff0c;说明如下&#xff1a; stc8g1k08a-sop8控制…

手撕Transformer -- Day6 -- DecoderBlock

手撕Transformer – Day6 – DecoderBlock 目录 手撕Transformer -- Day6 -- DecoderBlockTransformer 网络结构图DecoderBlock 代码Part1 库函数Part2 实现一个解码器Block&#xff0c;作为一个类Part3 测试 参考 Transformer 网络结构图 Transformer 网络结构 DecoderBlock 代…

【功能测试总结】

功能测试 1. 功能测试用例1.1 设计用例容易出现的问题 2. 如何写用例2.1 什么是好的用例2.2 测试用例设计常见方法 3. 用例分级 1. 功能测试用例 1.1 设计用例容易出现的问题 基础功能点用例覆盖不全/描述不清 描述不清 什么是正常内容&#xff0c;仅看用例能否知道该输入什么…

Mac玩Steam游戏秘籍!

Mac玩Steam游戏秘籍&#xff01; 大家好&#xff01;最近有不少朋友在用MacBook玩Steam游戏时遇到不支持mac的问题。别担心&#xff0c;我来教你如何用第三方工具Crossover来畅玩这些不支持的游戏&#xff0c;简单又实用&#xff01; 第一步&#xff1a;下载Crossover 首先&…

基于Springboot + vue实现的旅游网站

&#x1f942;(❁◡❁)您的点赞&#x1f44d;➕评论&#x1f4dd;➕收藏⭐是作者创作的最大动力&#x1f91e; &#x1f496;&#x1f4d5;&#x1f389;&#x1f525; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;欢迎留言讨论 &#x1f525;&#x1f525;&…

题解 CodeForces 430B Balls Game 栈 C/C++

题目传送门&#xff1a; Problem - B - Codeforceshttps://mirror.codeforces.com/contest/430/problem/B翻译&#xff1a; Iahub正在为国际信息学奥林匹克竞赛&#xff08;IOI&#xff09;做准备。有什么比玩一个类似祖玛的游戏更好的训练方法呢&#xff1f; 一排中有n个球…

Vue3播放视频报ReferenceError: SharedArrayBuffer is not defined

解决办法 前端本地测试vue.config.js server: {headers: {"Cross-Origin-Opener-Policy": "same-origin","Cross-Origin-Embedder-Policy": "require-corp",}, }, 后端vue.js生产环境 跨域隔离 是一种现代Web安全策略&#xff0c;…

Android BottomNavigationView不加icon使text垂直居中,完美解决。

这个问题网上千篇一律的设置iconsize为0&#xff0c;labale固定什么的&#xff0c;都没有效果。我的这个基本上所有人用都会有效果。 问题解决之前的效果&#xff1a;垂直方向&#xff0c;文本不居中&#xff0c;看着很难受 问题解决之后&#xff1a;舒服多了 其实很简单&…

微调神经机器翻译模型全流程

MBART: Multilingual Denoising Pre-training for Neural Machine Translation 模型下载 mBART 是一个基于序列到序列的去噪自编码器&#xff0c;使用 BART 目标在多种语言的大规模单语语料库上进行预训练。mBART 是首批通过去噪完整文本在多种语言上预训练序列到序列模型的方…

基于32QAM的载波同步和定时同步性能仿真,包括Costas环的gardner环

目录 1.算法仿真效果 2.算法涉及理论知识概要 3.MATLAB核心程序 4.完整算法代码文件获得 1.算法仿真效果 matlab2022a仿真结果如下&#xff08;完整代码运行后无水印&#xff09;&#xff1a; 仿真操作步骤可参考程序配套的操作视频。 2.算法涉及理论知识概要 载波同步是…

设计模式-工厂模式/抽象工厂模式

工厂模式 定义 定义一个创建对象的接口&#xff0c;让子类决定实列化哪一个类&#xff0c;工厂模式使一个类的实例化延迟到其子类&#xff1b; 工厂方法模式是简单工厂模式的延伸。在工厂方法模式中&#xff0c;核心工厂类不在负责产品的创建&#xff0c;而是将具体的创建工作…

【机器学习】零售行业的智慧升级:机器学习驱动的精准营销与库存管理

我的个人主页 我的领域&#xff1a;人工智能篇&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;&#x1f44d;点赞 收藏❤ 在当今数字化浪潮汹涌澎湃的时代&#xff0c;零售行业正站在转型升级的十字路口。市场竞争的白热化使得企业必须另辟蹊径&#xff0…

day_2_排序算法和树

文章目录 排序算法和树排序算法算法稳定性排序算法☆ 冒泡排序冒泡思路冒泡步骤代码实现效率优化 ☆ 选择排序排序思路排序步骤代码实现 ... 树01-树的基本概念02-树的相关术语03-二叉树的种类04-二叉树的存储05-树的应用场景_数据库索引06-二叉树的概念和性质07-广度优先遍历0…

蓝桥杯刷题第二天——背包问题

题目描述 有N件物品和一个容量是V的背包。每件物品只能使用一次。第i件物品的体积是Vi价值是Wi。 求解将哪些物品装入背包&#xff0c;可使这些物品的总体积不超过背包容量&#xff0c;且总价值最大。 输出最大价值。 输入格式 第一行两个整数&#xff0c;N&#xff0c;V&am…

Linux x86_64 程序动态链接之GOT 和 PLT

文章目录 前言一、动态链接二、位置无关代码三、GOT 和 PLT3.1 GOT3.2 PLT3.3 延时绑定3.4 示例 四、demo演示五、延迟绑定技术和代码修补参考资料 前言 这篇文章描述了&#xff1a;Linux x86_64 程序静态链接之重定位&#xff0c;接来本文描述Linux x86_64 程序动态链接之GOT…

学习记录-责任链模式验证参数

学习记录-责任链模式验证参数 1.什么是责任链模式 责任链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为设计模式&#xff0c;它允许将请求沿着一个处理链传递&#xff0c;直到链中的某个对象处理它。这样&#xff0c;发送者无需知道哪个对象将处理…

练习:MySQL单表查询与多表查询

一.单表查询 创建worke数据库&#xff0c;在数据库底下创建worker表 mysql> create database worke; Query OK, 1 row affected (0.00 sec)mysql> show databases; -------------------- | Database | -------------------- | information_schema | | mysql …

HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (四、最近上映电影滚动展示及加载更多的实现)

在HarmonyOS NEXT开发环境中&#xff0c;可以使用多种组件和库来构建丰富且交互友好的应用。本文将展示如何使用HarmonyOS NEXT框架和nutpi/axios库&#xff0c;从零开始实现一个简单的影视APP的首页&#xff0c;主要关注最近上映电影的滚动展示及加载更多功能的实现。 开源项目…