当前位置: 首页 > news >正文

JavaWeb 速通XML

目录

一、XML快速入门

        1.基本介绍 : 

        2.入门案例 : 

二、XML语法

        0.文件结构 : 

        1.文档声明 :

        2. 元素 : 

        3.属性 : 

        4.注释 : 

        5.CDATA节 : 

        PS : XML转义符 : 

三、Dom4j

        1.关于XML解析技术 : 

        2° Dom4j介绍 : 

        3.Dom4j使用 : 

            1° 获取Document对象的三种方式

            2° 代码演示

                1>准备工作(引入jar包)

                2>遍历和获取XML文件的元素

四、XML总结


一、XML快速入门

        1.基本介绍 : 

        XML 指可扩展标记语言(Extensible Markup Language)。

        XML 被设计用来传输和存储数据,能存储复杂的数据关系

        XML能干什么?

        解决程序间数据传输的问题(目前主流的传输格式是json),具有良好的可读性,可维护性。
        xml 可以作配置文件(使用最多
        eg : tomcat 服务器的 server.xml ,web.xml
        xml 可以充当小型的数据库(用的很少,因为很多程序为了安全都有自己的数据存储格式)。但是xml 文件做小型数据库,也是不错的选择,我们程序中可能用到的数据,如果放在数据库中读取不合适(因为你要增加维护数据库工作),可以考虑直接用 xml 来做小型数据库 ,而且直接读取文件显然要比读取数据库快。

        2.入门案例 : 

                在IDEA中新建一个File,以.xml作为文件后缀名
                模拟存储两个学生的信息,代码如下 : 

<?xml version="1.0" encoding="utf-8" ?>
<!--(1)<?xml version="1.0" encoding="utf-8" ?>用于说明文档信息xml : 表示文件类型是XML文件;version="1.0" : 表示通用的版本1.0,文档符合 XML1.0 规范;encoding="utf-8" : 表示文档的编码类型是UTF-8;(2)<students></students> : 此处表示root元素,可由程序员自主决定(3)<stu></stu> : 此处表示students元素的一个子元素,可以有任意多个(4)id : 此处为stu元素的属性(5)name,age,sex,score : 此处为stu元素的子元素,理论上子元素可以无限嵌套
-->
<students><stu id="1"><name>Cyan</name><age>21</age><sex>male</sex><score>423</score></stu><stu id="2"><name>Five</name><age>20</age><sex>female</sex><score>418</score></stu>
</students>

二、XML语法

        0.文件结构 : 

        1° 文档声明
        2° 元素
        3° 属性
        4° 注释
        5° CDATA 区 、特殊字符

        1.文档声明 :

        <?xml version="1.0" encoding="utf-8" ?>表示文档说明,用于说明文档信息,声明要放在 XML 文档的第一行
        xml : 表示文件类型是XML文件;
        version="1.0" : 文档符合 XML1.0 规范;
        encoding="utf-8" : 表示文档的编码类型是UTF-8(UTF-8是主流编码);

        PS : XML中注释的格式与HTML中相同

        2. 元素 : 

关于根元素——

        每个XML文档必须有且只有一个根元素。
        根元素是一个完全包括文档中其他所有元素的元素。
        根元素的起始标记要放在所有其他元素的起始标记之前;根元素的结束标记要放在所有其他元素的结束标记之后。

关于普通XML元素——

        XML 元素指 XML 文件中出现的标签,一个标签分为开始标签结束标签若一个标签没有标签体,以<age></age>为例,可以简写为<age/>
        一个标签中也可以嵌套若干子标签,并且允许有同名的元素存在;但所有标签都必须合理的嵌套,绝对不允许交叉嵌套。

关于XML元素的命名规则——

        区分大小写,eg : <P>和<p>是两个不同的标记。
        不能以数字开头。
        中间不能包含空格。
        名称中间不能包含冒号(:)。
        如果标签单词需要间隔,建议使用下划线。

                代码演示 :

<?xml version="1.0" encoding="UTF-8" ?><root>  <!-- Has one and only one root element --><bough><branch><branch/>   <!-- non-tagBody's Abbreviation --></branch></bough><Bough>    <!-- That's two different tag. --><branch><!--<3p></3p> can't be allowed<my name></my name> can't be allowed<my:name></my:name> can't be allowed;<my_name></my_name> is allowed.--></branch></Bough>
</root>

        3.属性 : 

        1° XML中属性的使用,和HTML中的类似;一个元素可以有多个属性,多个属性之间用空格分隔。区别——

        HTML中,同名的属性不会报错,而是只生效首次定义的属性;而在XML中,特定的属性名称在同一个元素标记中只能出现一次,否则直接报错"Duplicate attribute 属性名"。

        HTML中,属性值可以有&字符,&字符会影响属性的作用效果;而在XML中,属性值不能包括& 字符,否则直接报错。

        2° XML中,当属性值中含有',外部用"分隔;当属性值中含有",外部则用'分隔;即内单外双,内双外单

                代码演示 : 

<?xml version="1.0" encoding="UTF-8" ?><root><bough id="1" name="bough'1">   <!-- 属性值内有单引号,外面用双引号 --><branch color="cyan"></branch></bough><bough id="2" name='bough"1'>   <!-- 属性值内有双引号,外面用单引号 --><!--<branch color="cyan" color="pink"></branch>   //多个color不被允许--><!--<branch color="&id"></branch>                 //&id不被允许--></bough>
</root>

        4.注释 : 

        1. <!--XML中的注释与HTML中用法相同- ->
        2. 注释内容中不要出现--
        3. 不要把注释放在标记中间;错误写法 <Name <!--the name-->>TOM</Name>
        4. 注释不能嵌套;
        5. 可以在除标记以外的任何地方放注释

        5.CDATA节 : 

        若XML中有些内容不想让解析引擎执行,而是当作原始内容处理(即当做普通文本处理),可以使用 CDATA 将其包括起来,CDATA 节/元素中的所有字符都会被当作简单文本,而不是 XML 标记
        格式如下:
                <![CDATA[
                        需要保存的文本写在这儿(eg : 代码片段)
                ]]>

        PS:<![CDATA[ ]]>中可以输入任意字符(]]>除外);但不能嵌套使用。

                代码演示 : 

<?xml version="1.0" encoding="UTF-8" ?><root><code><![CDATA[<script type="text/javascript">window.onload = function () {//查找 id=language 下所有 li 节点var btn_4 = document.getElementById("btn_4");btn_4.onclick = function () {//此处缩小了dom对象的范围!var lis = document.getElementById("language").getElementsByTagName("li");alert("lis = " + lis);     //HTMLCollectionfor (var i = 0; i < lis.length; ++i) {alert("lis[" + i + "] = " + lis[i].innerText);}}}</script>]]></code>
</root>

        PS : XML转义符 : 

        对于一些单个字符,若想显示其原始样式,也可以使用转义的形式予以处理,转义字符在解析时会被解析成对应的文本。XML中的转义字符有点类似于HTML中的“字符实体”,但又有所区别。

        常见转义字符如下——

转义符对应符号
&lt;<
&gt;>
&amp;&
&quot;"
&apos'

三、Dom4j

        1.关于XML解析技术 : 

         XML解析技术是指,将XML文档映射为一棵xml dom树,之后可以通过相应的Java技术来对dom树中的元素进行增删查改。不管是HTML文件还是XML文件,都属于标记型文档,都可以通过w3c组织提供的dom技术来解析,dom就是这样一种XML解析技术

        XML DOM (XML Document Object Model) 定义了访问和操作 XML 文档的标准方法。DOM 把 XML 文档作为树结构来查看。能够通过 DOM 树来访问所有元素。可以修改或删除它们的内容,并创建新的元素。元素,它们的文本,以及它们的属性,都被认为是节点,其中,document对象表示的是整个文档(可以是 html 文档,也可以是 xml 文档)。(联系JavaScript DOM树的结构图


         XML解析技术的历史 : 

        早期 JDK 为我们提供了两种 xml 解析技术 DOM 和 Sax——
        (1)dom 解析技术是 W3C 组织制定的,而所有的编程语言都结合自身语言特点对这个解析技术进行了实现。 of course, Java 对 dom 技术解析也做了实现。
        (2)sun 公司在 JDK5 版本对 dom 解析技术进行升级,产生了SAX(Simple API for XML )SAX解析,它是以类似事件机制通过回调告诉用户当前正在解析的内容;是一行一行的读取 xml 文件进行解析的;不会创建大量的 dom 对象。 所以它在解析 xml 的时候,在性能上优于 Dom 解析。
        第三方的 XML 解析技术
        (1)jdom 在 dom 基础上进行了封装。
        (2)dom4j 又对 jdom 进行了封装,是当前主流的XML解析技术
        (3)pull主要用在 Android 手机开发,与sax非常类似,都是通过事件机制解析xml文件。

        2° Dom4j介绍 : 

        1. Dom4j 是一个简单、灵活的开放源代码的库(用于解析/处理 XML 文件)。Dom4j 是由早期开发 JDOM 的人分离出来而后独立开发的。
        2. 与 JDOM 不同的是,Dom4j 使用接口和抽象基类,虽然 Dom4j 的 API 相对要复杂一些,但它提供了比 JDOM 更好的灵活性。
        3. Dom4j 是一个非常优秀的 Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的 Dom4j
        4. 使用 Dom4j 开发,需下载 dom4j 相应的 jar 文件.

        PS:Dom4j官方API文档——dom4j 1.6.1 API。

        3.Dom4j使用 : 

            1° 获取Document对象的三种方式

        (1)读取 XML 文件,获得 document 对象(目前还在使用)
        SAXReader reader = new SAXReader(); //创建一个解析器
        Document document = reader.read(new File("src/input.xml"));//XML Document
        (2)解析 XML 形式的文本,得到 document 对象.(联系XML传输,应用场景不同
        String text = "<members></members>";
        Document document = DocumentHelper.parseText(text);
        (3)主动创建 document 对象. Document document =  DocumentHelper.createDocument(); //创建根节点        (无中生有)
        Element root = document.addElement("members")

            2° 代码演示

                1>准备工作(引入jar包)

                删去后缀,在Dom4j官网,下载jar包(版本不同不影响,XML的语法多年不变),如下图所示 :

                演示的XML文件代码如下 : 

<?xml version="1.0" encoding="UTF-8" ?><students><stu id="1"><name>Cyan</name><age>21</age><sex>male</sex><score>425</score></stu><stu id="2"><name>Kyrie</name><age>31</age><sex>male</sex><score>100</score></stu>
</students>

                2>遍历和获取XML文件的元素

                以Dom4j_Demo类为演示类,代码如下 : 

package xml;import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.jupiter.api.Test;import javax.xml.transform.sax.SAXResult;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.util.List;/*** @author : Cyan_RA9* @version : 21.0*/
public class Dom4j_Demo {/*XML dom 树的结构———document(DefaultDocument)rootElement(DefaultElement)content(ArrayList)elementData(Object[])DefaultText(line feed) or DefaultElement(stu)-->...same*///遍历XML元素@Testpublic void traverseXML() throws FileNotFoundException, DocumentException {SAXReader saxReader = new SAXReader();  //得到一个解析器!Document document = saxReader.read(new FileInputStream("src/xml/dom4j_test.xml"));//1.先得到根结点Element rootElement = document.getRootElement();//2.得到根结点下的student元素List<Element> stus = rootElement.elements("stu");System.out.println("dom树中student元素的个数 = " + stus.size());for (Element stu : stus) {//3.注意区别elements方法和element方法的区别Element name = stu.element("name");Element age = stu.element("age");Element sex = stu.element("sex");Element score = stu.element("score");System.out.println(("stu's info = " + name.getText() + "  " + age.getText() + "  " +sex.getText() + "  " + score.getText()));}}//获取XML指定元素/结点@Testpublic void readSpecificOne() throws DocumentException, FileNotFoundException {//得到一个解析器对象SAXReader saxReader = new SAXReader();//加载xml文件Document document = saxReader.read(new FileInputStream("src\\xml\\dom4j_test.xml"));//1.获取dom树的根结点Element rootElement = document.getRootElement();//2.获取stu对象的集合List<Element> stus = rootElement.elements("stu");//3.根据下标来获取指定的元素Element stu2 = (Element) stus.get(1);//4.attributeValue方法,可以获取元素的属性(同名属性是唯一的)System.out.println("stu2's id = " + stu2.attributeValue("id"));System.out.println((stu2.element("name").getText() + "  " + stu2.element("age").getText() +"  " + stu2.element("sex").getText() + "  " + stu2.element("score").getText()));}
}

                运行结果 : 


四、XML总结

        XML是一种可扩展的标记语言,其扩展性灵活性都达到了相当高度,目前XML最主流的使用就是作为配置文件。

        XML文档最基本的结构是文档声明,元素, 属性, 注释, 也可能有CDATA元素,五部分。每部分的语法格式要熟悉。

        对于Dom4j,熟悉Dom4j的xml dom树的结构,掌握最基本的Dom4j对XML元素的获取。

        System.out.println("END----------------------------------------------------------------------------"); 

相关文章:

JavaWeb 速通XML

目录 一、XML快速入门 1.基本介绍 : 2.入门案例 : 二、XML语法 0.文件结构 : 1.文档声明 &#xff1a; 2. 元素 : 3.属性 : 4.注释 : 5.CDATA节 : PS : XML转义符 : 三、Dom4j 1.关于XML解析技术 : 2 Dom4j介绍 : 3.Dom4j使用 : 1 获取Document对象的三种方式 2 …...

redis浅析

一 什么是NoSQL&#xff1f; Nosql not only sql&#xff08;不仅仅是SQL&#xff09; 关系型数据库&#xff1a;列行&#xff0c;同一个表下数据的结构是一样的。 非关系型数据库&#xff1a;数据存储没有固定的格式&#xff0c;并且可以进行横向扩展。 NoSQL泛指非关系…...

四种缓存的避坑总结

背景 分布式、缓存、异步和多线程被称为互联网开发的四大法宝。今天我总结一下项目开发中常接触的四种缓存实际项目中遇到过的问题。 JVM堆内缓存 JVM堆内缓存因为可以避免memcache、redis等集中式缓存网络通信故障问题&#xff0c;目前还在项目中广泛使用。 堆内缓存需要注…...

flutter开发实战-flutter二维码条形码扫一扫功能实现

flutter开发实战-flutter二维码条形码扫一扫功能实现 flutter开发实战-flutter二维码扫一扫功能实现&#xff0c;要使用到摄像头的原生的功能&#xff0c;使用的是插件&#xff1a;scan 效果图如下 一、扫一扫插件scan # 扫一扫scan: ^1.6.01.1 iOS权限设置 <key>NSCa…...

一篇文章了解Redis分布式锁

Redis分布式锁 什么是分布式锁&#xff1f; ​ redis分布式锁是一种基于redis实现的锁机制&#xff0c;它用于在多并发分布式环境下控制并发访问共享资源。在多个应用程序或是进程访问共享资源时&#xff0c;分布式锁可以确保只有一个进程可以访问该资源&#xff0c;不会发生…...

记录第一次组装电脑遇到的坑

京东装机大师配置清单如下&#xff1a; 主板cpu安装 本次安装拆了两次主板 原因1.主板侧面有个金属板需要从内部安装 2.cpu风扇有个板需要装在主板底下 显卡比较大个要最后装&#xff0c;要不然可能要拆好几次 装系统时候 u盘启动认不出来&#xff0c;他妈的是因为机箱上的usb…...

右键pdf文件没有打印

问题描述 右键点pdf文件&#xff0c;弹出的菜单找不到打印选项。网上找了很多办法&#xff0c;然并卵啊。还是得靠自己慢慢摸索。 原因分析 新安装的win11系统&#xff0c;pdf文件默认可以用windows自带的edge浏览器打开。但是edge浏览器没有能力提供右键打印功能。 解决办法…...

什么是CDN?CDN的原理和作用是什么?

一&#xff1a;什么是CDN CDN全称Content Delivery Network&#xff0c;即内容分发网络。 CDN是Content Delivery Network&#xff08;内容分发网络&#xff09;的缩写&#xff0c;是一种利用分布式节点技术&#xff0c;在全球部署服务器&#xff0c;即时地将网站、应用、视频…...

链路传播(Propagate)机制及使用场景

服务间链路追踪传播机制是指在微服务架构中&#xff0c;通过记录和跟踪服务之间的请求和响应信息&#xff0c;来实现对服务间链路的追踪和监控。这种机制可以帮助开发人员快速定位服务间出现的问题&#xff0c;并进行优化和调整。 具体来说&#xff0c;服务间链路追踪传播机制…...

pytorch技巧总结1:学习率调整方法

pytorch技巧总结1&#xff1a;学习率调整方法 前言 ​ 这个系列&#xff0c;我会把一些我觉得有用、有趣的关于pytorch的小技巧进行总结&#xff0c;希望可以帮助到有需要的朋友。 免责申明 ​ 本人水平有限&#xff0c;若有误写、漏写&#xff0c;请大家温柔的批评指正。 目录…...

谈谈VPN是什么、类型、使用场景、工作原理

作者&#xff1a;Insist-- 个人主页&#xff1a;insist--个人主页 作者会持续更新网络知识和python基础知识&#xff0c;期待你的关注 前言 本文将讲解VPN是什么、以及它的类型、使用场景、工作原理。 目录 一、VPN是什么&#xff1f; 二、VPN的类型 1、站点对站点VPN 2、…...

windows 下载安装Redis,并配置开机自启动

windows 下载安装Redis&#xff0c;并配置开机自启动 1. 下载 地址&#xff1a;https://github.com/tporadowski/redis/releases Redis 支持 32 位和 64 位。这个需要根据你系统平台的实际情况选择&#xff0c;这里我们下载 Redis-x64-xxx.zip压缩包&#xff0c;之后解压 打…...

2. CSS3的新特性

2.1CSS3的现状 ●新增的CSS3特性有兼容性问题, ie9才支持 ●移动端支持优于PC端 ●不断改进中 ●应用相对广泛 ●现阶段主要学习: 新增选择器和盒子模型以及其他特性 CSS3给我们新增了选择器,可以更加便捷,更加自由的选择目标元素&#xff1a; 1.属性选择器 2.结构伪类选择器…...

从零开始训练神经网络

用Keras实现一个简单神经网络 Keras&#xff1a; Keras是由纯python编写的基于theano/tensorflow的深度学习框架。 Keras是一个高层神经网络API&#xff0c;支持快速实验&#xff0c;能够把你的idea迅速转换为结果&#xff0c;如果有如下需 求&#xff0c;可以优先选择Keras&a…...

连接区块链节点的 JavaScript 库 web3.js

文章目录 前言web3.js 介绍web3.js安装web3.js库模块介绍连接区块链节点向区块链网络发送数据查询区块链网络数据 前言 通过前面的文章我们可以知道基于区块链开发一个DApp&#xff0c;而DApp结合了智能合约和用户界面&#xff08;客户端&#xff09;&#xff0c;那客户端是如…...

js:scroll平滑滚动页面或元素到顶部或底部的方案汇总

目录 1、CSS的scroll-behavior2、Element.scrollTop3、Element.scroll()/Window.scroll()4、Element.scrollBy()/Window.scrollBy()5、Element.scrollTo()/Window.scrollTo()6、Element.scrollIntoView()7、自定义兼容性方案8、参考文章 准备知识&#xff1a; scrollWidth: 是…...

【Docker】Docker的部署含服务和应用、多租环境、Linux内核的详细介绍

前言 Docker 是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。 &#x1f4d5;作者简介&#xff1a;热…...

C国演义 [第五章]

第五章 子集题目理解步骤树形结构递归函数递归结束的条件单层逻辑 代码 子集II题目理解步骤树形结构递归函数递归结束的条件单层逻辑 代码 子集 力扣链接 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的子集&#xff08;幂集&#xff09;。…...

Proxy-Reflect使用详解

1 监听对象的操作 2 Proxy类基本使用 3 Proxy常见捕获器 4 Reflect介绍和作用 5 Reflect的基本使用 6 Reflect的receiver Proxy-监听对象属性的操作(ES5) 通过es5的defineProperty来给对象中的某个参数添加修改和获取时的响应式。 单独设置defineProperty是只能一次设置一…...

【Linux后端服务器开发】Shell外壳——命令行解释器

目录 一、Shell外壳概述 二、描述Shell外壳原理的生动例子 三、C语言模拟实现Shell外壳 一、Shell外壳概述 在狭义上 , 我们称Linux操作系统的内核为 Linux 在广义上 , Linux发行版 Linux内核 外壳程序 就比如市面上现在的redhat, centos, ubuntu等等我们耳熟能详的Linux发…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

RocketMQ延迟消息机制

两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数&#xff0c;对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后&#xf…...

Java 语言特性(面试系列1)

一、面向对象编程 1. 封装&#xff08;Encapsulation&#xff09; 定义&#xff1a;将数据&#xff08;属性&#xff09;和操作数据的方法绑定在一起&#xff0c;通过访问控制符&#xff08;private、protected、public&#xff09;隐藏内部实现细节。示例&#xff1a; public …...

Java线上CPU飙高问题排查全指南

一、引言 在Java应用的线上运行环境中&#xff0c;CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时&#xff0c;通常会导致应用响应缓慢&#xff0c;甚至服务不可用&#xff0c;严重影响用户体验和业务运行。因此&#xff0c;掌握一套科学有效的CPU飙高问题排查方法&…...

初探Service服务发现机制

1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能&#xff1a;服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源&#xf…...

基于SpringBoot在线拍卖系统的设计和实现

摘 要 随着社会的发展&#xff0c;社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统&#xff0c;主要的模块包括管理员&#xff1b;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...

Go语言多线程问题

打印零与奇偶数&#xff08;leetcode 1116&#xff09; 方法1&#xff1a;使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...

android13 app的触摸问题定位分析流程

一、知识点 一般来说,触摸问题都是app层面出问题,我们可以在ViewRootImpl.java添加log的方式定位;如果是touchableRegion的计算问题,就会相对比较麻烦了,需要通过adb shell dumpsys input > input.log指令,且通过打印堆栈的方式,逐步定位问题,并找到修改方案。 问题…...

【前端异常】JavaScript错误处理:分析 Uncaught (in promise) error

在前端开发中&#xff0c;JavaScript 异常是不可避免的。随着现代前端应用越来越多地使用异步操作&#xff08;如 Promise、async/await 等&#xff09;&#xff0c;开发者常常会遇到 Uncaught (in promise) error 错误。这个错误是由于未正确处理 Promise 的拒绝&#xff08;r…...

Python的__call__ 方法

在 Python 中&#xff0c;__call__ 是一个特殊的魔术方法&#xff08;magic method&#xff09;&#xff0c;它允许一个类的实例像函数一样被调用。当你在一个对象后面加上 () 并执行时&#xff08;例如 obj()&#xff09;&#xff0c;Python 会自动调用该对象的 __call__ 方法…...