机器之心整理,做者:郑永川,参与:思源。git
这是一份收藏量超过 2 万 六、Fork 量超过 7 千的学习笔记。近日,中山大学郑永川构建了一个「准备秋招学习笔记」的项目,该项目包含了计算机科学的大量精要知识与教程。该项目从基础排序算法到编程理念展现了计算机科学的应知应会,该项目对机器学习开发者及入门读者也很是有用,例如 Linux 系统、面向对象的编程、Git 工具和代码可读性等。这些笔记都是做者根据对各种书籍的理解,并记录重要知识点而完成。
项目地址:github.com/CyC2018/Int…该项目的主体内容可分为 9 部分,其中算法介绍了基础的栈和队列、并查集、排序和查找等,操做系统介绍了现代计算机系统与 Linux 系统。其它如介绍了设计模式和基本思想的面向对象编程、世界上最早进的分布式版本控制系统 Git、以及 Java 和编程实践等都有涉及。程序员
以下是该项目各种别的基本目录与内容,由于机器学习可能会经常使用到面向对象的编程方法,所以咱们在后面简要介绍了这一章节中面向对象的基本思想。github
算法正则表达式
操做系统算法
网络数据库
面向对象编程
数据库设计模式
Javabash
分布式网络
工具
编码实践
面向对象思想
具体而言例如在面向对象的基本思想中,做者介绍了封装、继承和多态三大特性,此外还有类图和设计原则。这里摘取了原项目中展开的面向对象三大特性,更信息的内容请查看原 GitHub 项目。
面向对象的编程在实现想法乃至系统的过程当中都很是重要,咱们不管是使用 TensorFlow 仍是 PyTorch 来构建模型都或多或少须要使用类和方法。若能了解面向对象的三大特性并使用类和方法来构建模型,那么它们可让咱们的机器学习代码更加美丽迷人。
封装
利用抽象数据类型将数据和基于数据的操做封装在一块儿,使其构成一个不可分割的独立实体。数据被保护在抽象数据类型的内部,尽量地隐藏内部的细节,只保留一些对外接口使之与外部发生联系。用户无需知道对象内部的细节,但能够经过对象对外提供的接口来访问该对象。
优势:
如下 Person 类封装 name、gender、age 等属性,外界只能经过 get() 方法获取一个 Person 对象的 name 属性和 gender 属性,而没法获取 age 属性,可是 age 属性能够供 work() 方法使用。
注意到 gender 属性使用 int 数据类型进行存储,封装使得用户注意不到这种实现细节。而且在须要修改 gender 属性使用的数据类型时,也能够在不影响客户端代码的状况下进行。
public class Person {
private String name;
private int gender;
private int age;
public String getName() {
return name;
}
public String getGender() {
return gender == 0 ? "man" : "woman";
}
public void work() {
if (18 <= age && age <= 50) {
System.out.println(name + " is working very hard!");
} else {
System.out.println(name + " can't work any more!");
}
}
}
复制代码
继承
继承实现了 IS-A 关系,例如 Cat 和 Animal 就是一种 IS-A 关系,所以 Cat 能够继承自 Animal,从而得到 Animal 非 private 的属性和方法。
Cat 能够当作 Animal 来使用,也就是说可使用 Animal 引用 Cat 对象。父类引用指向子类对象称为 向上转型。
Animal animal = new Cat();
复制代码
继承应该遵循里氏替换原则,子类对象必须可以替换掉全部父类对象。
多态
多态分为编译时多态和运行时多态。编译时多态主要指方法的重载,运行时多态指程序中定义的对象引用所指向的具体类型在运行期间才肯定。
运行时多态有三个条件:
下面的代码中,乐器类(Instrument)有两个子类:Wind 和 Percussion,它们都覆盖了父类的 play() 方法,而且在 main() 方法中使用父类 Instrument 来引用 Wind 和 Percussion 对象。在 Instrument 引用调用 play() 方法时,会执行实际引用对象所在类的 play() 方法,而不是 Instrument 类的方法。
public class Instrument {
public void play() {
System.out.println("Instument is playing...");
}
}
public class Wind extends Instrument {
public void play() {
System.out.println("Wind is playing...");
}
}
public class Percussion extends Instrument {
public void play() {
System.out.println("Percussion is playing...");
}
}
public class Music {
public static void main(String[] args) {
List<Instrument> instruments = new ArrayList<>();
instruments.add(new Wind());
instruments.add(new Percussion());
for(Instrument instrument : instruments) {
instrument.play();
}
}
}复制代码