设计模式

本文主要介绍设计模式的主要设计原则和常用设计模式。

一、UML画图

1.类图

image-20230814220944426

2.时序图

image-20230814221009623

二、设计模式原则

1.单一职责原则

就是一个方法、一个类只做一件事;

2.开闭原则

就是软件的设计应该对拓展开放,对修改关闭,这在java中体现最明显的就是访问控制修饰符;

3.里式替换原则

就是在设计父子关系时,就是如果能用子类,则一定也能用父类替代;

4.接口隔离

每个接口的设计要高内聚,低耦合;

5.迪特米原则

这个也叫最小知道原则,就是设计一个类的时候,要保证这个对象知道的最小;

6.依赖倒置原则

主要是为了解决类之间的耦合性,这个在spring中体现的很详细,就是类间的依赖通过接口来实现;

三、常用设计模式

设计模式分为三种类型,共23种:

  1. 创建型模式:单例模式、抽象工厂模式、建造者模式、工厂模式、原型模式。

  2. 结构型模式:适配器模式、桥接模式、装饰模式、组合模式、外观模式、享元模式、代理模式。

  3. 行为型模式:模版方法模式、命令模式、迭代器模式、观察者模式、中介者模式、备忘录模式、解释器模式、状态模式、策略模式、责任链模式、访问者模式。

创建型模式

1.原型模式(singleton)

1) 概述

解决问题:在系统中其实只需要该类的一个对象,为避免频繁创建和销毁其他对象,只给该类一个单例对象供使用;解决方法:给该类一个全局静态变量来保存单例,只提供一个共有方法来获取该实例,不提供构造方法来实例化对象;使用场景:1.只需要一个全局实例的,比如说生产全局UUID的生成器;

2) 具体说明

  • 普通模式:重点注意由于只有一个实例化对象,所以实例变量是静态成员变量;再就是构造方法要是private修饰,排除new方法创建新的对象;还有就是创建实例对象的方法要是public static,这样才能通过类名直接创建;

    image-20230814221059150

  • 饿汉式:就是创建一个静态常量作为实例,这样类一加载就完成了实例对象的初始化操作;劣势也很明显,就是没法懒加载,但后面没有用到该单例时候也被加载进来的了;

  • 懒汉式:就是在调用getInstance()方法时才实例出单例对象,并且之前创建单例模式的方法都没有考虑到并发情况,当同时进入到getInstance()创建实例时候,没有办法保证只创建一个实例,所以动用synchronized和volatile关键字来保证方法的调用并发执行;

  • 双重检验式:在创建单例之前判断单例是否存在,再进入加锁阶段,和懒汉式有区别的是加锁阶段后还会再次判断是否单例存在,这是生产环境常用的模式。

  • IoDH方式:就是通过内部静态类的方式来避免懒汉式类加载的时候就创建了实例的问题;

3) 代码实现

/*** @author yangnk* @desc* @date 2023/08/13 16:46**/
public class Singleton {//volatile 保障可见性private volatile static Singleton singleton;//private构造方法,无法通过new来实例化对象private Singleton() { }public static Singleton getSingleton() {if (singleton == null) {//用synchronized加锁,只允许并发情况下进行一个实例化操作synchronized (Singleton.class) {//需要再次判断singletonTest == null,避免指令重排导致初始化和分配内存失序if (singleton == null) {singleton = new Singleton();}}}return singleton;}public static void main(String[] args) {for (int i = 0; i < 3; i++) {Singleton singleton = Singleton.getSingleton();System.out.println("singletonTest.hashCode() = " + singleton.hashCode());}}
}

4) 总结

优点:1、只有一个对象在内存中,不用占用过多堆内存;2、只有一个实例,可以严格控制访问控制;缺点:1、违法类设计模式的单一指责的原则,一个实例就能做好所有的事?肯定不行;

2.工厂模式(factory)

1) 概述

解决问题:将产品实例的创建过程封装在工厂类中实现,将产品的声明和创建分离开来,提供统一的接口来创建不同的产品实例,解决需要创建多种继承同一接口的产品;解决方法:每个产品实现同一抽象产品类,每个工厂类实现同一抽象工厂类,通过多态特性实现不同的产品由不同的产品工厂类来实现;使用场景:工厂设计模式在各大框架中是运用最多的,在自己之前写过的代码中,日志记录也用到了这种设计模式,他可以拓展其他记录日志的方式;再通过反射和配置的形式,可以做到不需要修改代码就能实现不同记录日志的功能;

2) 具体说明

**主要角色:**
  • 抽象工厂类:声明了一组用于创建产品对象的方法,每个方法对应一种产品类型。抽象工厂可以是接口或抽象类。

  • 具体工厂类:生产具体产品的类,实现了抽象工厂类;

  • 抽象产品类:是具体产品类的父类,封装了具体产品的方法;

  • 具体产品类:实现具体方法,实现了抽象产品类;

    几种不同的工厂模式:

  • 简单工厂模式:工厂方法的思路是通过工厂类来创建相应的实体对象,简单工厂的逻辑是具体产品类实现抽象或接口产品类的方法,外部想要使用该产品需要通过工厂类来获取,该类工厂模式通过判定来生产相应的具体产品类;

    image-20230814221441153

  • 抽象工厂模式:当碰到所需生产的具体产品太多的时候,它只需要实现相应的具体产品类,但是在工厂类中,他是需要修改代码来实现的,这就违背了设计模式修改闭合的原则,所以借鉴产品类有抽象或接口的思路,工厂类也有相应的抽象类或接口,如果新增了具体产品,就新增相应产品工厂类。

    image-20230814221457450

3) 代码实现

4) 总结

优势:1、向用户隐藏了产品生产的逻辑,符合Java良好封装性的特征;2、如果想要再加新的产品类,不需要修改其他代码,只需要实现他们的接口就好了;劣势:1、如果产品很多那就很麻烦了,所以工厂模式不太适合产品超过5个的设计;

3.原型模式(prototype)

1) 概述

  • 模式定义:允许通过拷贝原始对象的属性创建一个相同的对象,而不需要关注这个对象怎么创建的。

  • 解决问题:不需要关注怎么创建一个新的对象。

  • 解决方案:在Java中年通过实clone()方法,在Spring中通过声明bean为Prototype类型来实现。

  • 应用场景:通过Java中的clone方法可以根据模板对象克隆一个原型对象,这就是原型模式的应用。在使用原型模式的时候要着重关注浅克隆还是深克隆。比较适合创建一个实例化比较复杂的时候,比如创建网络链接或数据库连接; 原型创建的对象一般会缓存起来,在运行时在缓存中获取即可。

2) 具体说明

原型的设计模式在于系统中有一个原型实例,之后在需要只需要**复制**他的副本就好了。原型设计模式最初由原型抽象类和原形实现类组成,其中最关键的在于要实现原型副本的拷贝,在Java中这是很容易实现的,直接重写clone方法就好了,但这个要注意Java里的深复制和浅复制,如果成员变量有对象的话,需要实现通过流来实现深复制。之后原型进化出另外一个组件,是原型管理器,其将原型保存到一个map中,等到其他类需要的话,再从这个map中拷贝。![image-20230814221512615](https://img-blog.csdnimg.cn/13afef1af3ae460ea6f577b13f0b0f2d.png)

3) 代码实现

4) 总结

优势:提高实例化对象的性能,不需要关注构造函数和初始化的过程,一般创建好的原型对象会放在缓存中,后续直接从缓存中获取对象即可 。劣势:如果类的成员变量引用比较深的话,那样clone起来就比较麻烦了;参考资料:深度分析:java设计模式中的原型模式,看完就没有说不懂的:https://segmentfault.com/a/1190000023831083

4.构建者模式(Builder)

1) 概述

  • 解决问题:当实例化一个对象的时,需要配置多个参数,并且参数的组合类型还非常多的情况,可以考虑使用使用构建者模式。
  • 解决方案:通过Builder统一给需要的对象来进行构建。
  • 应用场景:应用于一个实例需要通过配置 多个参数才能构建,并且这样的参数搭配有很多种,这种情况可以将产品本身和产品的创建解耦,产品的创建就交给builder来实现,实践中一般构造函数中的参数超过4个就可以考虑使用构建者模式了;

2) 具体说明

构建者模式讲的是这样一件事,就是如果一个实例有很多类组件或属性共同组成,而且没有固定套路,这样的的组合有很多种,所以就需要一种套餐的形式去构建,就像kfc套餐一样,汉堡和饮料作为套餐,具体类别你可以再选择;

构建者模式有三大组件,包括builder接口类、builder实现类还有director。他们的逻辑关系是这样的,builder实现类负责组合各类产品,最合成一个套餐,这个套餐其实在他的接口中就已经制定好了,而director就负责构建这样一个套餐;

image-20230814221537720

3) 代码实现

简单构建者模式的实现:
public class Computer {private final String cpu;//必须private final String ram;//必须private final int usbCount;//可选private final String keyboard;//可选private final String display;//可选private Computer(Builder builder){this.cpu=builder.cpu;this.ram=builder.ram;this.usbCount=builder.usbCount;this.keyboard=builder.keyboard;this.display=builder.display;}public static class Builder{private String cpu;//必须private String ram;//必须private int usbCount;//可选private String keyboard;//可选private String display;//可选public Builder(String cup,String ram){this.cpu=cup;this.ram=ram;}public Builder setUsbCount(int usbCount) {this.usbCount = usbCount;return this;}public Builder setKeyboard(String keyboard) {this.keyboard = keyboard;return this;}public Builder setDisplay(String display) {this.display = display;return this;}public Computer build(){return new Computer(this);}}
}

4) 总结

优势:针对很多参数组成的实例,将对象的构建和使用分离,能够非常灵活的构建一个对象;

劣势:1.他有一定的局限性,就是builder的实例是同一个类别的,或者说他是实现同一个接口的;2.使用构建者模式进行对象创建适合参数比较多得情况,参数较少不建议使用;

参考资料:秒懂设计模式之建造者模式(Builder pattern) shusheng007:https://zhuanlan.zhihu.com/p/58093669

结构性模式

5.适配器模式(adapter)

1) 概述

  • 解决问题:已有的对象和需要的对象无法直接对接,需要通过适配器来进行中转适配。

  • 解决方案:适配器继承或者依赖适配者,在适配器中实现需要提供的功能;

  • 使用场景:适配器类的使用场景还是很广的, 在SpringMVC中就有广泛的使用,比如Handler和HandlerAdapter的关系;

2) 具体说明

主要角色:

  • 适配器接口类:规定适配器需要实现的接口方法;
  • 适配器类:为目标类实现功能匹配的类;
  • 适配者接口类:目标类,原始还未适配的类的接口;
  • 适配者类:目标类的实现类;

适配器模式是利用一个适配器类来将接口无法适配的类对接起来。常用组件是一个适配器类和一个适配器接口类外加一个适配者类,适配者类上面可以有个是适配者类接口,要做的就是外部通过适配器就能够直接调用适配者的方法,具体实现是适配器类实现适配接口类的方法,适配器类接口种定义了外部需要的接口,适配器类可以继承适配者,这样就能从其身上继承他的方法,另一种方式是组合适配者对象引用。总的来说,适配器模式的关键在于实现他的适配器接口类,继承适配者类。他的UML类图如下所示:

image-20230814221717048

3) 代码实现

4) 总结

  • 优势:1、可以通过一个适配器适配多个适配者,这样可以弥补前期设计没有考虑周全的问题; 

  • 劣势: 加了中间一层适配器类转发,导致代码关系变复杂了;

一文彻底弄懂适配器模式(Adapter Pattern):https://segmentfault.com/a/1190000040524953

6.装饰者模式(decorator)

1) 概述

  • 解决问题:在不改变目标类的前提下拓展功能。

  • 解决方案:通过将目标类包装在修饰器内,在能够实现目标类的功能同时,修饰器类也能拓展其他功能;

  • 应用场景:装饰者设计模式在Java IO中运用的十分普遍,为什么在IO中引用普遍呢?在于IO为了兼顾不同应用场景和需求有太多不同类型的IO流了,所以利用修饰者模式的话,只需要在基础IO流上进行功能补充就好了;

2) 具体说明

主要组件:
  • 构建接口:目标类的接口类,定义目标类需要实现的功能;

  • 具体构建类:构建接口的具体实现;

  • 修饰器接口:持有对构建类的引用,并实现了构建接口的方法,能够统一对外提供目标类的方法;

  • 具体修饰器类:实现了修饰器接口,作为修饰器具体实现类还会新增其他功能;

修饰者模式又称为包装器模式,出现的原因在于有在基础类上进行增加功能的需求,如果直接修改当然违背了对修改闭合的原则,所以就想出了在原本的类上新增特性的修饰者类。实现该种模式的逻辑是:原始的被目标类实现对应的接口,修饰者也实现这个接口,当然这不是真正的修饰者类,其真正的修饰者类继承了修饰者接口,将其补充功能在真正的修饰者类中实现。

image-20230814222021637

3) 代码实现

4) 总结

  • 优势:1、修饰者是类似于继承的一种增强其他类的一种方式,但是他更灵活,要增加什么功能可以自己增加;2、通过配置和运行时动态生成的方式,可以让他变得更灵活;

  • 劣势:变复杂了;

7.门面模式(facade)

1) 概述

解决问题:访问系统中存在多个子系统,访问起来非常复杂;解决方案:为客户端提供一个统一的门面类型,之后只需要访问门面即可访问子系统中方法;使用场景:Spring的日志框架中用到了,slf4j统一了丰富多样的日志实现;

2) 具体说明

主要角色:

  • 门面类:通过门面统一向外界提供服务;

  • 子系统接口:规定子系统需要实现的逻辑;

  • 子系统类:实现子系统接口,实现各自的业务逻辑;

    门面模式又称外观模式,用以解决在多个外部系统要和多个内部系统进行通信,可能存在非常多的联系,提升系统交互的复杂度,通过引入门面统一负责和外部系统的通信,减少系统的复杂程度;在门面模式中存在门面和子系统两个角色。

image-20230814222037023

3) 代码实现

4) 总结

优点:1.化繁为简,将对多个不同的子系统访问转换为会单个门面的访问;缺点:1.违反了开闭原则,组件间相互依赖,修改子系统会涉及修改门面 ;

8.代理模式(proxy)

1) 概述

解决问题:通过代理类来实现对委托类的操作,可以出现在委托类无法获得或者不便获得,也可以用以增强对委托类的操作;

解决方案:JDK和Spring源码中有很多实现;

2) 具体说明

主要角色:

  • 委托者接口:定义目标类需要实现的方法;

  • 委托者实现:具体实现委托类中的方法;

  • 代理者:代理类中有委托类的引用,在代理类中也需要实现委托类的方法,所以可以执行委托类的本身的方法外,除此之外还能够在该方法前后进行增加;

代理模式有3个组件,包括:委托者接口、委托者还有代理者,他们的关系是:定义一个委托者接口,委托者和代理者都要实现他的方法,在代理类中还需要创建委托者的对象引用,这样在对委托者类方法进行重写时候可以直接调用。动态代理的UML类图:

image-20230814222049512

代理模式经常用在(1)委托类不想被直接调用,可以通过调用他的代理类来实现,像房产中介一样;(2)还有一种情况是可以增强委托类的能力,像Java中的动态代理,这中在spring aop中应用广泛;

3) 代码实现

4) 总结

优势:降低调用者和被调用者的耦合关系,怎么说呢?就是被调用者想要拓展新功能,可以在代理类中实践,不需要在自身类中进行修改,符合设计模式的开闭原则;

劣势:1对于JDK的动态代理,他需要委托类有接口,通过CgLib来动态代理,可以不需要;

行为型模式

9.责任链模式(chain of responsibility)

1) 概述

解决问题:一条处理链中的每个角色都能够处理请求,避免请求方和相应方的耦合关系,沿着这条处理链处理请求,直到最后处理得到结果。使用场景:Spring的Filter中使用了责任链,这个适合于可以进行一系列链式处理的场景;

2) 具体说明

对于处理流程是线性的比较合适,每个handler中包含目前节点需要处理的业务,也包括下一个节点的引用。

image-20230814222100266

3) 代码实现

4) 总结

10.观察者模式(Observer)

1) 概述

2) 具体说明

观察者模式又称订阅发布模式,所以他适合发布订阅的场景,当目标对象有事件发生,就会通知观察者。

image-20230814222110225

3) 代码实现

4) 总结

四、代码实现

GitHub:https://github.com/yangnk/MyComputerScience/tree/07f4ea1e6c06437ba5fa552a288e67a1adae3cf9/src/main/java/designPattern

TODO

  1. 需要完善已经写的设计模式;
  2. 需要补充新的还未加上的设计模式;

参考资料

  1. 类图、时序图怎么画:https://design-patterns.readthedocs.io/zh_CN/latest/read_uml.html#id2

  2. 设计模式gitbook上的一本书,讲的很好:https://gof.quanke.name

  3. 菜鸟教程上的教程:http://www.runoob.com/design-pattern/design-pattern-tutorial.html

本文由博客一文多发平台 OpenWrite 发布!

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

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

相关文章

Kubernetes二进制部署方案

目录 一、环境准备 2.1、主机配置 2.2、安装 Docker 2.3、生成通信加密证书 2.3.1、生成 CA 证书&#xff08;所有主机操作&#xff09; 2.3.2、生成 Server 证书&#xff08;所有主机&#xff09; 2.3.3、生成 admin 证书(所有主机) 2.3.4、生成 proxy 证书 三、部署 …

Three.js程序化3D城市建模【OpenStreetMap】

对于我在 Howest 的研究项目&#xff0c;我决定构建一个 3D 版本的 Lucas Bebber 的“交互式讲故事的动画地图路径”项目。 我将使用 OSM 中的矢量轮廓来挤出建筑物的形状并将它们添加到 3js 场景中&#xff0c;随后我将对其进行动画处理 推荐&#xff1a;用 NSDT编辑器 快速搭…

VR/AR眼镜方案,MTK联发科平台智能眼镜安卓主板设计方案

随着人工智能在不同领域的逐渐深入&#xff0c;人们对一款产品的需求不再局限于某种单一的功能或单一场景&#xff0c;尤其是在工业医疗等专业领域&#xff0c;加快数字化转型才能实现产业的升级。 AR智能眼镜&#xff0c;是一个可以让现场作业更智能的综合管控设备。采用移动…

jvm内存溢出排查(使用idea自带的内存泄漏分析工具)

文章目录 1.确保生成内存溢出文件2.使用idea自带的内存泄漏分析工具3.具体实验一下 1.确保生成内存溢出文件 想分析堆内存溢出&#xff0c;一定在运行jar包时就写上参数-XX:HeapDumpOnOutOfMemoryError&#xff0c;可以看我之前关于如何运行jar包的文章。若你没有写。可以写上…

SpringBoot 学习(03): 弱语言的注解和SpringBoot注解的异同

弱语言代表&#xff1a;Hyperf&#xff0c;一个基于 PHP Swoole 扩展的常驻内存框架 注解概念的举例说明&#xff1b; 说白了就是&#xff0c;你当领导&#xff0c;破烂事让秘书帮你去安排&#xff0c;你只需要批注一下&#xff0c;例如下周要举办一场活动&#xff0c;秘书将方…

【VBA_选择区域的关键词更改颜色】

Private Sub CommandButtonl_Click() Cells.Font.ColorIndex 1 End Sub Sub Worksheet_SelectionChange(ByVal Target As Range) Dim rng As Range, i As Integer Dim T As String Dim C As Integer For Each rng In Selection T "河北" C 3 i 1 Do While InStr(…

SpringBoot + Vue 前后端分离项目 微人事(九)

职位管理后端接口设计 在controller包里面新建system包&#xff0c;再在system包里面新建basic包&#xff0c;再在basic包里面创建PositionController类&#xff0c;在定义PositionController类的接口的时候&#xff0c;一定要与数据库的menu中的url地址到一致&#xff0c;不然…

javaScript:模板字符串让你忘记字符串拼接

目录 一.前言 二.模板字符串的使用 1.介绍 2.模板字符串 支持换行 模板字符串更适合元素写入 innerHTML模板字符串写法 3.模板字符串中&#xff0c;可以运行表达式 4.模板字符串中可以运行函数 三.总结 语法&#xff1a; 多行字符串&#xff1a; 变量插值&#xff1a; …

SpringBoot统⼀功能处理

前言&#x1f36d; ❤️❤️❤️SSM专栏更新中&#xff0c;各位大佬觉得写得不错&#xff0c;支持一下&#xff0c;感谢了&#xff01;❤️❤️❤️ Spring Spring MVC MyBatis_冷兮雪的博客-CSDN博客 本章是讲Spring Boot 统⼀功能处理模块&#xff0c;也是 AOP 的实战环节&…

学习 Linux 系统路线图

在计算机科学领域&#xff0c;Linux 操作系统以其稳定性、灵活性和卓越性能而受到广泛欢迎。要真正掌握 Linux 系统&#xff0c;我们需要深入了解其关键组成部分&#xff0c;包括系统、内存、进程、网络和存储等模块。让我们深入探索这些模块&#xff0c;以建立起对 Linux 系统…

归并排序:从二路到多路

前言 我们所熟知的快速排序和归并排序都是非常优秀的排序算法。 但是快速排序和归并排序的一个区别就是&#xff1a;快速排序是一种内部排序&#xff0c;而归并排序是一种外部排序。 简单理解归并排序&#xff1a;递归地拆分&#xff0c;回溯过程中&#xff0c;将排序结果进…

深度学习在MRI运动校正中的应用综述

运动是MRI中的主要挑战之一。由于MR信号是在频率空间中获取的&#xff0c;因此除了其他MR成像伪影之外&#xff0c;成像对象的任何运动都会导致重建图像中产生伪影。深度学习被提出用于重建过程的几个阶段的运动校正。广泛的MR采集序列、感兴趣的解剖结构和病理学以及运动模式&…

vue3使用vuex

VUEX官方文档,可以学习详细,这篇笔记是写vue2升级vue3后使用vuex,或者忘记如何使用vuex做状态管理的情况 vueX状态管理 Vue 3 与 Vue 2 有很多不同之处&#xff0c;但 Vuex 的核心概念——State、Getters、Mutations、Actions 和 Modules——保持基本一致。Vuex 4 是为 Vue 3 …

部署工业物联网可以选择哪些通信方案?

部署工业物联网有诸多意义&#xff0c;诸如提升生产效率&#xff0c;降低管理成本&#xff0c;保障生产品质稳定&#xff0c;应对长期从业劳动力变化趋势等。针对不同行业、场景&#xff0c;工业物联网需要选择不同的通信方案&#xff0c;以达到成本和效益的最佳平衡。本篇就简…

drawio----输出pdf为图片大小无空白(图片插入论文)

自己在写论文插入图片时为了让论文图片放大不模糊&#xff0c;啥方法都试了&#xff0c;最后摸索出来这个。 自己手动画图的时候导出pdf总会出现自己的图片很小&#xff0c;pdf的白边很大如下如所示&#xff0c;插入论文的时候后虽然放大不会模糊&#xff0c;但是白边很大会显…

开源了一套基于springboot+vue+uniapp的商城,包含分类、sku、商户管理、分销、会员、适合企业或个人二次开发

RuoYi-Mall-JAVA商城-电商系统简介 开源了一套基于若依框架&#xff0c;SringBoot2MybatisPlusSpringSecurityjwtredisVueUniapp的前后端分离的商城系统&#xff0c; 包含分类、sku、商户管理、分销、会员、适合企业或个人二次开发。 前端采用Vue、Element UI&#xff08;ant…

【C#】条码管理操作手册

前言&#xff1a;本文档为条码管理系统操作指南&#xff0c;介绍功能使用、参数配置、资源链接&#xff0c;以及异常的解决等。思维导图如下&#xff1a; 一、思维导图 二、功能操作–条码打印&#xff08;客户端&#xff09; 2.1 参数设置 功能介绍&#xff1a;二维码图片样…

正则表达式:贪婪与非贪婪模式

正则中的三种模式&#xff0c;贪婪匹配、非贪婪匹配和独占模式。 在这 6 种元字符中&#xff0c;我们可以用 {m,n} 来表示 &#xff08;*&#xff09;&#xff08;&#xff09;&#xff08;?&#xff09; 这 3 种元字符&#xff1a; 贪婪模式&#xff0c;简单说就是尽可能进行…

材料行业可以转IC设计后端吗?

近来有许多材料行业的小伙伴通过后台来问我对于职业规划的看法&#xff0c;甚至有些小伙伴直接点明了某个行业适不适合自己&#xff0c;那么我这边仅以近年来比较热门的数字芯片设计来展开讲讲&#xff0c;材料适不适合转行做IC呢。 对于理工科的同学而言&#xff0c;选择哪个…

Day14 01-Shell脚本编程详解

文章目录 第一章 Shell编程【重点】1.1. Shell的概念介绍1.1.1. 命令解释器4.1.1.2. Shell脚本 1.2. Shell编程规范1.2.1. 脚本文件的结构1.2.2. 脚本文件的执行 1.3. Shell的变量1.3.1. 变量的用法1.3.2. 变量的分类1.3.3. 局部变量1.3.4. 环境变量1.3.5. 位置参数变量1.3.6. …