【Spring】——Spring的创建与使用

news2024/11/18 21:45:39

 目录

一、传统程序开发与控制反转🍭

1、传统程序开发🍉

传统程序开发的缺陷🍓

解决传统开发中的缺陷🍓

2、控制反转思维程序开发🍉

3 对比总结规律🍉

二、Spring创建与使用🍭

1、创建Spring🍉

Ⅰ、创建Maven项目🍓

 Ⅱ、添加Spring框架支持🍓

 Ⅲ、添加启动类🍓

注意:maven 项目下载 jar 失败的解决方案🍉

Ⅰ、配置好国内的Maven源🍓

配置国内源🍓

Ⅱ、重新下载jar包🍓

 Ⅲ、其他问题🍓

2.存储 Bean 对象🍉

Ⅰ、创建Bean🍓

Ⅱ、将 Bean 注册到容器🍓

3.获取并使用Bean 对象🍉

Ⅰ、获取Spring对象🍓

 多学一招:ApplicationContext与BeanFactory(常见面试题)

Ⅱ、获取指定的 Bean 对象🍓

 Ⅲ、使用Bean对象🍓

多学一招:getBean 方法的更多用法🍉

Ⅰ、根据类型获取 Bean:🍓

Ⅱ、根据名称 + 类型获取 Bean 🍓

两种方法的区别🍓

操作流程图


Spring_冷兮雪的博客-CSDN博客

上期我们讲解了Spring是什么及Spring的核心特点,其中重点讲解了控制反转(IoC)和依赖注入(DI),下面我们通过示例代码来去更深刻了解这其中的含义。

一、传统程序开发与控制反转🍭

1、传统程序开发🍉

在传统开发中,如果我们现在想构建⼀辆“⻋”的程序,我们的实现思路是这样的:

构建⼀辆车(Car Class),然而车需要依赖车身(FrameWork Class),而车身需要依赖底盘(Bottom Class),而底盘需要依赖轮胎(Tire Class),最终程序的实现代码如下
public class NewCarExample {
    public static void main(String[] args) {
        Car car = new Car();
        car.init();
    }

    /**
     * 汽⻋对象
     */
    static class Car {
        public void init() {
            // 依赖⻋身
            Framework framework = new Framework();
            framework.init();
        }
    }

    /**
     * ⻋身类
     */
    static class Framework {
        public void init() {
            // 依赖底盘
            Bottom bottom = new Bottom();
            bottom.init();
        }
    }

    /**
     * 底盘类
     */
    static class Bottom {
        public void init() {
            // 依赖轮胎
            Tire tire = new Tire();
            tire.init();
        }
    }

    /**
     * 轮胎类
     */
    static class Tire {
        public void init() {
            // 尺⼨
            int size = 30;
            System.out.println("轮胎尺⼨:" + size);
        }
    }
}

传统程序开发的缺陷🍓

以上程序中,轮胎的尺寸的固定的,然而随着对的车的需求量越来越⼤,个性化需求也会越来越多,这时候我们就需要加工多种尺寸的轮胎,那这个时候就要对上面的程序进行修改了,修改后的代码如下所示:
public class NewCarUpdateExample {
    public static void main(String[] args) {
        Car car = new Car(20);
        car.run();
    }
    /**
     * 汽⻋对象
     */
    static class Car {
        private Framework framework;
        public Car(int size) {
            framework = new Framework(size);
        }
        public void run() {
            // 依赖⻋身
            framework.init();
        }
    }
    /**
     * ⻋身类
     */
    static class Framework {
        private Bottom bottom;
        public Framework(int size) {
            bottom = new Bottom(size);
        }
        public void init() {
            // 依赖底盘
            bottom.init();
        }
    }
    /**
     * 底盘类
     */
    static class Bottom {
        private Tire tire;
        public Bottom(int size) {
            tire = new Tire(size);
        }
        public void init() {
            // 依赖轮胎
            tire.init();
        }
    }
    /**
     * 轮胎类
     */
    static class Tire {
        // 尺⼨
        private int size;
        public Tire(int size) {
            this.size = size;
        }
        public void init() {
            System.out.println("轮胎尺⼨:" + size);
        }
    }
}
从以上代码可以看出,以上程序的问题是:当最底层代码改动之后,整个调⽤链上的所有代码都需要修改。

解决传统开发中的缺陷🍓

如何解决上述问题呢?
我们可以尝试不在每个类中自己创建下级类,如果自己创建下级类就会出现当下级类发⽣改变操作,自己也要跟着修改。
此时,我们只需要将原来由自己创建的下级类,改为传递的方式(也就是注入的方式),因为我们不需要在当前类中创建下级类了,所以下级类即使发⽣变化(创建或减少参数),当前类本身也⽆需修改任何代码,这样就完成了程序的解耦。
PS:解耦指的是解决了代码的耦合性,耦合性也可以换⼀种叫法叫程序相关性。好的程序代码的耦合 性(代码之间的相关性)是很低的,也就是代码之间要实现解耦。
这就好比我们打造⼀辆完整的汽车,如果所有的配件都是自己造,那么当客户需求发⽣改变的时候, 比如轮胎的尺寸不再是原来的尺寸了,那我们要自己动手来改了,但如果我们是把轮胎外包出去,那么即使是轮胎的尺寸发生改变了,我们只需要向代理工厂下订单就行了,我们自身是不需要出力的。

2、控制反转思维程序开发🍉

基于以上思路,我们把调用汽车的程序示例改造⼀下,把创建子类的方式,改为注入传递的方式,具体实现代码如下:
public class IocCarExample {
        public static void main(String[] args) {
            Tire tire = new Tire(20);
            Bottom bottom = new Bottom(tire);
            Framework framework = new Framework(bottom);
            Car car = new Car(framework);
            car.run();
        }
        static class Car {
            private Framework framework;
            public Car(Framework framework) {
                this.framework = framework;
            }
            public void run() {
                framework.init();
            }
        }
        static class Framework {
            private Bottom bottom;
            public Framework(Bottom bottom) {
                this.bottom = bottom;
            }
            public void init(){
                bottom.init();
            }
        }
    static class Bottom {
        private Tire tire;
        public Bottom(Tire tire) {
            this.tire = tire;
        }
        public void init() {
            tire.init();
        }
    }
    static class Tire {
        private int size;
        public Tire(int size) {
            this.size = size;
        }
        public void init() {
            System.out.println("轮胎:" + size);
        }
    }
}
代码经过以上调整,⽆论底层类如何变化,整个调用链是不用做任何改变的,这样就完成了代码之间的解耦,从而实现了更加灵活、通用的程序设计了。

3 对比总结规律🍉

在传统的代码中对象创建顺序是:Car -> Framework -> Bottom -> Tire
改进之后解耦的代码的对象创建顺序是:Tire -> Bottom -> Framework -> Car

我们发现了⼀个规律:通用程序的实现代码,类的创建顺序是反的,传统代码是 Car 控制并创建了Framework,Framework创建并创建了 Bottom,依次往下,而改进之后的控制权发⽣的反转,不再是上级对象创建并控制下级对象了,而是下级对象把注⼊将当前对象中,下级的控制权不再由上级类控制了,这样即使下级类发⽣任何改变,当前类都是不受影响的,这就是典型的控制反转,也就是 IoC 的实现思想。
我们理解到了Spring的核心,下面我们来开始写第一个Spring代码。

二、Spring创建与使用🍭

1、创建Spring🍉

下面我们通过Maven ⽅式来创建⼀个 Spring 项⽬,具体可以分为三步:

  1. 创建⼀个普通 Maven 项⽬。
  2. 添加 Spring 框架支持(spring-context、spring-beans)。
  3. 创建一个普通类和main方法运行Spring框架。

Ⅰ、创建Maven项目🍓

 Ⅱ、添加Spring框架支持🍓

创建好了之后,在pom.xml添加 Spring 框架支持

添加的框架有 spring-context:spring 上下⽂,还有 spring-beans:管理对象的模块。
<dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.3.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>5.2.3.RELEASE</version>
        </dependency>
    </dependencies>

 添加之后

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>springdemo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.3.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>5.2.3.RELEASE</version>
        </dependency>
    </dependencies>
</project>

 Ⅲ、添加启动类🍓

在创建好的项⽬ java ⽂件夹下创建⼀个启动类,包含 main ⽅法即可:
public class App {
    public static void main(String[] args) {

    }
}

注意:maven 项目下载 jar 失败的解决方案🍉

Ⅰ、配置好国内的Maven源🍓

 检查项⼀共有两个:

1. 确认右边的两个勾已经选中,如果没有请点击选中。
2. 检查 User Settings file 的 settings.xml ⽂件是否存在:
        a. 如果不存在,复制下⾯配置了国内源的 settings.xml ⽂件,放到 User Settings file ⽬录下。
        b. 如果存在,检查 settings.xml 是否配置了国内源。
注意:两个路径中都不能出现中文!不能出现中文!不能出现中文!(重要的事说三遍)

配置国内源🍓

可以在Settings->搜索maven中 找到settings.xml ⽂件

配置的国内源的 settings.xml 配置如下:
<settings xmlns="http://maven.apache.org/SETTINGS/1.1.0" xmlns:xsi="htt
p://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.1.0 http://maven.
apache.org/xsd/settings-1.1.0.xsd">
<localRepository>C:\Users\intel\.m2\repository</localRepository>
 <mirrors>
 <mirror>
 <id>alimaven</id>
 <name>aliyun maven</name>
 <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
 <mirrorOf>central</mirrorOf> 
 </mirror>
 </mirrors>
</settings>

Ⅱ、重新下载jar包🍓

经过了第⼀步配置好国内maven源之后,⼀定要先配置好第⼀步!多检查几遍,然后删除本地存储 jar 包的⽬录,本地存储 jar 包的⽬录如下:

删除本地jar⽬录中的所有⽂件,切换到 Idea 中,重新下载 jar 包,如下图所示

 待下载完成,如果还是下载失败那就是本地网速问题,重复步骤 1 和步骤 2 直到下载成功!

 Ⅲ、其他问题🍓

如果经过上⾯配置,还是下载不了,那么有可能是以下问题:
  1. 上⾯的步骤没看仔细,可能遗漏了其中一步;
  2. Maven 路径中出现中⽂:出现中⽂会 导致下载的jar 包,在项目中不能正常使用;
  3. 当前网络运营商有问题:当前所在区域连接的网络运营商(中国电信、移动..)连接数据源有问题,尝试更好网络,使用手机热点或朋友的手机热点尝试,如果还是不行,就等三四个小时之后再试。

2.存储 Bean 对象🍉

存储 Bean 分为以下 2 步:
  1. 先创建⼀个 Bean。
  2. 将创建的 Bean 注册到 Spring 容器中。

Ⅰ、创建Bean🍓

所谓的 Bean 就是 Java 语⾔中的⼀个普通对象,我们写一个简单的 hello word 代码
public class User {
    public String sayHi(String name){
        return "hello"+name;
    }
}

Ⅱ、将 Bean 注册到容器🍓

在创建好的项⽬中添加 Spring 配置⽂件 spring-config.xml,将此⽂件放到 resources 的根目录下, 如下图所示:
创建:

 创建之后

Spring 配置文件的固定格式为以下内容:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

</beans>
然后再将 User 对象注册到 Spring 中就可以,具体操作是在 <beans> 中添加如下配置:
<bean id="user" class="User"></bean>

3.获取并使用Bean 对象🍉

获取并使⽤ Bean 对象,有以下 3 步:
  1. 得到 Spring 上下文对象,因为对象都交给 Spring 管理了,所以获取对象要从 Spring 中获取,那么就得先得到 Spring 的上下文。
  2. 通过Spring 上下文,获取某⼀个指定的 Bean 对象。
  3. 使用Bean 对象。

Ⅰ、获取Spring对象🍓

ApplicationContext:来自于Spring框架的接口。通过这个接口去获取Spring对象。

 

 多学一招:ApplicationContext与BeanFactory(常见面试题)

BeanFactory是以前的老方法了,现在已经被弃用,或者说现在比较少用了

import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.core.io.ClassPathResource;

public class App {
    public static void main(String[] args) {
        //1、获取spring对象
        BeanFactory context = new XmlBeanFactory(new ClassPathResource("spring-config.xml"));
        //2、从Spring中取出Bean对象 根据名称 + 类型获取 Bean
        User user= (User) context.getBean("user",User.class);//输出hello张三
        //3、使用Bean(可选)
        System.out.println(user.sayHi("张三"));
    }
}

 ApplicationContext VS BeanFactory

相同点:

  1. 都可以得到 Spring 上下文对象。
  2. 都是来自 Spring 的接口。

不同点

        1、继承关系和功能: 虽然都是Spring 容器的接口,但 ApplicationContext 属于 BeanFactory 的子类 。其中BeanFactory提供了基础的访问容器的能力,ApplicationContext除了继承BeanFactory 的所有功能之外,它还拥有独特的特性,还添加了对国际化支持、资源访问支持、以及事件传播等方面的支持。
        2、性能:ApplicationContext 是⼀次性加载并初始化所有的 Bean 对象,而BeanFactory 是需要哪个才去加载哪个,因此更加轻量。

Ⅱ、获取指定的 Bean 对象🍓

然后通过getBean方法取出Bean对象

注意:Bean 的 Id 要⼀⼀对应:  

 Ⅲ、使用Bean对象🍓

 我们现在就可以使用Bean,然后调用其中的方法了

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class App {
    public static void main(String[] args) {
        //1、获取spring对象
        ApplicationContext context=new ClassPathXmlApplicationContext("spring-config.xml");
        //2、从Spring中取出Bean对象
        User user= (User) context.getBean("user");
        //3、使用Bean(可选)
        System.out.println(user.sayHi("李四"));
    }
}

多学一招:getBean 方法的更多用法🍉

getBean() 方法有很多种重载⽅法,我们也可以使用其他方式来获取 Bean 对象,比如以下这两种:

Ⅰ、根据类型获取 Bean:🍓

User user= (User) context.getBean(User.class);
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class App {
    public static void main(String[] args) {
        //1、获取spring对象
        ApplicationContext context=new ClassPathXmlApplicationContext("spring-config.xml");
        //2、从Spring中取出Bean对象 Ⅰ、根据类型获取Bean
        User user= (User) context.getBean(User.class);
        //3、使用Bean(可选)
        System.out.println(user.sayHi("张三"));
    }
}

Ⅱ、根据名称 + 类型获取 Bean 🍓

User user= (User) context.getBean("user",User.class);

两种方法的区别🍓

当有⼀个类型被重复注册到 spring-config.xml 中时,只能使用 根据名称+类型获取了,比如以下程序

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class App {
    public static void main(String[] args) {
        //1、获取spring对象
        ApplicationContext context=new ClassPathXmlApplicationContext("spring-config.xml");
        //2、从Spring中取出Bean对象 Ⅰ、根据类型获取Bean
        User user= (User) context.getBean(User.class);//报错
        //Ⅱ、根据名称 + 类型获取 Bean
        //User user= (User) context.getBean("user",User.class);//输出hello张三
        //3、使用Bean(可选)
        System.out.println(user.sayHi("张三"));
    }
    public static void main1(String[] args) {
        //1、获取spring对象
        ApplicationContext context=new ClassPathXmlApplicationContext("spring-config.xml");
        //2、从Spring中取出Bean对象
        User user= (User) context.getBean("user");
        //3、使用Bean(可选)
        System.out.println(user.sayHi("李四"));
    }
}

操作流程图

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

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

相关文章

js解构记录

1.字符串结构 1.1 字符串转数组 1.2 字符串转成变量 1.3 结构字符串的属性 2. 数组结构 2.1 交换变量 2.2 允许指定默认值 只有赋值为undefined时默认值才生效&#xff0c;及时赋值null都不好使&#xff0c;会赋值为null 对是否是默认值在后面没有要求 3、对象结构 3.1 结…

spring cloud搭建(feign)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

I.MX RT1170加密启动详解(2):HAB认证原理

文章目录 1 基础2 使能过程3 Boot flow 1 基础 HAB认证是基于RSA或ECDSA算法的公钥密码学&#xff0c;它用一系列的私钥对image进行加密&#xff0c;然后BootROM在上电后用对应的公钥验证加密的镜像是否被修改。这个密钥结构就是PKI(Public Key Infrastructure)树 (1)normal …

DTU助力气象行业数字化转型,让数据更智能

近年来&#xff0c;随着社会的不断发展&#xff0c;气象行业在现代社会中扮演着极为重要的角色。天气对于人们的日常生活、农业、交通运输等方方面面都有着深远的影响。然而&#xff0c;在数据采集与监测过程中&#xff0c;气象行业也面临着一些问题。不准确的数据、不稳定的传…

基于simulink仿真无人机比赛场景

一、前言 展示了如何使用虚拟碰撞传感器以交互方式控制仿真&#xff0c;以及如何使用 Simulink3D 动画更改虚拟世界对象的外观。该示例表示一个简单的无人机 &#xff08;UAV&#xff09; 挑战。无人机比赛场景基于2013年在法国图卢兹举行的IMAV飞行比赛。 穿越窗口 降落直升机…

java基于springboot+vue的在线教育课程作业网站n5138

本基于springboot的在线教育网站的设计与实现有管理员&#xff0c;教师和学生三个角色。管理员功能有个人中心&#xff0c;教师管理&#xff0c;科目管理&#xff0c;学生管理&#xff0c;课程信息管理&#xff0c;课程作业管理&#xff0c;学生作业管理&#xff0c;学生成绩管…

Ubuntu下让matplotlib显示中文字体

文章目录 安装中文字体显示matplotlib库的字体文件夹删除matplotlib 的缓存文件&#xff08;可选&#xff09; matplotlib中设置字体&#xff0c;显示&#xff01; 参考文章&#xff1a; https://zodiac911.github.io/blog/matplotlib-chinese.html Ubuntu下python的matplotli…

七篇深入理解机器学习和深度学习的读物推荐

在这篇文章中将介绍7篇机器学习和深度学习的论文或者图书出版物&#xff0c;这些内容都论文极大地影响了我对该领域的理解&#xff0c;如果你想深入了解机器学习的内容&#xff0c;哪么推荐阅读。 Attention Is All You Need 在自然语言处理和序列建模领域&#xff0c;Vaswani…

华为OD机试真题 Java 实现【水仙花数】【2022Q4 100分】

一、题目描述 所谓水仙花数&#xff0c;是指一个n位的正整数&#xff0c;其各位数字的n次方和等于该数本身。 例如153是水仙花数&#xff0c;153是一个3位数&#xff0c;并且153 1^3 5^3 3^3。 二、输入描述 第一行输入一个整数n&#xff0c;表示一个n位的正整数。n在3到…

chatgpt赋能python:Python教程:如何创建一个Rectangle类

Python教程&#xff1a;如何创建一个Rectangle类 Python是一种简单易学的编程语言&#xff0c;适用于各种应用场景。在本教程中&#xff0c;我们将探讨如何使用Python创建一个Rectangle类。Rectangle类是一个简单的图形类&#xff0c;用于描述长方形的特征&#xff0c;如宽度和…

双域多尺度融合深度神经网络的PPG生物特征识别研究

目录 前言概述研究背景PPG存在的问题本文的创新点数据处理数据预处理数据分割特征提取 模型结构LSTM网络多尺度特征提取模块双域注意模块识别与验证 实验部分数据集识别指标 前言 本文是根据一篇论文总结写的。 论文英文名为&#xff1a;Dual-domain and Multiscale Fusion D…

Redis底层学习(三)—存储类型-List篇

文章目录 特点具体服务器操作命令具体操作应用场景 特点 适⽤场景&#xff1a;消息队列。 它的特点就是内部元素有序、重复&#xff0c;并且插⼊和删除很快 O(1) &#xff0c;但是查找却很慢 O(n) 。功能⽀持队列和栈操作。 具体服务器操作命令 左侧插⼊元素&#xff1a; LP…

基于同步矩阵的多通道脑电功能连接分析_kaic

摘 要 本文研究了基于同步矩阵的多通道脑电功能连接分析方法&#xff0c;旨在揭示脑区之间的功能联系。首先&#xff0c;介绍了脑电信号的产生和特点&#xff0c;以及功能连接分析的概念和方法。其次&#xff0c;详细讨论了多通道脑电数据的采集和预处理流程&#xff0c;包括…

JAVA并发学习

1 基础准备 1.1 并发与并行 并发是不同的代码块交替执行&#xff0c;也就是交替可以做不同的事情。 并行是不同的代码块同时执行&#xff0c;也就是同时可以做不同的事情。 根据CPU 核数&#xff0c;线程运行是不同的 单核CPU&#xff08;微观串行&#xff0c;宏观并行&…

YOLOV5 + PYQT5双目测距(一)

YOLOV5 PYQT5双目测距 1. 测距源码2. 测距原理3. PYQT环境配置4. 实验结果4.1 界面1&#xff08;简洁版&#xff09;4.2 界面2&#xff08;改进版&#xff09; 1. 测距源码 详见文章 YOLOV5 双目测距&#xff08;python&#xff09; 2. 测距原理 如果想了解双目测距原理&a…

Stable Diffusion 指定模型人物,Lora 训练全流程

简介 在使用 Stable Diffusion 的时候&#xff0c;可以选择别人训练好的 Lora&#xff0c;那么如何训练自己的 Lora&#xff0c;本篇文章介绍了介绍了如何训练Lora&#xff0c;如何从训练的模型中选择好的模型&#xff0c;如何在 Stable Diffusion 中使用。 闲话不多说&#…

CUDA编程接口详解

CUDA编程接口详解 本文将详细介绍NVIDIA CUDA编程指南第3章&#xff08;编程接口&#xff09;中的核心概念&#xff0c;例如NVCC编译器、CUDA运行时、版本管理和兼容性、计算模式、模式切换以及Windows下的Tesla计算集群模式。以下是本文的大纲&#xff1a; 文章目录 CUDA编程…

《斯坦福数据挖掘教程·第三版》读书笔记(英文版)Chapter 11 Dimensionality Reduction

来源&#xff1a;《斯坦福数据挖掘教程第三版》对应的公开英文书和PPT Chapter 11 Dimensionality Reduction Let M be a square matrix. Let λ be a constant and e a nonzero column vector with the same number of rows as M. Then λ is an eigenvalue of M and e is t…

快手三面全过了,却因为背调时leader手机号造假,导致offer作废了!

这是一个悲伤的故事&#xff1a; 快手本地三面全过了&#xff0c;但因为背调时leader手机号造假&#xff0c;导致offer作废了。 楼主感叹&#xff1a;大家背调填写信息时&#xff0c;一定要慎重再慎重&#xff0c;不要重复他的悲剧&#xff01; 网友愤慨&#xff0c;照这么说&a…

【Nginx 优化与防盗链】

目录 一、Nginx 服务优化1、配置Nginx 隐藏版本号2、修改用户与组3、缓存时间4、日志切割小知识 二、Nginx 深入优化1、连接超时2、更改进程数3、配置网页压缩4、配置防盗链 一、Nginx 服务优化 1、配置Nginx 隐藏版本号 可以使用 Fiddler 工具抓取数据包&#xff0c;查看 Ng…