自定义建设网站wordpress有什么插件

张小明 2025/12/31 4:39:36
自定义建设网站,wordpress有什么插件,整站网站优化费用,网站建设需要掌握哪些知识目录 概念泛型的擦除泛型的类型 1.泛型类2.泛型接口3.泛型通配符4.泛型方法 1.泛型方法的基本用法2.类中的泛型方法3.泛型方法与可变参数4.静态方法与泛型5.泛型方法总结 5.泛型上下边界 概念 概念移步百度百科:java泛型 我只说一下我的理解#xff0c;使用数据类型约束主…目录概念泛型的擦除泛型的类型1.泛型类2.泛型接口3.泛型通配符4.泛型方法1.泛型方法的基本用法2.类中的泛型方法3.泛型方法与可变参数4.静态方法与泛型5.泛型方法总结5.泛型上下边界概念概念移步百度百科:java泛型我只说一下我的理解使用数据类型约束主要是为了安全性这样可以在编译期发现更多的风险并且减少代码强转。在使用的时候定义好数据类型也算是一种约束对内部的代码调用等都非常的友好。java中可以定义指定的数据类型也可以定义泛型当定义了指定的数据类型时它就仅能接收这一种数据类型所以有时候我们为了使一个类或者接口或者方法面相更多的对象时不那么乏力这个时候我们的泛型就登场了。举个栗子来比较一下数据类型和泛型明显我们可以看出泛型适用于一些灵活的场景比如excel导入导出我们不确定数据类型比如jdbc封装时我们不确定的数据类型比如一些特殊场景需要用一个类或者一个方法或者一个接口面向多种数据类型编码时。泛型的擦除什么叫泛型的擦除我们来看一个栗子这里定义了两个不同数据类型的集合一个String另一个是Integer获取两个集合的class进行对比最终结果是一致的。这里是由于泛型的特性:泛型仅在编译时有效简单的说就是会在编译时期检查你的泛型但是运行时期就已经把类型擦除两个list都变成了没有数据类型的工具相当于:List stringArrayList Lists.newArrayList();如此一来就运行时就出现了上述结果两个带有数据类型约束的类比较结果竟然是true。泛型的类型泛型的类型主要有三种泛型类、泛型接口、泛型方法。下面我们一一道来。1.泛型类泛型类的最基本写法class 类名称 泛型标识可以随便写任意标识号标识指定的泛型的类型{ private 泛型标识 /*成员变量类型*/ var; ..... } }举个栗子使用时需要注意的是:泛型的类型参数不能是简单类型否则编译会报错Type argument cannot be of primitive type;定义泛型类的时候可以不用传入类型实参。2.泛型接口泛型接口与泛型类的定义及使用基本相同。泛型接口常被用在各种类的生产器中可以看一个例子:public interface TestInterfaceT { public T getNext(); }当实现泛型接口的类未传入泛型实参时/** * 未传入泛型实参时与泛型类的定义相同在声明类的时候需将泛型的声明也一起加到类中 * 即class FruitGeneratorT implements GeneratorT{ * 如果不声明泛型如class FruitGenerator implements GeneratorT编译器会报错Unknown class */ class FruitGeneratorT implements GeneratorT{ Override public T next() { return null; } }当实现泛型接口的类传入泛型实参时/** * 传入泛型实参时 * 定义一个生产器实现这个接口,虽然我们只创建了一个泛型接口GeneratorT * 但是我们可以为T传入无数个实参形成无数种类型的Generator接口。 * 在实现类实现泛型接口时如已将泛型类型传入实参类型则所有使用泛型的地方都要替换成传入的实参类型 * 即GeneratorTpublic T next();中的的T都要替换成传入的String类型。 */ public class FruitGenerator implements GeneratorString { private String[] fruits new String[]{Apple, Banana, Pear}; Override public String next() { Random rand new Random(); return fruits[rand.nextInt(3)]; } }3.泛型通配符我们知道Ingeter是Number的一个子类同时在特性章节中我们也验证过GenericIngeter与GenericNumber实际上是相同的一种基本类型。那么问题来了在使用GenericNumber作为形参的方法中能否使用GenericIngeter的实例传入呢在逻辑上类似于GenericNumber和GenericIngeter是否可以看成具有父子关系的泛型类型呢为了弄清楚这个问题我们使用GenericT这个泛型类继续看下面的例子public void showKeyValue1(GenericNumber obj){ Log.d(泛型测试,key value is obj.getKey()); } GenericInteger gInteger new GenericInteger(123); GenericNumber gNumber new GenericNumber(456); showKeyValue(gNumber); // showKeyValue这个方法编译器会为我们报错Genericjava.lang.Integer // cannot be applied to Genericjava.lang.Number // showKeyValue(gInteger);通过提示信息我们可以看到GenericInteger不能被看作为GenericNumber的子类。由此可以看出:同一种泛型可以对应多个版本因为参数类型是不确定的不同版本的泛型类实例是不兼容的。回到上面的例子如何解决上面的问题总不能为了定义一个新的方法来处理GenericInteger类型的类这显然与java中的多台理念相违背。因此我们需要一个在逻辑上可以表示同时是GenericInteger和GenericNumber父类的引用类型。由此类型通配符应运而生。我们可以将上面的方法改一下public void showKeyValue1(Generic? obj){ Log.d(泛型测试,key value is obj.getKey()); }类型通配符一般是使用代替具体的类型实参注意了此处’’是类型实参而不是类型形参 。重要说三遍此处’’是类型实参而不是类型形参 此处’’是类型实参而不是类型形参 再直白点的意思就是此处的和Number、String、Integer一样都是一种实际的类型可以把看成所有类型的父类。是一种真实的类型。可以解决当具体类型不确定的时候这个通配符就是 ? 当操作类型时不需要使用类型的具体功能时只使用Object类中的功能。那么可以用 ? 通配符来表未知类型。4.泛型方法在java中,泛型类的定义非常简单但是泛型方法就比较复杂了尤其是我们见到的大多数泛型类中的成员方法也都使用了泛型有的甚至泛型类中也包含着泛型方法这样在初学者中非常容易将泛型方法理解错了。泛型类是在实例化类的时候指明泛型的具体类型泛型方法是在调用方法的时候指明泛型的具体类型 。注释里面标明了一个泛型方法应该怎样定义。/** * 泛型方法的基本介绍 * param tClass 传入的泛型实参 * return T 返回值为T类型 * 说明 * 1public 与 返回值中间T非常重要可以理解为声明此方法为泛型方法。 * 2只有声明了T的方法才是泛型方法泛型类中的使用了泛型的成员方法并不是泛型方法。 * 3T表明该方法将使用泛型类型T此时才可以在方法中使用泛型类型T。 * 4与泛型类的定义一样此处T可以随便写为任意标识常见的如T、E、K、V等形式的参数常用于表示泛型。 */ public T T genericMethod(ClassT tClass)throws InstantiationException , IllegalAccessException{ T instance tClass.newInstance(); return instance; }1.泛型方法的基本用法举几个栗子大家可以参照代码中的注释进行理解public class GenericTest { //这个类是个泛型类在上面已经介绍过 public class GenericT{ private T key; public Generic(T key) { this.key key; } //我想说的其实是这个虽然在方法中使用了泛型但是这并不是一个泛型方法。 //这只是类中一个普通的成员方法只不过他的返回值是在声明泛型类已经声明过的泛型。 //所以在这个方法中才可以继续使用 T 这个泛型。 public T getKey(){ return key; } /** * 这个方法显然是有问题的在编译器会给我们提示这样的错误信息cannot reslove symbol E * 因为在类的声明中并未声明泛型E所以在使用E做形参和返回值类型时编译器会无法识别。 public E setKey(E key){ this.key keu } */ } /** * 这才是一个真正的泛型方法。 * 首先在public与返回值之间的T必不可少这表明这是一个泛型方法并且声明了一个泛型T * 这个T可以出现在这个泛型方法的任意位置. * 泛型的数量也可以为任意多个 * 如public T,K K showKeyName(GenericT container){ * ... * } */ public T T showKeyName(GenericT container){ System.out.println(container key : container.getKey()); //当然这个例子举的不太合适只是为了说明泛型方法的特性。 T test container.getKey(); return test; } //这也不是一个泛型方法这就是一个普通的方法只是使用了GenericNumber这个泛型类做形参而已。 public void showKeyValue1(GenericNumber obj){ Log.d(泛型测试,key value is obj.getKey()); } //这也不是一个泛型方法这也是一个普通的方法只不过使用了泛型通配符? //同时这也印证了泛型通配符章节所描述的?是一种类型实参可以看做为Number等所有类的父类 public void showKeyValue2(Generic? obj){ Log.d(泛型测试,key value is obj.getKey()); } /** * 这个方法是有问题的编译器会为我们提示错误信息UnKnown class E * 虽然我们声明了T,也表明了这是一个可以处理泛型的类型的泛型方法。 * 但是只声明了泛型类型T并未声明泛型类型E因此编译器并不知道该如何处理E这个类型。 public T T showKeyName(GenericE container){ ... } */ /** * 这个方法也是有问题的编译器会为我们提示错误信息UnKnown class T * 对于编译器来说T这个类型并未项目中声明过因此编译也不知道该如何编译这个类。 * 所以这也不是一个正确的泛型方法声明。 public void showkey(T genericObj){ } */ public static void main(String[] args) { } }2.类中的泛型方法其实类中的方法和泛型方法我认为还是比较好区分的在public/private等访问修饰符和返回值之间是否定义了泛型如果定义了则就是一个泛型方法仅供参考。public class GenericFruit { class Fruit{ Override public String toString() { return fruit; } } class Apple extends Fruit{ Override public String toString() { return apple; } } class Person{ Override public String toString() { return Person; } } class GenerateTestT{ public void show_1(T t){ System.out.println(t.toString()); } //在泛型类中声明了一个泛型方法使用泛型E这种泛型E可以为任意类型。可以类型与T相同也可以不同。 //由于泛型方法在声明的时候会声明泛型E因此即使在泛型类中并未声明泛型编译器也能够正确识别泛型方法中识别的泛型。 public E void show_3(E t){ System.out.println(t.toString()); } //在泛型类中声明了一个泛型方法使用泛型T注意这个T是一种全新的类型可以与泛型类中声明的T不是同一种类型。 public T void show_2(T t){ System.out.println(t.toString()); } } public static void main(String[] args) { Apple apple new Apple(); Person person new Person(); GenerateTestFruit generateTest new GenerateTestFruit(); //apple是Fruit的子类所以这里可以 generateTest.show_1(apple); //编译器会报错因为泛型类型实参指定的是Fruit而传入的实参类是Person //generateTest.show_1(person); //使用这两个方法都可以成功 generateTest.show_2(apple); generateTest.show_2(person); //使用这两个方法也都可以成功 generateTest.show_3(apple); generateTest.show_3(person); } }3.泛型方法与可变参数public T void printMsg( T... args){ for(T t : args){ Log.d(泛型测试,t is t); } } //printMsg(111,222,aaaa,2323.4,55.55);4.静态方法与泛型静态方法有一种情况需要注意一下那就是在类中的静态方法使用泛型静态方法无法访问类上定义的泛型如果静态方法操作的引用数据类型不确定的时候必须要将泛型定义在方法上。即如果静态方法要使用泛型的话必须将静态方法也定义成泛型方法 。public class StaticGeneratorT { .... .... /** * 如果在类中定义使用泛型的静态方法需要添加额外的泛型声明将这个方法定义成泛型方法 * 即使静态方法要使用泛型类中已经声明过的泛型也不可以。 * 如public static void show(T t){..},此时编译器会提示错误信息 StaticGenerator cannot be refrenced from static context */ public static T void show(T t){ } }5.泛型方法总结无论何时如果你能做到你就该尽量使用泛型方法。也就是说如果使用泛型方法将整个类泛型化 那么就应该使用泛型方法。另外对于一个static的方法而已无法访问泛型类型的参数。 所以如果static方法要使用泛型能力就必须使其成为泛型方法。5.泛型上下边界在使用泛型的时候我们还可以为传入的泛型类型实参进行上下边界的限制如类型实参只准传入某种类型的父类或某种类型的子类。为泛型添加上边界即传入的类型实参必须是指定类型的子类型public void showKeyValue1(Generic? extends Number obj){ Log.d(泛型测试,key value is obj.getKey()); } GenericString generic1 new GenericString(11111); GenericInteger generic2 new GenericInteger(2222); GenericFloat generic3 new GenericFloat(2.4f); GenericDouble generic4 new GenericDouble(2.56); //这一行代码编译器会提示错误因为String类型并不是Number类型的子类 //showKeyValue1(generic1); showKeyValue1(generic2); showKeyValue1(generic3); showKeyValue1(generic4);我们把泛型类的定义也改一下:public class GenericT extends Number{ private T key; public Generic(T key) { this.key key; } public T getKey(){ return key; } } //这一行代码也会报错因为String不是Number的子类 GenericString generic1 new GenericString(11111);再来一个泛型方法的例子//在泛型方法中添加上下边界限制的时候必须在权限声明与返回值之间的T上添加上下边界即在泛型声明的时候添加 //public T T showKeyName(GenericT extends Number container)编译器会报错Unexpected bound public T extends Number T showKeyName(GenericT container){ System.out.println(container key : container.getKey()); T test container.getKey(); return test; }通过上面的两个例子可以看出泛型的上下边界添加必须与泛型的声明在一起 。文章借鉴了很多其他文章的demo也有一些自己手撸的代码供大家参考。Java程序员如今深陷技术迭代放缓与行业需求收缩的双重困境职业发展空间正被新兴技术浪潮持续挤压。面对当前Java程序员可能面临的“发展瓶颈”或行业挑战更积极的应对策略可以围绕技术升级、方向转型、能力拓展三个核心展开而非被动接受“不行”的标签通过调查对比我发现人工智能大模型是个很好的出路。技术升级与转型机会突破传统Java开发边界大模型技术的普及为Java开发者提供了新的机遇使他们能够突破传统企业级开发的局限进入人工智能这一高增长领域。通过学习大模型集成Java开发者可以转型为AI应用开发者拓展职业发展空间。技术栈升级Java社区积极拥抱大模型技术推出了多个开源项目和框架如Deeplearning4j、DJLDeep Java Library等。这些工具为Java开发者提供了丰富的资源使他们能够更方便地构建和部署基于大模型的应用。发挥Java在企业级应用中的优势稳定性与可靠性Java作为企业级应用的主流语言其稳定性和可靠性在大模型应用中同样得到体现。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大模型学习资源包》免费分享
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

宜春网站建设可以做问答的网站

金相显微镜在PCB制造中主要用于切片观察和质量控制,贯穿来料检验、制程监控和失效分析全流程。 通过对PCB截面和表面细节的放大观察,可以评估层压、孔金属化、焊接等关键工序的可靠性,特别适合做切片后的定性和定量分析。作为国内领先的PCB测…

张小明 2025/12/25 20:55:23 网站建设

高邑网站建设江阴网站的建设

第一章:Open-AutoGLM GPU 加速适配为充分发挥 Open-AutoGLM 在大规模语言任务中的性能潜力,GPU 加速适配是关键环节。通过合理配置深度学习框架与硬件驱动,模型推理与训练效率可显著提升。环境准备与依赖安装 在开始之前,确保系统…

张小明 2025/12/25 20:54:49 网站建设

网站首页设计定位做关于水果的网站

Excalidraw 中的依赖注入:让代码更易测试、更灵活扩展 在现代前端开发中,我们常常面临一个看似简单却影响深远的问题:如何写出既能快速迭代,又方便测试、易于维护的代码?尤其是在构建像 Excalidraw 这类功能丰富、集成…

张小明 2025/12/25 20:54:16 网站建设

许昌建设网站江门网站建设公司哪家好

Jessibuca播放器跨平台兼容指南:提升直播体验的5个关键策略 【免费下载链接】jessibuca Jessibuca是一款开源的纯H5直播流播放器 项目地址: https://gitcode.com/GitHub_Trending/je/jessibuca 在当今多终端接入的直播场景中,Jessibuca播放器作为…

张小明 2025/12/25 20:53:43 网站建设

国内高端品牌网站建设网站建设科技公司

你是否曾经在深夜研究某个重要话题时,突然被知名新闻媒体或财经报刊的付费墙拦住去路?那种感觉就像站在知识宝库门前,却找不到开门的钥匙。今天,我要分享一个改变游戏规则的工具——Bypass Paywalls Clean,它能让付费内…

张小明 2025/12/28 11:20:30 网站建设

企业培训网站嘉兴制作企业网站

📋 概述 本文提供全面的AI大模型优化方案,涵盖模型微调(PEFT技术如LoRA/QLoRA/AdaLoRA)和推理(量化、注意力优化、批处理)两大环节。通过系统化应用这些技术,可在保持性能的同时显著降低计算资源消耗,提升训练和推理效率。文章包…

张小明 2025/12/25 20:52:05 网站建设