Java——Java面向对象

该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架。

概述:

Java是面向对象的程序设计语言,Java语言提供了定义类、成员变量、方法等最基本的功能。类可被认为是一种自定义的数据类型,可以使用类来定义变量,所有使用类定义的变量都是引用变量,它们将会引用到类的对象。类用于描述客观世界里某一类对象的共同特征,而对象则是类的具体存在,Java程序使用类的构造器来创建该类的对象。

对象和类:

Java是面向对象的程序设计语言,类是面向对象的重要内容,可以把类当成一种自定义类型,可以使用类来定义变量,这种类型的变量统称为引用变量。也就是说,所有类是引用类型。对象是由类创建出来的,可以说类时对象的抽象,对象是类的实例。

对象的概念:

Java 是面向对象的编程语言,对象就是面向对象程序设计的核心。所谓对象就是真实世界中的实体,对象与实体是一一对应的,也就是说现实世界中每一个实体都是一个对象,它是一种具体的概念。对象有以下特点:

  • 对象具有属性和行为。
  • 对象具有变化的状态。
  • 对象具有唯一性。
  • 对象都是某个类别的实例。
  • 一切皆为对象,真实世界中的所有事物都可以视为对象。

面向对象与面向过程:

1、面向过程:

面向过程是一种以事件为中心的编程思想,编程的时候把解决问题的步骤分析出来,然后用函数把这些步骤实现,在一步一步的具体步骤中再按顺序调用函数。

我们以五子棋为例来解释一下面向过程是如何解决问题的:

下过五子棋的同学都知道,首先要找两个人,然后把棋谱摆放好,其中一方手持黑棋,另一方手持白旗,一般约定白棋先动,然后黑棋在动,这样每人一步,直到某一方先凑成五子一条线便为赢。这是我们平常下五子棋的过程,那么用面向过程该如何表示呢?

我们可以将下五子棋的过程抽象成如下步骤:

(1)开始游戏(2)黑子先走(3)绘制画面(4)判断输赢(5)轮到白子(6)绘制画面(7)判断输赢(8)返回步骤(2) (9)输出最后结果。

接着我们用面向过程来实现五子棋这一程序:

下五子棋{

    开始游戏();

    黑子先走();

    绘制画面();

    判断输赢();

    轮到白子();

    绘制画面();

    判断输赢();

    返回到 黑子先走();

    输出最后结果;

}

复制

可见,面向过程始终关注的是怎么一步一步地判断棋局输赢的,通过控制代码,从而实现函数的顺序执行。

2、面向对象:

​ 一种基于面向过程的新编程思想,顾名思义就是该思想是站在对象的角度思考问题,我们把多个功能合理放到不同对象里,强调的是具备某些功能的对象。

具备某种功能的实体,称为对象。面向对象最小的程序单元是:类。面向对象更加符合常规的思维方式,稳定性好,可重用性强,易于开发大型软件产品,有良好的可维护性。

Java编程思想一书中有一段对面向对象的总结非常清晰到位,可谓是面向对象的精华所在:

1、万物皆对象 2、程序时对象的集合,它们通过发送消息来告知彼此所需要做的 3、每个对象都有自己的由其他对象所构成的存储 4、每个对象都拥有其类型 5、某一特定类型的所有对象都可以接收同样的消息

3、两者优缺点比较:

(1)、面向过程:

优点:

  流程化使得编程任务明确,在开发之前基本考虑了实现方式和最终结果,具体步骤清楚,便于节点分析。

  效率高,面向过程强调代码的短小精悍,善于结合数据结构来开发高效率的程序。

缺点:

  需要深入的思考,耗费精力,代码重用性低,扩展能力差,后期维护难度比较大。

(2)、面向对象:

优点:

  结构清晰,程序是模块化和结构化,更加符合人类的思维方式;

  易扩展,代码重用率高,可继承,可覆盖,可以设计出低耦合的系统;

  易维护,系统低耦合的特点有利于减少程序的后期维护工作量。

缺点:

  开销大,当要修改对象内部时,对象的属性不允许外部直接存取,所以要增加许多没有其他意义、只负责读或写的行为。这会为编程工作增加负担,增加运行开销,并且使程序显得臃肿。

  性能低,由于面向更高的逻辑抽象层,使得面向对象在实现的时候,不得不做出性能上面的牺牲,计算时间和空间存储大小都开销很大。

面向对象的三大特性:

概述:

1、继承:

  继承是面向对象的三大特征之一,也是实现软件复用的重要手段。Java的继承具有单继承的特点,每个子类只有一个直接父类。

2、封装:

  封装(Encapsulation)是面向对象的三大特征之一,它指的是将对象的状态信息隐藏在对象内部,不允许外部程序直接访问对象内部信息,而是通过该类所提供的方法来实现对内部信息的操作和访问。

  封装是面向对象编程语言对客观世界的模拟,在客观世界里,对象的状态信息都被隐藏在对象内部,外界无法直接操作和修改。比如说一个人的年龄,年龄只会随着时间的流逝而逐渐增长,不能随意修改人的年龄。对一个类或对象实现良好的封装,可以实现以下目的。

3、多态:

  Java引用变量有两个类型:一个是编译时类型,一个是运行时类型。编译时类型由声明该变量时使用的类型决定,运行时类型由实际赋给该变量的对象决定。如果编译时类型和运行时类型不一致,就可能出现所谓的多态(Polymorphism)。

  多态的作用是消除类型之间的耦合关系。

详解:

一、继承:

1、继承的概念:

程序来源于生活,也为生活所用。我们先从生活中的例子来看一下什么是继承:

现在有一个农场主,家有良田万顷,每年收入很多,他有一个儿子,就是我们口中的富二代。有一天农场主不幸去世了,那么他手下的农田和财产都是谁的了,毫无疑问,当然是他儿子的了(如果你好好努力,将来你儿子有很大机会是富二代哦)。那么他儿子本来一无所有,现在顷刻间多了需要Money,农田,房子等等,也就是拥有了他父亲的所有物资财富,这个我们就称之为继承。

Java的继承通过extends关键字来实现,实现继承的类被称为子类,被继承的类被称为父类,有的也称其为基类、超类。父类和子类的关系,是一种一般和特殊的关系。例如水果和苹果的关系,苹果继承了水果,苹果是水果的子类,则苹果是一种特殊的水果。

class Fruit{
	public double weight;
	public void info() {
		System.out.println("我是一个水果,重"+weight+"g");
	}
}

public class Apple extends Fruit{
	public static void main(String[] args) {
		//创建Apple对象
		Apple apple=new Apple();
		//Apple对象本身并没有weight成员变量
		//但是Apple的父类用于weight变量,所以Apple也可以方位
		apple.weight=88;
		apple.info();
	}

}

结果:我是一个水果,重88.0g

复制

2、重写父类的方法:

子类扩展了父类,子类是一个特殊的父类。大部分时候,子类总是以父类为基础,额外增加新的成员变量和方法。但有一种情况例外:子类需要重写父类的方法。例如鸟类都包含了飞翔方法,其中鸵鸟是一种特殊的鸟类,因此鸵鸟应该是鸟的子类,因此它也将从鸟类获得飞翔方法,但这个飞翔方法明显不适合鸵鸟,为此,鸵鸟需要重写鸟类的方法。

//父类
class Bird{
	public void fly() {
		System.out.println("我在天空自由的飞翔");
	}
}

public class Ostrich extends Bird {
	//重写Bird的fly方法
	public void fly() {
		System.out.println("我只能在地上奔跑");
	}
	
	public static void main(String[] args) {
		//创建Ostrich对象
		Ostrich ostrich=new Ostrich();
		ostrich.fly();
	}
}

结果:我只能在地上奔跑

复制

重写时需要注意:

1、返回值类型

2、方法名

3、参数类型及个数

都要与父类继承的方法相同,才叫方法的重写。

重写与重载的区别:

重写:相对继承而言,子类中对父类已经存在的方法进行区别化的修改。

重载:在同一个类中处理不同数据的多个相同方法名的多态手段。重载方法名相同,参数列表不同。

3、继承的初始化顺序:

先思考一下下面代码的输出结果:

class Animal{
	public Animal() {
		System.out.println("我是父类动物");
	}
}

class Humanity extends Animal{
	public Humanity() {
		System.out.println("我是父类人类");
	}
}

public class Student extends Humanity{
	
	public Student() {
		System.out.println("我是子类学生");
	}

	public static void main(String[] args) {
		Student student=new Student();
	}
}

复制

不要看结果,自己先思考一下

输出结果:

结果

复制

是不是和你思考的结果一样,不一样的同学接着往下看:

Java中继承初始化顺序如下:

1、初始化父类再初始化子类

2、先执行初始化对象中属性,再执行构造方法中的初始化。

基于上面两点,我们就知道实例化一个子类,java程序的执行顺序是:

父类对象属性初始化---->父类对象构造方法---->子类对象属性初始化—>子类对象构造方法

下面放上一张形象的图:

4、final关键字:

final 关键字可用于修饰类、变量和方法,final关键字有点类似C#里的sealed关键字,用于表示它修饰的类、方法和变量不可改变。

final修饰变量时,表示该变量一旦获得了初始值就不可被改变,final既可以修饰成员变量(包括类变量和实例变量),也可以修饰局部变量、形参。有的书上介绍说final修饰的变量不能被赋值,这种说法是错误的!严格的说法是,final修饰的变量不可被改变,一旦获得了初始值,该final变量的值就不能被重新赋值。由于final变量获得初始值之后不能被重新赋值,因此final修饰成员变量和修饰局部变量时有一定的不同。

1、final修饰变量:

  ☆:final修饰成员变量:一旦有了初始值,就不能被重新赋值。final修饰的成员变量必须由程序显示的指定初始值。final修饰类变量必须在静态初始化块中指定初始值或声明该类变量时指定初始值,而且只能在两个地方其中之一指定;final修饰实例变量必须在非静态初始化块、声明该实例变量或构造器中指定初始值,而且只能在三个地方的其中之一指定。

  ☆:final修饰局部变量:系统不会对局部变量进行初始化,局部变量必须由程序员显式初始化。因此使用final修饰局部变量时,既可以在定义时指定默认值,也可以不指定默认值。

  ☆:final修饰基本类型变量与引用类型变量区别:当使用final修饰基本类型变量时,不能对基本类型变量重新赋值,因此基本类型变量不能被改变。但对于引用类型变量而言,它保存的仅仅是一个引用,final只保证这个引用类型变量所引用的地址不会改变,即一直引用同一个对象,但这个对象完全可以发生改变。

import java.util.Arrays;

public class FinalTest {
	
	public static void main(String[] args) {
		//final修饰数组变量,arr只是一个引用变量
		final int[] arr= {3,90,33,12};
		System.out.println(Arrays.toString(arr));
		
		//对数组进行排序,合法
		Arrays.sort(arr);
		System.out.println(Arrays.toString(arr));
		//对数组元素进行赋值,合法
		arr[2]=109;
		System.out.println(Arrays.toString(arr));
		
		//下面语句对arr重新赋值,非法
		//arr=null;
		
	}

}

复制

2、final修饰方法:

  final修饰的方法不可被重写

3、final修饰类:

  final修饰的类不可以有之类

5、this关键字:

this是自身的一个对象,代表对象本身,可以理解为:指向对象本身的一个指针。

this的用法:

1、普通的直接引用

2、形参与成员名字重名,用this来区分

public class Student{
	
	String username;
	String password;
	
	public Student(String username,String password) {
		//this 代表当前对象 也就是下面的student
		this.username=username;
		this.password=password;
	}

	public static void main(String[] args) {
		Student student=new Student("jack","123");
	}
}

复制

3、引用构造函数,这个放在super关键字中说

6、super关键字:

super可以理解为是指向自己超(父)类对象的一个指针,而这个超类指的是离自己最近的一个父类。

super的用法:

1、普通的直接引用:与this类似,super相当于是指向当前对象的父类

super.name:引用父类的变量

super.add():引用父类的方法

2、子类中的成员变量或方法与父类中的成员变量或方法同名:

class Humanity{
	public void eat() {
		System.out.println("动物吃肉");
	}
}

public class Student extends Humanity{
	
	public void eat() {
		//super调用父类中的同名方法
		super.eat();
		System.out.println("人吃饭");
	}

	public static void main(String[] args) {
		Student student=new Student();
		student.eat();
	}
}

复制

结果:

动物吃肉
人吃饭

复制

3、引用构造函数:

super(参数):调用父类中的某一个构造函数(应该为构造函数中的第一条语句)。

this(参数):调用本类中另一种形式的构造函数(应该为构造函数中的第一条语句)。

class Humanity{
	
	public Humanity() {
		System.out.println("父类无参构造");
	}
	
	public Humanity(String s) {
		System.out.println("父类有参构造======"+s);
	}
	
}

public class Student extends Humanity{
	
	public Student() {
		super();//调用父类的无参构造方法
		System.out.println("子类无参构造");
	}
	
	
	public Student(String s) {
		super(s);//调用父类的有参构造
		System.out.println("子类的有参构造======"+s);
	}
	
	public Student(String username,String password) {
		this(username);//调用本类的有参构造
		System.out.println("子类带两个参数的构造函数======"+username+"======"+password);
	}
	
	public static void main(String[] args) {
		Student student=new Student();
		Student student2=new Student("小明");
		Student student3=new Student("小明","123");
	}
	
}

复制

输出结果:

父类无参构造
子类无参构造
父类有参构造======小明
子类的有参构造======小明
父类有参构造======小明
子类的有参构造======小明
子类带两个参数的构造函数======小明======123

复制

二、封装:

1、封装的概念与优点:

封装(Encapsulation)是面向对象的三大特征之一,它指的是将对象的状态信息隐藏在对象内部,不允许外部程序直接访问对象内部信息,而是通过该类所提供的方法来实现对内部信息的操作和访问。

封装是面向对象编程语言对客观世界的模拟,在客观世界里,对象的状态信息都被隐藏在对象内部,外界无法直接操作和修改。就如刚刚说的Person对象的age变量,只能随着岁月的流逝,age才会增加,通常不能随意修改Person对象的age。对一个类或对象实现良好的封装,可以实现以下目的。

  1. 隐藏类的实现细节。
  2. 让使用者只能通过事先预定的方法来访问数据,从而可以在该方法里加入控制逻辑,限制对成员变量的不合理访问。
  3. 可进行数据检查,从而有利于保证对象信息的完整性。
  4. 便于修改,提高代码的可维护性。

为了实现良好的封装,需要从两个方面考虑。

  1. 将对象的成员变量和实现细节隐藏起来,不允许外部直接访问。
  2. 把方法暴露出来,让方法来控制对这些成员变量进行安全的访问和操作。

2、访问修饰符:

Java提供了3个访问修饰符:public、protected和private,另外还有一个默认的修饰符default,Java的访问控制级别如下图所示:

下面来详细介绍一下四个访问修饰符:

  • private(当前类访问权限):如果类里的一个成员(包括成员变量、方法和构造器等)使用private访问控制符来修饰,则这个成员只能在当前类的内部被访问。很显然,这个访问控制符用于修饰成员变量最合适,使用它来修饰成员变量就可以把成员变量隐藏在该类的内部。
  • default(包访问权限):如果类里的一个成员(包括成员变量、方法和构造器等)或者一个外部类不使用任何访问控制符修饰,就称它是包访问权限的,default 访问控制的成员或外部类可以被相同包下的其他类访问。关于包的介绍请看5.4.3节。
  • protected(子类访问权限):如果一个成员(包括成员变量、方法和构造器等)使用protected访问控制符修饰,那么这个成员既可以被同一个包中的其他类访问,也可以被不同包中的子类访问。在通常情况下,如果使用protected来修饰一个方法,通常是希望其子类来重写这个方法。
  • public(公共访问权限):这是一个最宽松的访问控制级别,如果一个成员(包括成员变量、方法和构造器等)或者一个外部类使用public访问控制符修饰,那么这个成员或外部类就可以被所有类访问,不管访问类和被访问类是否处于同一个包中,是否具有父子继承关系。

掌握了访问修饰符后,我们就可以来使用封装了。

public class Person {
	
	private String username;
	private Integer age;
	
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public Integer getAge() {
		return age;
	}
	public void setAge(Integer age) {
		this.age = age;
	}
	
}

复制

上述代码Person类中有两个成员变量username和age,它们都是私有变量,外部不能访问,但是提供了get和set方法,通过这两个方法便可以修改和获取Person类中的相关数据,这就是封装

3、java中的包是什么?

记得我上初中的时候,班级有两个同名的同学,都叫王健,老师每次叫王健的时候他俩不知道叫的是谁,后来加上性别区分,一个叫男王健,一个叫女王健,这次区分开。

那么我们在java中会不会遇到这种情况呢?当然会,比如就Person这个类而言,在一个大型项目中,多人协作开发,你写了一个类叫Person,我也写个类叫Person,那么该如何区分这两个类呢?总不能一个叫男Person,一个叫女Person吧,哈哈。这时候java就引入了包的机制,允许在类名前面加上一个前缀来限制这个类,提供了类的多层命名空间

注意:

1、package语句必须作为源文件的第一条非注释性语句,一个源文件只能指定一个包,即只能包含一条package语句,该源文件中可以定义多个类,则这些类将全部位于该包下。 2、如果没有显式指定package语句,则处于默认包下。在实际企业开发中,通常不会把类定义在默认包下,但本书中的大量示例程序为了简单起见,都没有显式指定package语句。 3、同一个包下的类可以自由访问

三、多态:

1、多态的概念:

多态是指允许不同类的对象对同一消息做出响应。即同一消息可以根据发送对象的不同而采用多种不同的行为方式。(发送消息就是函数调用)

2、多态的作用:

消除类型之间的耦合关系。

3、多态产生的条件:

  1、要有继承;

  2、要有重写;

  3、父类引用指向子类对象。

4、多态的优点:

1、可替换性(substitutability)。多态对已存在代码具有可替换性。例如,多态对圆Circle类工作,对其他任何圆形几何体,如圆环,也同样工作。

2、可扩充性(extensibility)。多态对代码具有可扩充性。增加新的子类不影响已存在类的多态性、继承性,以及其他特性的运行和操作。实际上新加子类更容易获得多态功能。例如,在实现了圆锥、半圆锥以及半球体的多态基础上,很容易增添球体类的多态性。

3、接口性(interface-ability)。多态是超类通过方法签名,向子类提供了一个共同接口,由子类来完善或者覆盖它而实现的。如图8.3 所示。图中超类Shape规定了两个实现多态的接口方法,computeArea()以及computeVolume()。子类,如Circle和Sphere为了实现多态,完善或者覆盖这两个接口方法。

4、灵活性(flexibility)。它在应用中体现了灵活多样的操作,提高了使用效率。

5、简化性(simplicity)。多态简化对应用软件的代码编写和修改过程,尤其在处理大量对象的运算和操作时,这个特点尤为突出和重要。

Java中多态的实现方式:接口实现,继承父类进行方法重写,同一个类中进行方法重载。

5、经典的多态案例:

class Animal{
	public void eat() {
		
	}
}


class Cat extends Animal
{
	public void eat()
	{
		System.out.println("吃鱼");
	}
	public void catchMouse()
	{
		System.out.println("抓老鼠");
	}
}
 
class Dog extends Animal
{
	public void eat()
	{
		System.out.println("吃骨头");
	}
	public void kanJia()
	{
		System.out.println("看家");
	}
}

public class AnimalTest {

	 public static void main(String[] args) {
		Animal cat=new Cat();//向上转型
		cat.eat();
		Animal dog=new Dog();
		dog.eat();
          //Cat c=(Cat)cat;//向上转型
		
	}
}

复制

Animal是父类,它有两个之类分别是Dog和Cat,之类分别重写了父类的eat方法。

输出结果:

吃鱼
吃骨头

复制

从输出结果可以看出,同样都是Animal,但是却有不同的行为表现,这就是多态

6、向上转型和向下转型:

1、向上转型:就以上述的父类Animal和一个子类Dog来说明,当父类的引用可以指向子类的对象时,就是向上类型转换:Animal cat=new Cat();

2、向下转型:向下类型转换(强制类型转换),是大类型转换到小类型(有风险,可能出现数据溢出)。例如:Cat c=(Cat)cat

7、重写和重载:

重写:父类与子类之间的多态性,对父类的函数进行重新定义。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。在Java中,子类可继承父类中的方法,而不需要重新编写相同的方法。

重载:方法重载是让类以统一的方式处理不同类型数据的一种手段。多个同名函数同时存在,具有不同的参数个数/类型。重载是一个类中多态性的一种表现。

重载发生在一个类当中,重写发生在两个类当中,但是这两个类是父子类的关系。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

@Autowired与@Resource原理知识点详解

文章目录 前言springIOC依赖注入的三种方式属性注入(字段注入)构造方法注入setter注入用哪个? Autowired实现原理 Resource实现原理结论 Autowired与Resource的不同来源不同参数不同使用不同装配顺序 前言 现在spring可以说是一统天下了&…

【Unity-UGUI控件全面解析】| Canvas 画布组件详解

🎬【Unity-UGUI控件全面解析】| Canvas 画布组件详解一、组件介绍1.1 绘制元素的顺序二、组件属性面板2.1 Canvas :画布,控制UI的渲染模式2.2 Canvas Scaler:画布缩放器,控制UI画布的放大缩放的比例2.3 Graphic Raycaster:图形射线投射器,控制是否让UI响应射线点击三、…

【干货分享】一文说透分布式一致性协议(上)

本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注"慕课网"! 作者:大熊老师 | 慕课网讲师 在常见的分布式系统中,总会发生诸如机器宕机或网络异常(包括消息的延迟…

数据备份系列:Rsync 备份详解(一)

一、Rsync 简介 1.1 Rsync 是一个远程增量文件备份软件工具 1.2 Rsync 的特性 支持拷贝特殊文件,如连接文件、设备等。可以有排除指定文件或目录同步的功能,相当于打包命令 tar 的排除功能。可以做到保持原文件或目录的权限、时间、软硬链接、属主、组…

Python每日一练(20230502)

目录 1. 被围绕的区域 🌟🌟 2. 两数之和 II 🌟 3. 二叉树展开为链表 🌟🌟 🌟 每日一练刷题专栏 🌟 Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 Java每日一练 专栏 1…

react native ios 添加启动页 xcode14 react-native-splash-screen

最近更新xcode,有些配置有些不同,网上查的方法都是过时的,导致配了一段时间卡在这里,最后访问官网才弄好了,所以以后解决问题的办法先看官网再查其他各路神仙的办法。 官网的步骤:https://github.com/crazy…

颜色空间转换RGB-YCbCr

颜色空间 颜色空间(Color Space)是描述颜色的一种方式,它是一个由数学模型表示的三维空间,通常用于将数字表示的颜色转换成可见的颜色。颜色空间的不同取决于所选的坐标轴和原点,以及用于表示颜色的色彩模型。在计算机…

【C++入门】一篇搞懂auto关键字

个人主页:平行线也会相交 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 平行线也会相交 原创 收录于专栏【C之路】 目录 作用不那么大的场景auto真正的价值auto和指针结合使用注意点auto不能推导的场景范围for范围for的使用条件 作用不那么大的…

海尔牵头IEEE P2786国际标准通过Sponsor投票并连任工作组主席

01 海尔牵头IEEE P2786国际标准 通过Sponsor投票 并连任工作组主席 海尔牵头制定的全球首个服装物联网国际标准IEEE P2786《Standard for General Requirements and Interoperability for Internet of Clothing》通过Sponsor投票,标志着该国际标准草案得到了行业…

2.6 浮点运算方法和浮点运算器

学习目标: 以下是一些具体的学习目标: 理解浮点数的基本概念和表示方法,包括符号位、指数和尾数。学习浮点数的运算规则和舍入规则,包括加、减、乘、除、开方等。了解浮点数的常见问题和误差,例如舍入误差、溢出、下…

FPGA实现10G万兆网UDP通信 10G Ethernet Subsystem替代网络PHY芯片 提供工程源码和技术支持

目录 1、前言2、我这里已有的UDP方案3、详细设计方案传统 FPGA UDP 方案本 FPGA 10G UDP 方案(牛逼)10G Ethernet 框图10G Ethernet 发送解析10G Ethernet 接收解析10G Ethernet 寄存器配置10G Ethernet UI 配置 4、vivado工程详解5、上板调试验证并演示ping功能测试数据收发测…

一款支持全文检索、工作流审批、知识图谱的企事业知识库

一、项目介绍 一款全源码,可二开,可基于云部署、私有部署的企业级知识库云平台,一款让企业知识变为实打实的数字财富的系统,应用在需要进行文档整理、分类、归集、检索、分析的场景。 获取方式q:262086839 为什么建立知识库平台&…

perf record对C++程序耗时进行分析

本节将介绍如何使用perf工具的perf record对C代码进行性能分析,一切操作都是在ubuntu 20下进行。 perf工具安装 由于perf工具和内核版本有关,因此直接安装容易出错,建议直接通过如下指令安装: sudo apt-get install linux-tool…

00后卷王的自述,我难道真的很卷?

前言 前段时间去面试了一个公司,成功拿到了offer,薪资也从12k涨到了18k,对于工作都还没两年的我来说,还是比较满意的,毕竟一些工作3、4年的可能还没我高。 我可能就是大家说的卷王,感觉自己年轻&#xff…

独立IP服务器和共享IP服务器有什么区别

在选择一个合适的服务器时,最常见的选择是共享IP服务器和独立IP服务器。尽管两者看起来很相似,但它们有着很大的不同。本文将详细介绍共享IP服务器和独立IP服务器的不同之处,以及如何选择适合您需求的服务器。 一、什么是共享IP服务器? 共享…

Python探索性P图,四种增强方式快速玩转pillow库

嗨害大家好鸭!我是爱摸鱼的芝士❤ 我们平时使用一些图像处理软件时, 经常会看到其对图像的亮度、对比度、色度或者锐度进行调整。 你是不是觉得这种技术的底层实现很高大上? 其实最基础的实现原理, 用 Python 实现只需要几行…

Java JDK下载安装环境变量配置

目录 一、下载安装 1.简介 2.JDK下载JDK 官网海外历史地址: 3.安装 二、环境变量配置 1.新建JAVA_HOME变量 2.PATH变量 3.CLASSPATH 变量 4.测试是否安装成功 一、下载安装 1.简介 JDK 是SUN公司提供的一套Java 语言的软件开发工具包,简称JDK(JavaDevelo…

如何编写高质量代码

如何编写高质量代码 1. 前言2. 明确业务场景和用户需求3. 编程实践技巧3.1 提高命名规范3.2 保持代码简洁3.3 好的注释 4. 软件测试5. 总结 1. 前言 现代软件开发中,代码是构建高质量软件的核心。高质量代码能够提高软件系统的可靠性、可维护性和可扩展性&#xff…

给失业的互联网人一个思路:别再苦苦找工作了,要去找门槛低、现金流好、天花板低、资本看不上的创业项目,一年也能几百万!...

失业大潮中的互联网人该何去何从?这大概是许多人在难捱的深夜反复思考的问题。 一位失业很久的网友就在痛苦思索中悟出了适合自己的道路,下面分享给大家,篇幅太长,小编给大家划一下重点。 先说结论:失业的互联网人别再…

浅谈软件测试工程师的技能树

软件测试工程师是一个历史很悠久的职位,可以说从有软件开发这个行业以来,就开始有了软件测试工程师的角色。随着时代的发展,软件测试工程师的角色和职责也在悄然发生着变化,从一开始单纯的在瀑布式开发流程中担任测试阶段的执行者…