Java面试题(每天10题)-------连载(32)

news2025/1/19 19:19:56

目录

设计模式篇

1、工厂方法模式(利用创建同一接口的不同实例):

2、抽象工厂模式(多个工厂)

3、单例模式(保证对象只有一个实例)

4、原型模式(对一个原型进行复制、克隆产生类似新对象) 

5、适配器模式(接口兼容) 

6、装饰模式

7、代理模式

8、外观模式 

9、桥接模式(数据库驱动桥接) 

10、组合模式(部分整体模式)

11、 享元模式(共享池、数据库连接池)

12、策略模式(多种算法封装) 

13、模板方法模式(抽象方法作为骨架,具体逻辑让子类实现)

14、观察这模式(发布-订阅模式) 

15、迭代器模式(遍历集合)

16、责任链模式(多任务形成一条链,请求在链上传递) 

17、命令模式(实现请求和执行的解耦)

18、备忘录模式(保存和回复对象状态)

19、状态模式(对象状态改变时改变其行为) 

20、访问者模式(数据接口稳定,但算法易变) 

21、中介者模式 

22、解耦器模式 (对于一些固定文法构建⼀个解释句子的解释器,如正则表达式)

23、建造者模式(创建复合对象) 

24、设计模式的六大原则 

25、JDK中的设计模式

26、spring中的设计模式


设计模式篇

1、工厂方法模式(利用创建同一接口的不同实例):

1 、普通⼯⼚模式:建⽴⼀个⼯⼚类,对实现了同⼀接⼝的⼀些类进⾏实例的创建;
public class SendFactory {

    public Sender produce(String type) {
        if ("mail".equals(type)) {
            return new MailSender();
        } else if ("sms".equals(type)) {
            return new SmsSender();
        } else {
            System.out.println("请输⼊正确的类型!");
            return null;
        }
    }
}

2、多个工厂方法模式:提供多个工厂方法,分别创建对象:

public class SendFactory {

    public Sender produceMail() {
        return new MailSender();
    }

    public Sender produceSms() {
        return new SmsSender();
    }
}

3、静态工厂方法模式:将上面的多个工厂置为静态的,不需要创建工厂实例,直接调用即可;

4、适⽤场景:凡是出现了⼤量不同种类的产品需要创建,并且具有共同的接⼝时,可以通过⼯⼚⽅法模式进⾏创建。在以上的三种模式中,第⼀种如果传⼊的字符串有误,不能正确创建对象,第三种相对于第⼆种,不需要实例化⼯⼚类,所以,⼤多数情况下,我们会选⽤第三种——静态⼯⼚⽅法模式。

2、抽象工厂模式(多个工厂)

创建多个工厂类,提高工厂的扩展性,不⽤像上⾯⼀样如果增加产品则要去修改唯⼀的⼯⼚类;

3、单例模式(保证对象只有一个实例)

1 、适⽤场景:
  1. 某些类创建⽐较频繁,对于⼀些⼤型的对象,这是⼀笔很⼤的系统开销。
  2. 省去了new操作符,降低了系统内存的使⽤频率,减轻GC压⼒。
  3. 有些类如交易所的核⼼交易引擎,控制着交易流程,如果该类可以创建多个的话,系统完全乱了。(⽐如⼀个军队出现了多个司令员同时指挥,肯定会乱成⼀团),所以只有使⽤单例模式,才能保证核⼼交易服务器独⽴控制整个流程。
2 、代码:
public class Singleton {

    /* 持有私有静态实例,防⽌被引⽤,此处赋值为null,⽬的是实现延迟加载 */
    private static Singleton instance = null;

    /* 私有构造⽅法,防⽌被实例化 */
    private Singleton() {
    }

    /* 静态⼯程⽅法,创建实例 */
    public static Singleton getInstance() {
        if (instance == null) {
            instance = new Singleton();
        }
        return instance;
    }

    /* 如果该对象被⽤于序列化,可以保证对象在序列化前后保持⼀致 */
    public Object readResolve() {
        return instance;
    }
}
3 、分类:
  1. 饿汉式:类初始化时创建单例,线程安全,适⽤于单例占内存⼩的场景,否则推荐使⽤懒汉式延迟加载;
    public class Singleton {
        private static Singleton instance = new Singleton();
    
        private Singleton() {
        }
    
        public static Singleton newInstance() {
            return instance;
        }
    }
  2. 懒汉式:需要创建单例实例的时候再创建,需要考虑线程安全(性能不太好)
    public class Singleton {
        private static Singleton instance = null;
    
        private Singleton() {
        }
    
        public static synchronized Singleton newInstance() {
            if (null == instance) {
                instance = new Singleton();
            }
            return instance;
        }
    }
  3. 双重检验锁:效率⾼; ( 解决问题:假如两个线程 A B A 执⾏了 if (instance == null) 语句,它会认为单例对象没有创建,此时线程切到 B 也执⾏了同样的语句,B 也认为单例对象没有创建,然后两个线程依次执⾏同步代码块,并分别创建了⼀个单例对象。 )
    public class Singleton {
        private static volatile Singleton instance = null;//volatile的⼀个语义是禁⽌指令重排序优化 
    
        private Singleton() {
        }
    
        public static Singleton getInstance() {
            if (instance == null) {
                synchronized (Singleton.class) {
                    if (instance == null) {//2 
                        instance = new Singleton();
                    }
                }
            }
            return instance;
        }
    }
  4.  静态内部类⽅式:可以同时保证延迟加载和线程安全。

    public class Singleton {
        private static class SingletonHolder {
            public static Singleton instance = new Singleton();
        }
    
        private Singleton() {
        }
    
        public static Singleton newInstance() {
            return SingletonHolder.instance;
        }
    }
  5. 枚举:使⽤枚举除了线程安全和防⽌反射调⽤构造器之外,还提供了⾃动序列化机制,防⽌反序列化的时候创建新的对象。
    public enum Singleton {
        instance;
    
        public void whateverMethod() {
        }
    }

4、原型模式(对一个原型进行复制、克隆产生类似新对象) 

1 、核⼼:它的核⼼是原型类 Prototype ,需要实现 Cloneable 接⼝,和重写 Object 类中的 clone ⽅法;
2 、作⽤:使⽤原型模式创建对象⽐直接 new ⼀个对象在性能上要好的多,因为 Object 类的 clone ⽅法是⼀个本地⽅法,它直接操作内存中的⼆进制流,特别是复制⼤对象时,性能的差别⾮常明显。

5、适配器模式(接口兼容) 

将某个类的接⼝转换成客户端期望的另⼀个接⼝表示,⽬的是消除由于接⼝不匹配所造成的类的兼容性问题。
1 、类的适配器模式:

2 、对象的适配器模式:

3、接⼝的适配器模式:

4 、使⽤场景:
  1. 类的适配器模式:当希望将⼀个类转换成满⾜另⼀个新接⼝的类时,可以使⽤类的适配器模式,创建⼀个新类,继承原有的类,实现新的接⼝即可。
  2. 对象的适配器模式:当希望将⼀个对象转换成满⾜另⼀个新接⼝的对象时,可以创建⼀个Wrapper类,持有原类的⼀个实例,在Wrapper类的⽅法中,调⽤实例的⽅法就⾏。
  3. 接⼝的适配器模式:当不希望实现⼀个接⼝中所有的⽅法时,可以创建⼀个抽象类Wrapper,实现所有⽅法,我们写别的类的时候,继承抽象类即可。

6、装饰模式

给对象动态增加新功能,需持有对象实例):装饰模式就是给⼀个对象增加⼀些新的功能,⽽且是动态的,要求装饰对象和被装饰对象实现同⼀个接⼝,装饰对象持有被装饰对象的实例:

 1、实例

2、使⽤场景:

  1. 需要扩展⼀个类的功能。
  2. 动态的为⼀个对象增加功能,⽽且还能动态撤销。(继承不能做到这⼀点,继承的功能是静态的,不能动态增删。)

7、代理模式

 持有被代理类的实例,进⾏操作前后控制):采⽤⼀个代理类调⽤原有的⽅法,且对产⽣的结果进⾏控制。

8、外观模式 

外观模式是为了解决类与类之间的依赖关系的,像 spring ⼀样,可以将类和类之间的关系配置到配置⽂件中,⽽外观模式就是将他们的关系放在⼀个Facade 类中,降低了类类之间的耦合度。

9、桥接模式(数据库驱动桥接) 

桥接模式就是把事物和其具体实现分开,使他们可以各⾃独⽴的变化。桥接的⽤意是:将抽象化与实现化解耦,使得⼆者可以独⽴变化,像我们常⽤的JDBC DriverManager ⼀样, JDBC 进⾏连接数据库的时候,在各个数据库之间进⾏切换,基本不需要动太多的代码,甚⾄丝毫不⽤动,原因就是JDBC 提供统⼀接⼝,每个数据库提供各⾃的实现,⽤⼀个叫做数据库驱动的程序来桥接就⾏了。

10、组合模式(部分整体模式)

组合模式有时⼜叫部分-整体模式在处理类似树形结构的问题时⽐较⽅便。

11、 享元模式(共享池、数据库连接池)

享元模式的主要⽬的是实现对象的共享,即共享池,当系统中对象多的时候可以减少内存的开销,通常与⼯⼚模式⼀起使⽤。当⼀个客户端请求时,⼯⼚需要检查当前对象池中是否有符合条件的对象,如果有,就返回已经存在的对象,如果没有,则创建⼀个新对象,如数据库连接池;

12、策略模式(多种算法封装) 

策略模式定义了⼀系列算法,并将每个算法封装起来,使他们可以相互替换,且算法的变化不会影响到使⽤算法的客户。需要设计⼀个接⼝,为⼀系列实现类提供统⼀的⽅法,多个实现类实现该接⼝:
    ICalculator cal =new Plus(); //ICalculator是统⼀接⼝,Plus是实现类(多个)
    int result = cal.calculate(exp); //jvm根据实现类不同⽽调⽤不同实现类的⽅法

13、模板方法模式(抽象方法作为骨架,具体逻辑让子类实现)

定义一个操作中算法的框架,⽽将⼀些步骤延迟到⼦类中,使得⼦类可以不改变算法的结构即可重定义该算法中的某些特定步骤。完成公共动作和特殊动作的分离。
//题⽬:排序并打印: 
abstract class AbstractSort {
/**
 * 将数组array由⼩到⼤排序
 *
 * @param array
 */
protected abstract void sort(int[]array);

public void showSortResult(int[]array){
        System.out.print("排序结果:");//打印
        }
        }

//排序
class ConcreteSort extends AbstractSort {

    @Override
    protected void sort(int[] array) {
        for (int i = 0; i < array.length - 1; i++) {
            selectSort(array, i);
        }
    }

    private void selectSort(int[] array, int index) {
        //排序的实现逻辑
    }
}

//测试
public class Client {
    public static int[] a = {10, 32, 1, 9, 5, 7, 12, 0, 4, 3}; // 预设数据数组

    public static void main(String[] args) {
        AbstractSort s = new ConcreteSort();
        s.showSortResult(a);
    }
}

14、观察这模式(发布-订阅模式) 

当⼀个对象变化时,其它依赖该对象的对象都会收到通知,并且随着变化!对象之间是⼀种⼀对多的关系。类似于邮件订阅和RSS 订阅,当你订阅了该⽂章,如果后续有更新,会及时通知你。

15、迭代器模式(遍历集合)

 迭代器模式就是顺序访问聚集中的对象。

16、责任链模式(多任务形成一条链,请求在链上传递) 

有多个对象,每个对象持有对下⼀个对象的引⽤,这样就会形成⼀条链,请求在这条链上传递,直到某⼀对象决定处理该请求。但是发出者并不清楚到底最终那个对象会处理该请求,所以,责任链模式可以实现,在隐瞒客户端的情况下,对系统进⾏动态的调整。

17、命令模式(实现请求和执行的解耦)

命令模式的⽬的就是达到命令的发出者和执⾏者之间解耦,实现请求和执⾏分开,熟悉 Struts 的同学应该知道,Struts 其实就是⼀种将请求和呈现分离的技术,其中必然涉及命令模式的思想!

18、备忘录模式(保存和回复对象状态)

主要目的是保存一个对象的某个状态,以使在适当的时候恢复对象。

19、状态模式(对象状态改变时改变其行为) 

当对象的状态改变时,同时改变其⾏为。状态模式就两点:
  1. 可以通过改变状态来获得不同的⾏为。
  2. 你的好友能同时看到你的变化。

20、访问者模式(数据接口稳定,但算法易变) 

访问者模式把数据结构和作⽤于结构上的操作解耦合,使得操作集合可相对⾃由地演化。
访问者模式适⽤于数据结构相对稳定算法⼜易变化的系统。因为访问者模式使得算法操作增加变得容易。访问者模式就是⼀种分离对象数据结构与⾏为的⽅法,通过这种分离,可达到为⼀个被访问者动态添加新的操作⽽⽆需做其它的修改的效果。

21、中介者模式 

中介者模式也是⽤来降低类类之间的耦合的。如果使⽤中介者模式,只需关⼼和 Mediator 类的关系,具体类类之间的关系及调度交给Mediator 就⾏,这有点像 spring 容器的作⽤。

22、解耦器模式 (对于一些固定文法构建⼀个解释句子的解释器,如正则表达式

解释器模式⽤来做各种各样的解释器,如正则表达式等的解释器。

23、建造者模式(创建复合对象) 

⼯⼚类模式提供的是创建单个类的模式,⽽建造者模式则是将各种产品集中起来进⾏管理,⽤来创建复合对象,所谓复合对象就是指某个类具有不同的属性。

24、设计模式的六大原则 

  1. 开闭原则(Open Close Principle)
    开闭原则就是说对扩展开放,对修改关闭。在程序需要进⾏拓展的时候,不能去修改原有的代码,实现⼀个热插拔的效果。
    所以⼀句话概括就是:为了使程序的扩展性好,易于维护和升级。想要达到这样的效果,我们需要使⽤接⼝和抽象类,后⾯的具体设计中我们会提到这点。
  2. 里氏代换原则(Liskov Substitution Principle)
    里氏代换原则(Liskov Substitution Principle LSP)⾯向对象设计的基本原则之⼀。 里氏代换原则中说,任何基类可以出现的地方,子类⼀定可以出现。 LSP是继承复用的基石,只有当衍⽣类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复⽤,⽽衍⽣类也能够在基类的基础上增加新的⾏为。⾥⽒代换原则是对“开-闭”原则的补充。实现“开-闭”原则的关键步骤就是抽象化。⽽基类与⼦类的继承关系就是抽象化的具体实现,所以⾥⽒代换原则是对实现抽象化的具体步骤的规范。—— From Baidu 百科
  3. 依赖倒转原则(Dependence Inversion Principle)
    这个是开闭原则的基础,具体内容:真对接⼝编程,依赖于抽象⽽不依赖于具体。
  4. 接⼝隔离原则(Interface Segregation Principle)
    这个原则的意思是:使⽤多个隔离的接⼝,⽐使⽤单个接⼝要好。还是⼀个降低类之间的耦合度的意思,从这⼉我们看出,其实设计模式就是⼀个软件的设计思想,从⼤型软件架构出发,为了升级和维护⽅便。所以上⽂中多次出现:降低依赖,降低耦合。
  5. 迪⽶特法则(最少知道原则)(Demeter Principle)
    为什么叫最少知道原则,就是说:⼀个实体应当尽量少的与其他实体之间发⽣相互作⽤,使得系统功能模块相对独⽴。
  6. 合成复⽤原则(Composite Reuse Principle)
    原则是尽量使⽤合成/聚合的⽅式,⽽不是使⽤继承

25、JDK中的设计模式

1、单例模式

  • java.lang.Runtime#getRuntime()
  • java.awt.Desktop#getDesktop()

  • java.lang.System#getSecurityManager()

2、责任链模式

  • java.util.logging.Logger#log()
  • javax.servlet.Filter#doFilter()z

3、观察者模式

  • java.util.Observer/ java.util.Observable(很少在现实世界中使用)
  • 所有实现java.util.EventListener(因此实际上各地的Swing
  • javax.servlet.http.HttpSessionBindingListener

  • javax.servlet.http.HttpSessionAttributeListener

  • javax.faces.event.PhaseListener

26、spring中的设计模式

a. 简单⼯⼚:spring中的BeanFactory就是简单⼯⼚模式的体现,根据传⼊⼀个唯⼀的标识来获得bean对象,但是否是在传⼊参数后创建还是传⼊参数前创建这个要根据具体情况来定。

b. 单例模式:Spring下默认的bean均为singleton

c. 代理模式:为其他对象提供⼀种代理以控制对这个对象的访问。 从结构上来看和Decorator模式类似,但Proxy是控制,更像是⼀种对功能的限制,⽽Decorator是增加职责。 springProxy模式在aop中有体现,⽐如JdkDynamicAopProxy和Cglib2AopProxy。

d. 观察者模式:定义对象间的⼀种⼀对多的依赖关系,当⼀个对象的状态发⽣改变时,所有依赖于它的对象都得到通知并被⾃动更新。springObserver模式常⽤的地⽅是listener的实现。如ApplicationListener

 

今天更新的有点多,但是都是设计模式,没办法分两天更,所以多看看吧。 

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

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

相关文章

【Linux】gcc/g++ gdb 使用

目录 1&#xff0c;背景知识 2&#xff0c;gcc 如何完成 1&#xff0c;预处理(进行宏替换) 2&#xff0c;编译&#xff08;生成汇编&#xff09; 3&#xff0c;汇编&#xff08;生成机器可识别代码&#xff09; 4&#xff0c;连接&#xff08;生成可执行文件或库文件&…

Lombok超详解

目录 一、Lombok概述 二、Lombok插件安装 三、Lombok相关注解 3.1 Setter和Getter 3.2 ToString 3.3 EqualsAndHashCode&#xff0c;NonNull 3.4 NoArgsConstructor&#xff0c;RequiredArgsConstructor&#xff0c;AllArgsConstructor 3.5 Data 3.6 Builder 3.7 Log…

C++入门第七篇--STL模板--vector模拟实现

前言&#xff1a; 有了前面的string库的介绍&#xff0c;在这里我就不再介绍vector库了&#xff0c;而是直接模拟实现了。 vector库的概念和作用&#xff1a; vector库是针对于数组的数据类型的容器&#xff0c;它有点类似我们曾经实现过的顺序表&#xff0c;你完全可以按照…

C++二分算法:使数组严格递增

涉及知识点 动态规划 二分查找 题目 给你两个整数数组 arr1 和 arr2&#xff0c;返回使 arr1 严格递增所需要的最小「操作」数&#xff08;可能为 0&#xff09;。 每一步「操作」中&#xff0c;你可以分别从 arr1 和 arr2 中各选出一个索引&#xff0c;分别为 i 和 j&#…

查询附近500米的餐厅

前言 查询附近500米数据&#xff0c;第一反应是用ST_Buffer&#xff0c;但是ST_Buffer文档写了一句话&#xff0c;使用ST_DWithin效率更高。 ST_Buffer (postgis.net) ST_DWithin (postgis.net) 数据取点 我有一种坐标系4326的表ne_10m_admin_0_boundary_lines_land&#xf…

DataCamp在线学习平台

DataCamp&#xff08;https://www.datacamp.com/blog&#xff09;是一个在线学习平台&#xff0c;专注于数据科学和分析领域的教育。该平台提供丰富的课程&#xff0c;涵盖了从数据处理到机器学习和深度学习的各个方面。以下是DataCamp的主要特点&#xff1a; 互动学习&#x…

【Linux】命令expect使用详解

&#x1f984; 个人主页——&#x1f390;个人主页 &#x1f390;✨&#x1f341; &#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341; 感谢点赞和关注 &#xff0c;每天进步一点点&#xff01;加油&#xff01;&…

继电器测试负载箱的价格和性价比如何?

继电器测试负载箱是一种专门用于测试继电器性能的设备&#xff0c;它可以模拟各种负载条件&#xff0c;对继电器进行全方位的性能测试。这种设备在电力系统、自动化设备、通信设备等领域有着广泛的应用。 价格方面&#xff0c;继电器测试负载箱的价格因品牌、型号、性能等因素而…

Lobatto Quadrature-数值积分

See https://mathworld.wolfram.com/LobattoQuadrature.html

达梦数据库常用参数查询

字符集 字符是各种文字和符号的统称&#xff0c;包括各个国家文字、标点符号、表情、数字等等。 字符集 就是一系列字符的集合。字符集的种类较多&#xff0c;每个字符集可以表示的字符范围通常不同&#xff0c;就比如说有些字符集是无法表示汉字的。 常见的字符集有 ASCII、G…

系列四、本地接口(Native Interface)

一、概述 本地接口的作用是融合不同的编程语言为Java所用&#xff0c;它的初衷是融合C/C程序&#xff0c;Java诞生的时候正是C/C横行的时候&#xff0c;要想立足&#xff0c;必须要调用C/C的程序&#xff0c;于是Java就在内存中开辟了一块区域专门用于处理标记为native的代码&a…

如何使用ArcGIS Pro制作粉饰效果

在地图上&#xff0c;如果某个部分比较重要&#xff0c;直接的制图不能将其凸显出来&#xff0c;如果想要突出显示重要部分&#xff0c;可以通过粉饰效果来实现&#xff0c;这里为大家介绍一下方法&#xff0c;希望能对你有所帮助。 数据来源 本教程所使用的数据是从水经微图…

印染污水处理设备有哪些分类

印染污水处理设备有多种分类方法。根据处理方法&#xff0c;可以分为物理法、化学法、生物法等。 物理法处理设备主要包括格栅、沉淀池、过滤器等&#xff0c;利用物理分离、去除的原理&#xff0c;将污水中的悬浮物和沉淀物去除。化学法处理设备主要包括混凝和氧化等&#xf…

kaggle项目部署

目录 流程详细步骤注意事项 流程 修改模块地址打包项目上传到kaggle Datasets创建code文件&#xff0c;导入数据与项目粘贴train.py文件&#xff0c;调整超参数&#xff0c;选择GPUsave version&#xff0c;后台训练查看训练结果 详细步骤 打开kaggle网站&#xff0c;点击da…

中移链共识机制介绍

01 为什么需要共识 共识是对某事达成的共同看法&#xff0c;它是区块链的灵魂&#xff0c;对确保区块链的完整性和安全性起着至关重要的作用。在传统的集中式系统中&#xff0c;单个实体或一组实体有权验证和记录交易。然而&#xff0c;区块链中的一个核心概念是去中心化&…

linux查看资源占用情况常用命令

1. 查看 CPU 使用情况&#xff1a; top这个命令会显示系统中当前活动进程的实时信息&#xff0c;包括 CPU 使用率、内存使用率等。按 q 键退出。 2. 查看内存使用情况&#xff1a; free -m这个命令显示系统内存的使用情况&#xff0c;以兆字节&#xff08;MB&#xff09;为…

VINS-MONO代码解读----配置文件,数据结构,前端feature_tracker

跑通代码之后可以深入看代码了&#xff0c;整体代码很多&#xff0c;可先从配置文件开始看。 1. VINS-MONO配置文件理解 参考启动文件launch与参数配置文件yaml介绍 启动文件launch&#xff1a;euroc.launch 参数配置文件yaml&#xff1a;euroc_config.yaml&#xff1a;包括…

【kerberos】使用 curl 访问受 Kerberos HTTP SPNEGO 保护的 URL

前言&#xff1a; 大数据集群集成 Kerberos 后&#xff0c;很多 WEBUI 打开都会提示输入用户名和密码。由于我想获取 flink 任务的详情&#xff0c;且KNOX 并不支持Flink api&#xff0c;查看KNOX 直接的列表&#xff1a;https://docs.cloudera.com/cdp-private-cloud-base/7.…

vivado产生报告阅读分析-Report Power4

在布线后会生成“ Power Report ” &#xff08; 功耗报告 &#xff09;&#xff0c; 它基于当前器件工作条件和设计的切换率来报告功耗详情。功耗分析要求网表已完成综合或设计已完成布局布线。 • set_operating_conditions 命令用于设置工作条件。 • set_switching_ac…

想转行互联网行业,是选择网络安全还是人工智能?

随着数字时代的到来&#xff0c;网络安全和人工智能成了科技创新产业的重要组成部分。也逐渐成了大多数人心中热门的行业选择。那么该如何抉择呢&#xff1f; 首先我们来了解下人工智能的发展前景&#xff1a; 如今&#xff0c;人工智能技术无论是在核心技术方面&#xff0c…