探索设计模式的魅力:设计之美-揭秘设计模式、原则与UML的魔法


设计模式专栏:http://t.csdnimg.cn/U54zu


目录

一、引言

二、设计模式与设计原则

 设计模式

 设计原则

三、面向对象设计原则

四、UML(统一建模语言)

 4.1 UML是什么

 UML是一种语言

 UML是一种建模语言

  UML是一种图形化语言

 4.2 UML有什么

 4.3 UML能干什么

 4.4 UML类图之间关系

  关联

  泛化

  实现

  依赖

五、设计模式、设计原则与UML的协同之旅

六、结论


一、引言

    在数字化飞速发展的今天,软件已经成为我们生活中不可或缺的一部分。无论是手机应用、网站服务,还是嵌入式系统,背后都离不开精心设计的软件架构。软件设计不仅是编程前的蓝图规划,更是确保软件系统质量、稳定性、可维护性和可扩展性的关键因素。它如同建筑中的蓝图,决定了软件系统的结构和未来成长的方向。
    在软件设计的复杂世界中,设计模式、设计原则和UML(统一建模语言)犹如三位智者,为开发者提供了宝贵的指导。设计模式是前人智慧的结晶,它们为我们提供了解决常见问题的最佳实践;设计原则则像一盏明灯,指引我们走向清晰、简洁、灵活的设计之路;而UML,则是一种强大的可视化工具,帮助我们更好地理解和沟通软件设计的细节。
    这三者在软件设计中各自发挥着不可替代的作用,但它们的价值并不仅限于此。当它们协同工作时,能够激发出巨大的能量,帮助开发人员构建出既优雅又实用的软件系统。本文的目的,正是要深入探索这三者如何相互融合、相互促进,共同助力我们打造出高质量的软件产品,以满足不断变化的市场需求和用户期待。

二、设计模式与设计原则

    设计模式和设计原则都是软件工程中重要的概念,它们相辅相成,旨在提高软件的结构质量和可维护性。

 设计模式

    设计模式是针对软件设计中常见问题的标准解决方案。它们是在多年软件开发实践中总结出的一些有助于代码重用和设计高质量软件的经验准则。设计模式通常分为三类:

  1. 创建型模式

  • 涉及对象创建机制,旨在创建对象的同时隐藏创建逻辑。如:工厂方法(Factory Method),抽象工厂(Abstract Factory),建造者(Builder),原型(Prototype),单例(Singleton)。

  2. 结构型模式

  • 涉及类和对象的组合,构建出大的结构。如:适配器(Adapter),桥接(Bridge),组合(Composite),装饰器(Decorator),外观(Facade),享元(Flyweight),代理(Proxy)。

  3. 行为型模式

  • 涉及类的对象之间的通信。如:命令(Command),中介者(Mediator),观察者(Observer),状态(State),策略(Strategy),模板方法(Template Method),访问者(Visitor)。

 设计原则

    设计原则,相比之下,更加抽象和基础性,指导设计模式的应用以及更广泛的软件设计活动。一些经典的设计原则包括但不限于以下:

  1. 单一责任原则(SRP)

  • 一个类应该只有一个发生变化的原因。

  2. 开闭原则(OCP)

  • 软件实体应当对扩展开放,对修改关闭。

  3. 里氏替换原则(LSP)

  • 子类对象应该能够替换掉它们的父类型对象。

  4. 接口隔离原则(ISP)

  • 多个专用接口比一个宽泛用途的接口要好。

  5. 依赖倒转原则(DIP)

  • 高层模块不应该依赖于低层模块,它们都应该依赖于抽象;抽象不应该依赖于细节,细节应该依赖于抽象。

  6. 合成/聚合复用原则(CARP):

  • 它强调优先使用对象组合/聚合,而不是通过类继承来达到软件复用的目的。这样做可以提高系统的灵活性和可维护性,因为组合/聚合关系比继承关系更松耦合,更易于管理和扩展。

  7. 迪米特法则(LoD)

  • 主张一个对象应当对其他对象保持最少的了解,即每一个软件单位对其他的单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。

三、面向对象设计原则

    面向对象设计原则在软件设计和开发过程中起着至关重要的作用,帮助开发者创建出更加灵活、可维护和可复用的代码。

  1. 单一职责原则(Single Responsibility Principle, SRP)

  • 描述:一个类应该只有一个引起变化的原因。这意味着一个类应该只负责一项功能或业务逻辑,避免将过多的职责放在一个类中,从而增加类的复杂性和耦合度。
  • 好处:提高代码的可读性、可维护性和可测试性;降低类的复杂性和耦合度;增加类的内聚性。

  2. 开放封闭原则(Open Closed Principle, OCP)

  • 描述:软件实体(类、模块、函数等)应该是可扩展,而不可修改的。也就是说,当需要添加新功能时,应该通过扩展现有代码来实现,而不是修改现有代码。
  • 好处:提高系统的稳定性和可扩展性;减少对现有代码的破坏和潜在错误;促进代码复用。

  3. 里氏替换原则(Liskov Substitution Principle, LSP)

  • 描述:子类必须能够替换其父类并且出现在父类能够出现的任何地方,而程序的行为不变。这意味着子类在扩展父类功能的同时,不能破坏父类原有的功能和行为。
  • 好处:保证继承体系的正确性和稳定性;增强代码的可替换性和可复用性。

  4. 接口隔离原则(Interface Segregation Principle, ISP)

  • 描述:客户端不应该依赖它不需要的接口。这意味着接口应该尽量细化,每个接口只负责一项功能或业务逻辑,避免接口过于臃肿和庞大。
  • 好处:提高系统的灵活性和可维护性;减少接口的耦合度和实现难度;促进接口的复用和组合。

  5. 依赖倒置原则(Dependency Inversion Principle, DIP)

  • 描述:高层模块不应该依赖低层模块,它们都应该依赖其抽象;抽象不应该依赖细节,细节应该依赖抽象。这意味着在代码设计中,应该尽量使用接口和抽象类来定义依赖关系,而不是直接使用具体的实现类。
  • 好处:降低代码之间的耦合度;提高系统的可维护性和可扩展性;促进代码的复用和替换。

  6. 合成/聚合复用原则(Composite/Aggregate Reuse Principle, CARP)

  • 描述:尽量使用对象组合/聚合,而不是继承关系达到软件复用的目的。合成和聚合都是将已有对象纳入新对象中,使之成为新对象的一部分,但新对象可以独立于已有对象而存在。继承则是一种强耦合的关系,父类与子类之间通常存在“是一种”的关系,这限制了复用的灵活性。
  • 好处:降低类之间的耦合度,因为组合或聚合使每个类更独立,职责更清晰;提高系统的灵活性,因为组合和聚合允许在运行时动态地改变对象的行为和属性;增强代码的可维护性,因为组合和聚合使得类的结构更加清晰,易于理解和修改。

  7. 迪米特法则(Law of Demeter, LoD)或最少知识原则(Least Knowledge Principle, LKP)

  • 描述:一个对象应当对其他对象保持最少的了解。这意味着在代码设计中,应该尽量减少对象之间的直接交互和依赖,通过引入中介者或者消息传递等方式来降低对象之间的耦合度。
  • 好处:提高系统的模块化和可维护性;减少对象之间的耦合度和依赖关系;增加代码的可读性和可测试性。

    面向对象设计原则相互关联、相互补充,共同构成了面向对象设计的基石。遵循这些原则可以帮助开发者编写出更加健壮、灵活和可维护的代码。

    其他原则

 除了上面提到的原则,还有一些原则如下:

  1. 面向接口编程:

  • 面向接口编程(Interface-oriented programming,IOP)是一种编程方法论,强调程序设计应基于接口而不是具体的实现。在面向接口编程中,类和模块之间的耦合关系不是通过具体的类来实现,而是基于接口来进行交互和依赖。

  2. 一个类需要的数据应该隐藏在类的内部:

  • 将数据和对数据的操作封装在一个类的内部,通过访问控制修饰符(如 private、protected)限制外部对数据的直接访问,只允许通过类定义的接口(方法)进行访问。

  3. 类这间应该零耦合,或者只有传导耦合。换句话说,类之间没有关系,要么只使用另一个类的接口提供的操作:

  • 在面向对象编程中,尽量以传导耦合为目标,降低模块之间的依赖关系,减少因修改一个模块而引起对其他模块的影响。这可以通过合理的接口设计、抽象化、依赖注入等手段来实现。另外,利用设计模式和设计原则,如依赖倒置原则(DIP)、最少知识原则(LKP)等,也有助于减小模块之间的耦合,使得系统更易维护、扩展和测试。

  4. 在水平方向尽可能统一地分布系统功能:

  • 实现系统功能的均衡负载和高可伸缩性。这种设计方法可以将系统功能分布到多个相同或相似的节点上,以实现更好的性能和可靠性。

    详见:探索设计模式的魅力:深入理解面向对象设计的深层原则与思维-CSDN博客文章浏览阅读8.8k次,点赞74次,收藏69次。软件设计原则是指在软件开发过程中,通过一系列指导性的原则来指导设计决策和编码实践。这些原则旨在提高软件系统的质量,使其具有可维护性、可扩展性、可重用性和可测试性。几个重要性:可维护性、可扩展性、可重用性、可测试性和降低系统复杂度。软件设计原则是提高软件系统质量和可维护性的基石。遵循这些原则可以使得代码更加清晰、灵活和可靠,提高开发效率和软件质量,减少后期维护成本。同时,它们也为团队合作和团队成员共同理解代码提供了共同的规范和指导。https://blog.csdn.net/danci_/article/details/135794263

四、UML(统一建模语言)

 4.1 UML是什么

    UML是一种标准图形化建模语言,它是面向对象分析与设计的 一种标准表示。
    UML(Unified Modeling Language,统一建模语言)是一种用于对软件密集系统进行可视化建模的标准语言。它提供了一套丰富的图形化表示法,使得开发人员能够更清晰、直观地描述和理解软件系统的结构和行为。

 UML是一种语言

    那就是一种用来交流的语言,UML 用来在哪些人员之间进行交流呢?主要是在软件开发的整个生命周期所涉及到的人员之间进行交流的语言。

 UML是一种建模语言

    "建模"指的是使用工具化表示法来创建系统的抽象表示。这个抽象表示能够描述系统的静态结构和动态行为,帮助开发者和设计师更好地理解、设计和开发软件系统。

   模型的主要作用包括:

  1. 可视化

  • 通过将系统抽象为图形化的表示,模型使得系统的结构和行为更容易被理解和沟通。

  2. 分析

  • 通过对模型进行分析,可以检查系统是否满足需求,识别潜在的问题,以及优化系统的设计。

  3. 文档化

  • 模型可以作为系统开发过程中的重要文档,帮助团队成员了解系统的设计和实现。

  4. 指导开发

  • 模型可以作为开发过程中的指导,帮助开发者按照预定的设计进行编码和测试。

  UML是一种图形化语言

    “图形化”指的是使用图形、图表和符号等视觉元素来表示和传达软件系统的结构和行为。UML是一种标准化的图形化建模语言,它提供了一套丰富的图形表示法,用于描述软件系统的各个方面。
    这些图形表示法包括结构图、行为图和交互图等。结构图用于描述系统的静态结构,如类图、对象图、包图等,它们展示了系统中的类、接口、属性和关系等。行为图则用于描述系统的动态行为,如活动图、状态图、时序图等,它们展示了系统中的流程、状态转换和交互等。

 UML是一种标准的图形化建模语言

    在只有标准的东西,才会有更多的人学习和使用它,大家对同一表达的理解才会一样,才能真正达到相互交流的目的。
    否则要是没有标准,大家各自为政,可能会出现同一个图形, 大家有不同的认识和理解,那就没法交流了。

 4.2 UML有什么

    UML主要包括以下几种类型的图形化表示法:

  1. 结构化图形:

  • 类图(Class diagrams):用于描述系统中的类、接口、以及它们之间的关系,如继承、实现、关联等。
  • 对象图(Object diagrams):展示系统中对象的实例以及它们之间的关系。
  • 包图(Package diagrams):描述系统的模块结构和包之间的依赖关系。
  • 组件图(Component diagrams):描述系统的物理结构,包括软件组件以及它们之间的关系。
  • 部署图(Deployment diagrams):展示系统的硬件结构,包括节点以及它们之间的通信关系。

  2. 行为式图形:

  • 活动图(Activity diagrams):用于描述系统的动态行为,包括业务流程、并行活动以及活动间的约束关系。
  • 状态图(State diagrams):描述系统中对象的生命周期和状态转移,以及状态之间的转换条件。
  • 用例图(Use case diagrams):从用户角度描述系统的功能需求,包括参与者、用例以及它们之间的交互关系。

  3. 交互性图形:

  • 顺序图(Sequence diagrams):描述系统中对象之间的交互,强调交互发生的时间顺序。
  • 通信图(Communication diagrams):展示对象之间的消息传递顺序和协作关系。
  • 交互概述图(Interaction overview diagrams):用于描述多个交互图之间的关系。

 4.3 UML能干什么

    UML的作用主要体现在以下几个方面:

  1. 可视化和描述系统结构:

  • UML能够以图形方式表示系统的结构,包括类、对象、组件、模块、子系统等,帮助开发人员更清晰地了解系统的组成部分。

  2. 描述系统行为和交互:

  • UML可以描述系统的动态行为和对象间的交互,包括消息传递顺序、并行活动、业务流程等,有助于开发人员理解系统的运行方式和交互逻辑。

  3. 设计和模型转换:

  • 使用UML,开发人员可以在设计阶段进行模型转换,将高级的概念转换为具体的实现,从而更好地组织和规划开发工作。

  4. 文档化和沟通:

  • UML图表提供了一种标准的、易于理解的方式来描述系统,可以作为开发团队之间的沟通工具,促进团队成员之间的协作和理解。

 4.4 UML类图之间关系

  本专栏画的图涉及到比较多的是类图,类图之间关系如下:

  关联

    UML 的 关联用 于描述类和类的连接。类与类之间有多种连接方式,每种连接的含义 都是不同的,虽然语义不同,但是外部表象类似,因此统称为关联。。

   最常见的关联有普通关联递归关联聚合关联

  普通关联

    只要类与类之间存在关联关系就可以用普通关联来表示。

  递归关联

    如果一个类与它本身有关联关系,那么这种关联关系被称为递归关联。

  聚合关联

  泛化

    泛化又称通用化或继承,用来描述一 个通用元素的所有信息能被另外一 个具体元素 继承的机制。

  实现

    就是描述 类实现接又的 关系。接又是对行为而 非实现的说明,实现 类来具体实现接 又中的抽象定义。

  依赖

    如果某个对象的行为和实现,需要受到另外对象的影响,那么就是这个对象依赖于其他对象。基本上有关联的地方,严格说都有依赖。现在最常用的依赖关系是“使用” ,意思是如果A使用了B,那么A就依赖于B。

五、设计模式、设计原则与UML的协同之旅

    在软件设计的旅途中,设计模式、设计原则和UML并不是孤立存在的,它们相互关联,协同作用,共同构成了软件设计的坚实基础。
    设计模式为我们提供了解决问题的模板,这些模板是经验的总结,能够帮助我们快速、有效地解决常见问题。而设计原则则是指导我们进行设计的哲学,它确保我们的设计是清晰的、可维护的、可扩展的。UML作为一种可视化建模语言,它能够将我们的设计以图形的形式展现出来,使得设计更加直观,更易于理解和沟通。
    让我们通过一个实际的项目案例来探索这三者是如何协同工作的。假设我们正在开发一个复杂的电子商务系统,其中涉及到大量的用户交互、数据处理和业务逻辑。在这个项目中,我们首先运用UML对系统进行建模,通过类图、活动图等图形化表示法,清晰地展现出系统的结构和行为。然后,我们根据设计原则,如单一职责原则、依赖倒置原则等,对系统进行模块化设计,确保每个模块都职责清晰,易于维护。最后,我们运用设计模式,如工厂模式、策略模式等,来解决项目中遇到的具体问题,提高代码的可重用性和可扩展性。
    在这个过程中,我们可以看到设计模式、设计原则和UML是如何相互支持、相互补充的。UML帮助我们清晰地理解系统,设计原则指导我们设计出高质量的系统结构,而设计模式则为我们提供了解决具体问题的有效方案。这三者的协同工作,使得我们能够构建出高质量的软件系统。
    在总结来说,设计模式、设计原则和UML在软件设计过程中的协同作用是非常重要的。它们能够帮助我们更好地理解系统,设计出清晰、可维护、可扩展的系统结构,并快速有效地解决遇到的问题。因此,在软件设计过程中,我们应该综合运用这三者,发挥它们的最大价值,以构建出高质量的软件系统。

六、结论

    在本文中,我们详述了软件设计的重要性,并且针对软件开发中的核心地位给予了深入探讨。我们确认,设计模式、设计原则和统一建模语言(UML)是软件设计中不可或缺的元素,它们各自以独特的方式提升了软件的质量、可维护性和拓展性。
    设计模式,作为一组被广泛验证的解决方案模板,它们为常见的设计问题提供了规范化的处理机制。设计原则,如SOLID原则,为开发者提供了一个原则框架,帮助他们创造出低耦合、高内聚以及容易修改的系统。而UML,则为我们构建了一个共同的语言,允许开发人员跨领域能以标准化的方式交流和文档化他们的设计思想。
    为了成为一个出色的软件设计师,开发人员必须不断地学习和实践这些设计理念和工具。通过持续的研究和应用,我们可以提高自己的软件设计水平,更重要的是,可以灵活地适应不断变化的行业要求与技术创新。
    随着技术的快速进步,软件设计领域无疑将持续变革和发展。未来的软件设计可能会融合更多的人工智能和机器学习元素,使得系统设计更加智能化、自动化。在这样的变革中,设计模式、设计原则和UML仍将发挥它们的作用,可能会随着新的挑战和技术进步,它们也会持续演化,以更好地服务于未来的软件设计。
    我们鼓励每一位开发人员都能拥抱这一演变的浪潮,将设计模式、设计原则,以及UML等工具和概念视为武装自己的利器。让我们一起期待和塑造一个更加智能、高效和创新的软件设计未来。

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

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

相关文章

2.6 假期作业

分布编译 -ESc iso 1.预处理:头文件展开,宏替换,删除注释,不会查找语法错误 例:gcc -E 1.c -o 1.i 2.编译:生成汇编文件,会查找语法错误 例:gcc -S 1.i -o 1.s 3.汇编:生成二…

64位Office API声明语句第115讲

跟我学VBA,我这里专注VBA, 授人以渔。我98年开始,从源码接触VBA已经20余年了,随着年龄的增长,越来越觉得有必要把这项技能传递给需要这项技术的职场人员。希望职场和数据打交道的朋友,都来学习VBA,利用VBA,起码可以提高…

黑马程序员-瑞吉外卖-day7

目录 1.做新建菜品里面的上传图片 1.1设置存储路径(先是我们自己存到我们的本地) 2.在controller目录下写代码 3.在过滤器放开这个路径的访问 4.访问localhost:8080/backend/page/demo/upload.html 1.做新建菜品里面的上传图片 1.1设置存储路径&…

系留无人机的发展与应用场景分析,系留旋翼无人机技术难点分析

传统无人机的局限 随着无人机民用市场的扩大,无人机的功能愈加多样化,被广泛应用于搜救、公共安全、农林、摄像娱乐等多领域。民用市场的扩大使传统无人机面临很多技术难题,诸如定位、通讯、交互技术等等,其中最主要的是续航问题…

LeetCode-第876题-链表的中间结点

1.题目描述 给你单链表的头结点 head ,请你找出并返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点。 2.样例描述 3.思路描述 创建两个快慢指针 slow , fast ,起始共同指向头节点,slow 每次走一步,fas…

编译原理与技术(三)——语法分析(五)自底向上-LR分析

一、自顶向下的LL(1)与自底向上的LR (一)LL(1)非递归预测分析器及分析表 (二)LR分析器及分析表 二、LR分析 举个例子。 从上面不难看出,LR分析也是由分析表驱动的。那么关键在于构造LR分析表。

《动手学深度学习(PyTorch版)》笔记6.1

注:书中对代码的讲解并不详细,本文对很多细节做了详细注释。另外,书上的源代码是在Jupyter Notebook上运行的,较为分散,本文将代码集中起来,并加以完善,全部用vscode在python 3.9.18下测试通过&…

力扣 第 383 场周赛 解题报告 | 珂学家 | Z函数/StringHash

前言 谁言别后终无悔 寒月清宵绮梦回 深知身在情长在 前尘不共彩云飞 整体评价 T3是道模拟题,但是感觉题意有些晦涩,T4一眼Z函数,当然StringHash更通用些。 新年快乐, _. T1. 将单词恢复初始状态所需的最短时间 I 思路: 模拟 就是前缀和为…

C++ 哈希+unordered_map+unordered_set+位图+布隆过滤器(深度剖析)

文章目录 1. 前言2. unordered 系列关联式容器2.1 unordered_map2.1.1 unordered_map 的概念2.1.2 unordered_map 的使用 2.2 unordered_set2.2.1 unordered_set 的概念2.2.2 unordered_set 的使用 3. 底层结构3.1 哈希的概念3.2 哈希冲突3.3 哈希函数3.4 哈希冲突的解决3.4.1 …

芯片级原子钟,国产原子钟,芯片原子钟、国产芯片级微型原子钟介绍

原子钟已经为天文、航海、宇宙航行等领域提供了强有力的保障。但是,目前这些器件体积庞大,重量也很大,达几百千克。要成为平常人可使用的实用功能,原子钟的尺寸需要大幅缩小,而精度和速度需要被保留。 文章介绍的此类…

linux设置固定ip

进入目录 cd /etc/sysconfig/network-scripts 找到对应的配置文件,一般是ifcfg-ens开头的 vim ifcfg-ens192 BOOTPROTOstatic 网络类型配置,static代表静态ip IPADDR就是你要设置的ip

并发容器【ConcurentHashMap、CopyOnWriteArrayList、阻塞队列、ArrayBlockingQueue】

并发容器 什么是并发容器?同步容器:并发容器: ConcurrentHashMap结构图JDK1.7结构图JDK1.8结构图 CopyOnWriteArrayList实现原理 并发队列阻塞队列ArrayBlockingQueue 转自极客时间 什么是并发容器? 在JUC包中,有一大部分是关于并发容器的,如Concurr…

ref用法

目录 React中提供两种方法创建ref对象: 类组件获取 Ref 三种方式 ① Ref属性是一个字符串。 ② Ref 属性是一个函数。 ③ Ref属性是一个ref对象。 高级用法1:forwardRef 转发 Ref 高级用法2:ref实现组件通信 【ref作用】:最…

年假作业day2

1.打印字母图形 #include<stdio.h> #include<string.h> int main(int argc, const char *argv[]) { int i,j; char k; for(i1;i<7;i) { for(j1;j<i;j) { printf("%c",_); } for(j0,…

2.6学习总结

2.6 1.蓝桥公园 2.路径 3.打印路径 4.【模板】Floyd Floyd算法&#xff1a; 是一种多源的最短路径算法&#xff0c;经过一次计算可以得到任意两个点之间的最短路径。 这种算法是基于动态规划的思想&#xff1a; m[i][j]表示从i到j这条边的距离&#xff0c;dp[k][i][j]表示从…

【Vue3】解决路由缓存问题(响应路由参数的变化)

官方文档解释&#xff1a; 解决问题的思路: 让组件实例不复用,强制销毁重建监听路由变化,变化之后执行数据更新操作 方案一&#xff1a;给router-view添加key 以当前路由完整路径为key 的值&#xff0c;给router-view组件绑定 <RouterView :key"$route.fullPath&qu…

如何使用Docker部署Nginx容器实现无公网ip远程访问本地服务

文章目录 1. 安装Docker2. 使用Docker拉取Nginx镜像3. 创建并启动Nginx容器4. 本地连接测试5. 公网远程访问本地Nginx5.1 内网穿透工具安装5.2 创建远程连接公网地址5.3 使用固定公网地址远程访问 在开发人员的工作中&#xff0c;公网远程访问内网是其必备的技术需求之一。对于…

mvn常见报错:Failed to read artifact descriptor for 解决

问题&#xff1a; mvn打包时报错&#xff1a;Failed to read artifact descriptor for 产生原因&#xff1a; 项目打包时所需的依赖包不存在本地仓库&#xff0c;或本地仓库文件存在问题。 解决方法&#xff1a; 检查仓库可用性&#xff1a; 确保在Maven设置或pom.xml中指定…

npm 上传一个自己的应用(3) 在项目中导入及使用自己上传到NPM的工具

上文 npm 上传一个自己的应用(2) 创建一个JavaScript函数 并发布到NPM 我们创建了一个函数 并发上了npm 最后 我们这里 我们可以看到它的安装指令 这里 我们可以打开一个vue项目 终端输入 我们的安装指令 npm i 自己的包 如下代码 npm i grtest我们在 node_modules目录 下…

dbeaver免费、跨平台数据管理软件

下载 dbeaver是一款的数据库连接工具&#xff0c;免费&#xff0c;跨平台。 官网&#xff1a;DBeaver Community | Free Universal Database Tool下载地址&#xff1a;Download | DBeaver Community 点击下载 安装 修改安装路径 点击安装 点击完成 使用 连接mysql 已连接 点…