昆明商城网站开发蜂网站开发
2026/4/6 2:29:01 网站建设 项目流程
昆明商城网站开发,蜂网站开发,甘肃手机版建站系统信息,wordpress使用难不难1.SPI简介 SPI#xff08;Service Provicer Interface#xff09;是Java语言提供的一种接口发现机制#xff0c;用来实现接口和接口实现的解耦。简单来说#xff0c;就是系统只需要定义接口规范以及可以发现接口实现的机制#xff0c;而不需要实现接口。 SPI机制在Java中…1.SPI简介SPIService Provicer Interface是Java语言提供的一种接口发现机制用来实现接口和接口实现的解耦。简单来说就是系统只需要定义接口规范以及可以发现接口实现的机制而不需要实现接口。SPI机制在Java中应用广泛。例如JDBC中的数据库连接驱动使用SPI机制只定义了数据库连接接口的规范而具体实现由各大数据库厂商实现不同数据库的实现不同我们常用的mysql的驱动也实现了其接口规范通过这种方式JDBC数据库连接可以适配不同的数据库。SPI机制在各种框架中也有应用例如springboot的自动装配中查找spring.factories文件的步骤就是应用了SPI机制dubbo也对Java的SPI机制进行扩展实现了自己的SPI机制。2.SPI入门案例2.1.创建工程我们刚才在介绍中说过了SPI机制需要定义接口规范这里我们以一个简单的接口案例来说明。首先我们需要创建四个工程•spi-interface这里定义SPI的接口类Person•spi-impl1这里定义接口的第一个实现类Teacher•spi-impl2这里定义接口的第二个实现类Student•spi-test这里通过SPI机制加载所有实现类进行测试2.2.创建SPI接口规范接口如下所示package com.jd.spi; public interface Person { String favorite(); }2.3.创建实现类1项目2.3.1.创建接口接口如下所示package com.jd.spi; public class Teacher implements Person { public String favorite() { return 老师喜欢给学生上课; } }2.3.2.创建spi配置文件如下图所示在项目的resources文件夹下创建两个文件夹META-INF/services然后在文件夹下面创建名称为com.jd.spi.Person的文件其文件的内容为当前项目的接口实现类com.jd.spi.Teacher。2.4.创建实现类2项目2.4.1.创建实现类2接口如下所示package com.jd.spi; public class Student implements Person { public String favorite() { return 学生喜欢努力学习; } }2.4.2.创建spi配置文件如下图所示在项目的resources文件夹下创建两个文件夹META-INF/services然后在文件夹下面创建名称为com.jd.spi.Person的文件其文件的内容为当前项目的接口实现类com.jd.spi.Student。2.5.创建测试项目2.5.1.引入3个maven依赖这里需要引入接口定义项目和两个接口实现项目。如下所示dependencies dependency groupIdorg.example/groupId artifactIdspi-interface/artifactId version1.0-SNAPSHOT/version /dependency dependency groupIdorg.example/groupId artifactIdspi-impl1/artifactId version1.0-SNAPSHOT/version /dependency dependency groupIdorg.example/groupId artifactIdspi-impl2/artifactId version1.0-SNAPSHOT/version /dependency /dependencies2.5.2.创建测试类如下所示package com.jd.spi; import java.util.Iterator; import java.util.ServiceLoader; public class SPITest { public static void main(String[] args) { ServiceLoaderPerson loader ServiceLoader.load(Person.class); for(IteratorPerson it loader.iterator(); it.hasNext();){ Person person it.next(); System.out.println(person.favorite());; } } }运行测试类其结果如下所示我们发现Java的SPI机制获取了所有Person类的实现类并执行其对应的favorite方法。3.SPI机制的原理3.1.ServiceLoader的核心属性其核心机制就是ServiceLoader类的load方法下面我们将从源码来分析其原理。首先我们先看下ServiceLoader的核心属性public final class ServiceLoaderS implements IterableS { private static final String PREFIX META-INF/services/; // The class or interface representing the service being loaded private final ClassS service; // The class loader used to locate, load, and instantiate providers private final ClassLoader loader; // The access control context taken when the ServiceLoader is created private final AccessControlContext acc; // Cached providers, in instantiation order private LinkedHashMapString,S providers new LinkedHashMap(); // The current lazy-lookup iterator private LazyIterator lookupIterator;这个PREFIX属性、providers属性和lookupIterator属性将在后续的代码中使用到我们发现PREFIX属性就是示例中说的META-INF/services路径。3.2.ServiceLoader的遍历器示例中我们会获取serviceLoader的遍历器iterator其方法如下所示public IteratorS iterator() { return new IteratorS() { IteratorMap.EntryString,S knownProviders providers.entrySet().iterator(); public boolean hasNext() { if (knownProviders.hasNext()) return true; return lookupIterator.hasNext(); } public S next() { if (knownProviders.hasNext()) return knownProviders.next().getValue(); return lookupIterator.next(); } public void remove() { throw new UnsupportedOperationException(); } }; }然后需要执行遍历器的next方法获取元素其next方法执行的是lookupIterator.next()。接下来我们来看下lookupIterator的next方法public S next() { if (acc null) { return nextService(); } else { PrivilegedActionS action new PrivilegedActionS() { public S run() { return nextService(); } }; return AccessController.doPrivileged(action, acc); } }其执行的是nextService方法如下所示private S nextService() { if (!hasNextService()) throw new NoSuchElementException(); String cn nextName; nextName null; Class? c null; try { c Class.forName(cn, false, loader); } catch (ClassNotFoundException x) { fail(service, Provider cn not found); } if (!service.isAssignableFrom(c)) { fail(service, Provider cn not a subtype); } try { S p service.cast(c.newInstance()); providers.put(cn, p); return p; } catch (Throwable x) { fail(service, Provider cn could not be instantiated, x); } throw new Error(); // This cannot happen }nextService方法首先执行hasNextService方法如下所示private boolean hasNextService() { if (nextName ! null) { return true; } if (configs null) { try { String fullName PREFIX service.getName(); if (loader null) configs ClassLoader.getSystemResources(fullName); else configs loader.getResources(fullName); } catch (IOException x) { fail(service, Error locating configuration files, x); } } while ((pending null) || !pending.hasNext()) { if (!configs.hasMoreElements()) { return false; } pending parse(service, configs.nextElement()); } nextName pending.next(); return true; }这个方法会执行String fullName PREFIX service.getName()而PREFIX就是我们前面刚才说的非常重要的属性其值为META-INF/services/service就是接口类其最终的fullName指的就是META-INF/services文件夹下的名称为com.jd.spi.Person的文件。接着会执行configs loader.getResources(fullName)方法这个方法这里不做详细描述其主要功能就是获取类路径下所有相对路径为fullName的所有文件的URL对象。然后会执行pending parse(service, configs.nextElement())方法这个方法这里也不详细描述其主要功能是读取文件将文件内容变成字符串然后nextName就被赋值为当前文件的内容即实现类的接口全限定名。因此执行hasNextService()方法后nextName被赋值为一个实现类的全限定名。我们继续看上面的nextService()方法其最终会执行c Class.forName(cn, false, loader)方法这个方法很明显就是通过反射实例化一个对象。通过一系列操作最终返回了对应实现类的对象。3.3.流程总结我们将其总结为以下几个步骤1.创建ServiceLoader对象2.创建迭代器lookupIterator3.通过迭代器的hasNextService方法读取类路径下META-INF/services目录的所有名称为接口全限定名的文件将其内容存入configs对象中4.从configs对象中获取实现类的全限定名然后通过反射实例化对象从上述流程我们也可以总结实现SPI的几点重要信息1.实现工程必须在类路径下的META-INF/services目录下创建接口全限定名的文件其文件内容必须是接口实现类的全限定名2.实现类必须有一个无参构造方法因为SPI默认是使用无参构造方法实例化对象的4.总结本文首先概述了Java的SPI机制随后阐述了其基本使用方法最后深入探讨了其实现原理。SPI在Java语言体系中具有广泛应用能够有效地实现系统解耦众多框架基于此机制进行了拓展和优化从而实现了更为强大的SPI机制。掌握SPI的使用技巧可以帮助我们设计出更为灵活的系统而深入理解其原理则有助于提升我们的技术水平。Java开发的就业市场正在经历结构性调整竞争日益激烈传统纯业务开发岗位如仅完成增删改查业务的后端工程师的需求特别是入门级岗位正显著萎缩。随着企业技术需求升级市场对Java人才的要求已从通用技能转向了更深入的领域经验如云原生、微服务或前沿的AI集成能力。这也导致岗位竞争加剧在一、二线城市求职者不仅面临技术内卷还需应对学历与项目经验的高门槛。大模型为核心的AI领域正展现出前所未有的就业热度与人才红利2025年AI相关新发岗位数量同比激增543%单月增幅最高超过11倍大模型算法工程师位居热门岗位前列。行业顶尖人才的供需严重失衡议价能力极强跳槽薪资涨幅可达30%-50%。值得注意的是市场并非单纯青睐算法研究员而是急需能将大模型能力落地于复杂业务系统的工程人才。这使得具备企业级架构思维和复杂系统整合经验的Java工程师在向“Java大模型”复合人才转型时拥有独特优势成为企业竞相争夺的对象其薪资天花板也远高于传统Java岗位。说真的这两年看着身边一个个搞Java、C、前端、数据、架构的开始卷大模型挺唏嘘的。大家最开始都是写接口、搞Spring Boot、连数据库、配Redis稳稳当当过日子。结果GPT、DeepSeek火了之后整条线上的人都开始有点慌了大家都在想“我是不是要学大模型不然这饭碗还能保多久”先给出最直接的答案一定要把现有的技术和大模型结合起来而不是抛弃你们现有技术掌握AI能力的Java工程师比纯Java岗要吃香的多。即使现在裁员、降薪、团队解散的比比皆是……但后续的趋势一定是AI应用落地大模型方向才是实现职业升级、提升薪资待遇的绝佳机遇如何学习AGI大模型作为一名热心肠的互联网老兵我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。因篇幅有限仅展示部分资料需要点击下方链接即可前往获取2025最新版CSDN大礼包《AGI大模型学习资源包》免费分享**一、2025最新大模型学习路线一个明确的学习路线可以帮助新人了解从哪里开始按照什么顺序学习以及需要掌握哪些知识点。大模型领域涉及的知识点非常广泛没有明确的学习路线可能会导致新人感到迷茫不知道应该专注于哪些内容。我们把学习路线分成L1到L4四个阶段一步步带你从入门到进阶从理论到实战。L1级别:AI大模型时代的华丽登场L1阶段我们会去了解大模型的基础知识以及大模型在各个行业的应用和分析学习理解大模型的核心原理关键技术以及大模型应用场景通过理论原理结合多个项目实战从提示工程基础到提示工程进阶掌握Prompt提示工程。L2级别AI大模型RAG应用开发工程L2阶段是我们的AI大模型RAG应用开发工程我们会去学习RAG检索增强生成包括Naive RAG、Advanced-RAG以及RAG性能评估还有GraphRAG在内的多个RAG热门项目的分析。L3级别大模型Agent应用架构进阶实践L3阶段大模型Agent应用架构进阶实现我们会去学习LangChain、 LIamaIndex框架也会学习到AutoGPT、 MetaGPT等多Agent系统打造我们自己的Agent智能体同时还可以学习到包括Coze、Dify在内的可视化工具的使用。L4级别大模型微调与私有化部署L4阶段大模型的微调和私有化部署我们会更加深入的探讨Transformer架构学习大模型的微调技术利用DeepSpeed、Lamam Factory等工具快速进行模型微调并通过Ollama、vLLM等推理部署框架实现模型的快速部署。整个大模型学习路线L1主要是对大模型的理论基础、生态以及提示词他的一个学习掌握而L3 L4更多的是通过项目实战来掌握大模型的应用开发针对以上大模型的学习路线我们也整理了对应的学习视频教程和配套的学习资料。二、大模型经典PDF书籍书籍和学习文档资料是学习大模型过程中必不可少的我们精选了一系列深入探讨大模型技术的书籍和学习文档它们由领域内的顶尖专家撰写内容全面、深入、详尽为你学习大模型提供坚实的理论基础。书籍含电子版PDF三、大模型视频教程对于很多自学或者没有基础的同学来说书籍这些纯文字类的学习教材会觉得比较晦涩难以理解因此我们提供了丰富的大模型视频教程以动态、形象的方式展示技术概念帮助你更快、更轻松地掌握核心知识。四、大模型项目实战学以致用当你的理论知识积累到一定程度就需要通过项目实战在实际操作中检验和巩固你所学到的知识同时为你找工作和职业发展打下坚实的基础。五、大模型面试题面试不仅是技术的较量更需要充分的准备。在你已经掌握了大模型技术之后就需要开始准备面试我们将提供精心整理的大模型面试题库涵盖当前面试中可能遇到的各种技术问题让你在面试中游刃有余。因篇幅有限仅展示部分资料需要点击下方链接即可前往获取2025最新版CSDN大礼包《AGI大模型学习资源包》免费分享

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询