Java基础教程 - 7 面向对象-1

更好的阅读体验:点这里 ( www.doubibiji.com
更好的阅读体验:点这里 ( www.doubibiji.com
更好的阅读体验:点这里 ( www.doubibiji.com

7 面向对象

面向对象,首先涉及到的两个概念就是:对象

什么是类?

类就是对现实事物的抽象设计。

例如设计学生的类,可能包括属性:学号,姓名、年龄、性别等。

设计狗的类,可能包括属性:名字、年龄、品种。

类表示的是对一个事物的抽象,不是具体的某个事物。

什么是对象?

对象就是一个具体的实例,这个实例是从类派生出来的。

我们将类的属性赋值,就产生了一个个实例,也就是对象。

例如通过学生的类,我们赋值:学号=001,姓名=张三,年龄=16,性别=男,班级=三年二班,产生了就是一个名字叫张三的具体的学生,这样我们通过给类可以派生出一个个不同属性值的对象,李四、王五、赵六…。

所以是先设计类,然后根据类来生成一个个对象。

7.1 类和对象

1 类的定义

类中可以定义属性和行为,属性也就是成员变量,表示这个类有哪些数据信息,行为也叫成员方法,表示这个类能干什么。

例如,对于学生类而言,学号、姓名、年级就是属性,学习这个行为,可以定义为方法。

那么我们可以定义以下学生类:

/***定义类使用class关键字,后面跟类名*/
class Student {public String sid;public String name;public int age;public void study() {System.out.println("我是" + name + ", 我在学习");}
}

上面的类定义了三个成员变量(sid、name、age),public 表示访问修饰符,用来限制属性的访问权限,后面再讲,现在使用 public。后面是变量类型和变量的名称。

还定义了一个成员方法 study(),定义成员方法和之前定义静态方法是一样的,只是没有 static 关键字。

2 类的使用

上面我们定义好类了,现在可以使用类来创建对象了。

/*** 定义学生类*/
class Student {public String sid;public String name;public int age;public void study() {System.out.println("我是" + name + ", 我在学习");}
}/*** 测试类*/
public class Test {public static void main(String[] args) {Student stu = new Student();   // 创建对象stu.sid = "001";        // 为对象的sid属性赋值stu.name = "张三";       // 为对象的name属性赋值,现在学生是张三了stu.age = 18;System.out.println(stu.name);   // 打印名称stu.study();       // 使用对象调用方法}
}

因为 Java 中所有的代码都要放到类中,这里将测试的 main 方法放到了另一个类中,当然 main 方法放到 Student 中也是可以的,这里为了结构清晰。

首先通过 new Student() 可以创建一个 Student 对象,赋值给 Student 类型的变量 stu

创建对象后,我们可以通过 对象.属性 来访问变量,也可以通过 对象.属性=值 来给属性赋值。

使用 对象.方法() 可以调用方法。

执行结果:

张三
我是张三, 我在学习

面向对象编程就是先设计类,然后通过类创建对象,由对象做具体的工作。

3 默认构造方法

在上面创建对象后,使用 对象.属性=值 来给属性赋值,有点麻烦,我们可以在创建对象的时候,直接传递参数,给属性赋值。

这里就需要用到 构造方法。构造方法会在创建对象的时候自动执行,通过传递的属性值,给属性进行初始化。

举个栗子:

构造方法的名称和类的名称是一致的,没有返回值类型。

/*** 定义类*/
class Student {public String sid;public String name;public int age;/*** 构造方法*/public Student(String sid, String name, int age) {this.sid = sid;			// this.sid 访问的是属性,sid 是方法的形参this.name = name;this.age = age;}public void study() {System.out.println("我是" + name + ", 我在学习");}
}/*** 测试类*/
public class Test{public static void main(String[] args) {// 创建张三Student stu1 = new Student("001", "张三", 18);stu1.study();// 创建李四Student stu2 = new Student("002", "李四", 19);stu2.study();}
}

在上面的代码中,定义了构造方法,接收三个参数 (String sid, String name, int age),在构造方法中,分别将三个参数赋值给类中的成员变量。

因为构造方法的参数和类中的成员变量名称相同了(也可以不同),所以如果在构造方法中直接使用变量名,访问的将是构造方法的参数,访问不到成员变量,如果要访问成员,需要使用 this 关键字。

当然在 study() 方法中,没有参数和成员变量 name 同名,所以 name 访问到的就是成员变量,可以不用 this (当然使用也没毛病)。

在创建对象的时候,就可以传递参数为对象的属性赋值: new Student("001", "张三", 18)每次 new 就会创建新的对象,每个对象是独立的,所以上面张三和李四对象是独立的两个对象,修改其中一个对象的值,不会影响另一个对象。

执行结果:

我是张三, 我在学习
我是李四, 我在学习

4 this的作用

在上面的代码中用到了 this,因为上面我们写构造方法的时候,形参和类的属性名相同(当然也可以不同),导致在构造方法中,使用 sid/name/age 无法访问到类的属性,使用this,就表示访问的是属性 。

其实 this 表示的是调用当前方法的对象。如何理解?

举个栗子:

下面的代码,我们定义了学生类,创建了两个学生的对象。

/*** 定义类*/
class Student {public String sid;public String name;public int age;/*** 构造方法*/public Student(String sid, String name, int age) {this.sid = sid;			// this.sid 访问的是属性,sid 是方法的形参this.name = name;this.age = age;}public void study() {System.out.println("我是" + this.name + "我" + age +"岁了" + ", 我在学习");}
}/*** 测试类*/
public class Test{public static void main(String[] args) {// 创建张三Student stu1 = new Student("001", "张三", 18);stu1.study();// 创建李四Student stu2 = new Student("002", "李四", 19);stu2.study();}
}

执行结果:

我是张三, 我18岁了, 我在学习
我是李四, 我19岁了, 我在学习

当我们使用 stu1 调用 study() 方法的时候,this 就是指 张三 (stu1)这个对象,那么 this.name 的值就是张三;当我们使用 stu2 调用 study() 方法的时候,this 就是指 李四 (stu2) 这个对象,那么 this.name 的值就是李四。this 就是调用当前方法的对象。

5 对象内存解析

先查看下面的代码:

Student stu1 = new Student();   // 创建张三对象
stu1.sid = "001";        
stu1.name = "张三";
stu1.age = 18;Student stu2 = new Student();   // 创建李四对象
stu2.sid = "002";        
stu2.name = "李四";
stu2.age = 19;Student stu3 = stu1;
stu3.name = "王五";        System.out.println(stu1.name);   // 王五
System.out.println(stu2.name);   // 李四
System.out.println(stu3.name);   // 王五

在上面的代码中,首先创建了两个对象赋值给了 stu1 和 stu2,并对属性进行赋值,然后定义了一个 stu3 的变量,将 stu1 赋值给了 stu3,我们前面说过 stu1 和 stu2 是独立的两个对象,那么 stu1 和 stu3 是独立的两个对象吗?两个是同一个对象。下面画一下内存示意图:

创建完 stu1 并赋值后,内存结构如下(其实字符串是不保存在堆或栈中的,这里简化了):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

创建完 stu2 并赋值后,内存结构如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Student stu3 = stu1 执行完,内存结构如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

stu3.name = "王五"; 执行完成,内存结构如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

所以只在 new 的时候才会创建新的对象,stu3 = stu1 只是将 stu1 执行的对象的引用赋值给了 stu3 。

6 静态变量

上面我们定义的属性和方法,是实例变量和实例方法,也叫成员变量和成员方法。

实例变量对于每个实例而言,是独立的数据,每个对象之间相互不会影响。创建一个对象,就会开辟独立的内存空间保存对象的实例变量数据。但是无论创建多少对象,实例方法只有一份,所有对象共享,通过 this,来确定是哪个对象调用了实例方法。

在类中还可以定义各个对象共享的数据,也就是静态变量。

打个比方,我们定义了一个 Student 类,然后通过 Student 类来创建对象,我们想知道一共创建了多少个 Student 对象,应该如何操作呢?

我们可以通过定义 静态变量 来实现,静态变量和成员变量的区别就是:前面通过 static 关键字来修饰。

/*** 定义类*/
class Student {public static int stuCount = 0;		// 定义一个静态变量,用于记录创建的对象个数public String sid;public String name;public int age;/*** 构造方法*/public Student(String sid, String name, int age) {stuCount++;				  // 创建对象会调用构造方法,调用一次就+1this.sid = sid;			// this.sid 访问的是属性,sid 是方法的形参this.name = name;this.age = age;}
}/*** 测试类*/
public class Test{public static void main(String[] args) {Student stu1 = new Student("001", "张三", 18);Student stu2 = new Student("002", "李四", 19);Student stu3 = new Student("003", "王五", 20);// 通过类名访问System.out.println(Student.stuCount);		// 输出: 3// 通过对象也可以访问System.out.println(stu1.stuCount);		// 输出: 3System.out.println(stu2.stuCount);		// 输出: 3System.out.println(stu3.stuCount);		// 输出: 3}
}

在上面的代码中,我们定义了一个类,然后在类中定义了一个 stuCount 静态变量。当创建对象的时候,会调用构造方法,我们在构造方法中将 stuCount++,这样就可以记录调用构造方法的次数。

静态变量用来定义那些所有对象共享的数据。

**静态变量是属于类的,而不是属于类的实例。在类的方法中,如果没有局部变量和静态变量重名,那么可以直接使用静态变量,就像上面在构造方法中一样,如果有局部变量和静态变量重名,可以使用 类名.静态变量 来访问。 **

在类外,像上面在 Test 类中访问 Student 类中的静态变量,那么可以通过 类名.静态变量 来赋值和访问,也可以通过 对象.静态变量 来访问,但是推荐使用 类名.静态变量

7 静态方法

除了静态变量,还有静态方法。静态变量也是属于类的,而不是属于类的实例。

静态方法通过 static 关键字来修饰的方法,之前在学习方法的时候,我们定义的全是静态方法。

/*** 定义类*/
class Student {public static int stuCount = 0;		// 定义一个静态变量,用于记录创建的对象个数public String sid;public String name;public int age;/*** 构造方法*/public Student(String sid, String name, int age) {stuCount++;				// 创建对象会调用构造方法,调用一次就+1this.sid = sid;			// this.sid 访问的是属性,sid 是方法的形参this.name = name;this.age = age;}public void study() {System.out.println("我正在学习");}/*** 定义静态方法*/public static void getStuCount() {System.out.println("一共创建了" + stuCount + "个学生");// System.out.println(name);   // 静态方法中无法访问成员变量// study();  // 静态方法中无法调用成员方法}
}/*** 测试类*/
public class Test{public static void main(String[] args) {// 创建张三new Student("001", "张三", 18);// 创建李四new Student("002", "李四", 19);// 创建王五new Student("003", "王五", 20);Student.getStuCount();		// 输出: 一共创建了3个学生}
}

在静态方法不能访问成员变量和成员方法,因为静态方法是通过 类.静态方法() 调用的,不是通过对象实例来调用的,所以如果在静态方法中调用的成员变量没法确定是哪个实例的变量。但是在成员方法中是可以访问静态变量和静态方法的。


静态方法一般用来定义一些工具类,例如定义一个字符串的工具类:

public class StringUtils {/*** 判断字符串是否为空*/public static boolean isEmpty(String arg) {// trim()方法是去掉字符串的前后空格return (null == arg || arg.trim().length() < 1);}/*** 判断字符串是否不为空*/public static boolean isNotEmpty(String arg) {return !isEmpty(arg);}// ...定义其他的工具方法
}

定义完工具类,我就可以在其他的类中,通过 StringUtils.isEmpty("字符串") 来调用这个工具类中的方法了。

8 局部变量和全局变量

变量的作用域也就是在哪里可以访问到这个变量。按照作用域的不同,变量可分为 局部变量全局变量

什么是局部变量?

局部变量就是在方法中(包括方法的参数)或代码块中(例如for循环中定义的变量)定义的变量,这些变量只能在该方法中进行访问,其他方法中无法访问。

什么是全局变量?

全局变量就是类的属性,这些变量可以在多个方法中进行访问。


局部变量和全局变量除了作用域不同,还有一些地方也不同:

  • 权限修饰符:全局变量是类的属性,可以添加权限修饰符,我们目前只使用了 public,局部变量没有权限修饰符,关于权限修饰符后面再讲解;
  • 初始化:全局变量有初始化值,而局部变量在使用前,需要自己进行初始化,否则无法使用;
  • 内存中的位置:全局变量是保存在堆中的,而局部变量(非static,static是保存在虚拟机的方法区中的)是保存在栈中的。

关于全局变量的初始化值,在这里举个栗子:

/*** 定义类*/
class DataClass {public byte byteValue;public short shortValue;public int intValue;public long longValue;public float floatValue;public double doubleValue;public boolean booleanValue;public char charValue;public String stringValue;
}/*** 测试类*/
public class Test{public static void main(String[] args) {DataClass data = new DataClass();System.out.println(data.byteValue);     // 0System.out.println(data.shortValue);    // 0System.out.println(data.intValue);      // 0System.out.println(data.longValue);     // 0System.out.println(data.floatValue);    // 0.0System.out.println(data.doubleValue);   // 0.0System.out.println(data.booleanValue);  // falsechar c = 0;System.out.println(data.charValue == c);// trueSystem.out.println(data.stringValue);   // null}
}

在上面的代码中,我们并没有对类的属性进行初始化,但是类中的属性会默认有初始化值。

byte、short、int、long、char默认初始化值为 0float、double 默认初始化值为 0.0boolean 默认初始化值为 false引用类型的默认初始化值为 null

9 构造方法的重载

如果一个类中,没有显式的构造方法,那么会有一个隐式的无参构造方法。

class Student {public String sid;public String name;public int age;
}public class ObjectTest {public static void main(String[] args) {// 这里的Student()调用的就是默认隐式的构造方法Student stu = new Student();}
}

此时创建 Student 类对象,就是调用的隐式无参构造方法。当然,我们也可以手动写一个无参构造方法。

class Student {public String sid;public String name;public int age;public Student() {System.out.println("无参构造方法");}
}public class ObjectTest {public static void main(String[] args) {Student stu = new Student();	// 打印:无参构造方法}
}

当我们手动写了显式的无参构造方法,那么就会调用这个显式的无参构造方法了。

如果我们显式的写了有参的构造方法,那么隐式的无参构造方法就没有了,所以在创建对象的时候,就必须传递参数。

举个栗子:

class Student {public String sid;public String name;public int age;public Student(String sid, String name, int age) {this.sid = sid;this.name = name;this.age = age;}
}public class ObjectTest {public static void main(String[] args) {// Student stu = new Student();  // 报错,没有无参构造方法了Student stu = new Student("001", "ZhangSan", 18);}
}

当然构造方法也是可以重载的,我们可以定义多个构造方法。

class Student {public String sid;public String name;public int age;public Student() {System.out.println("无参构造方法");}public Student(String sid, String name) {System.out.println("有参构造方法: sid, name");this.sid = sid;this.name = name;}public Student(String sid, String name, int age) {System.out.println("有参构造方法: sid, name, age");this.sid = sid;this.name = name;this.age = age;}
}public class ObjectTest {public static void main(String[] args) {Student stu1 = new Student();Student stu2 = new Student("001", "ZhangSan");Student stu3 = new Student("001", "ZhangSan", 18);}
}

执行结果:

无参构造方法
有参构造方法: sid, name
有参构造方法: sid, name, age


那么如何在一个构造方法中调用另一个构造方法呢?

使用 this([参数]) 来调用,举个栗子:

class Student {public String sid;public String name;public int age;public Student() {System.out.println("无参构造方法");}public Student(String sid, String name) {this();	// 调用无参构造方法System.out.println("有参构造方法: sid, name");this.sid = sid;this.name = name;}public Student(String sid, String name, int age) {this(sid, name);	// 调用其他的构造方法System.out.println("有参构造方法: sid, name, age");this.sid = sid;this.name = name;this.age = age;}
}public class ObjectTest {public static void main(String[] args) {Student stu1 = new Student();Student stu2 = new Student("001", "ZhangSan");Student stu3 = new Student("001", "ZhangSan", 18);}
}

需要注意,使用 this([参数]) 调用其他的构造方法,这句代码必须放在构造方法的第一句。

执行结果:

无参构造方法
无参构造方法
有参构造方法: sid, name
无参构造方法
有参构造方法: sid, name
有参构造方法: sid, name, age

10 代码块

在类中还有代码块,代码块的主要作用也是进行一些初始化的工作。

代码块有静态代码块和非静态代码块。

静态代码块主要用于 初始化类的静态变量 或执行只需在类加载时运行一次的代码。

非静态代码块主要是对成员变量进行初始化工作。

举个栗子:

class Student {// 静态变量public static int staticValue;// 成员变量public int value;// 静态代码块static {staticValue = 10;System.out.println("执行静态代码块");}// 非静态代码块{value = 20;System.out.println("执行非静态代码块");}// 构造方法public Student() {System.out.println("执行构造方法");}
}/*** 测试类*/
public class ObjectTest {public static void main(String[] args) {new Student();new Student();}
}

执行结果:

执行静态代码块
执行非静态代码块
执行构造方法
执行非静态代码块
执行构造方法

从执行结果可以看出,静态代码块只会在类加载的时候执行一次,后面不会再执行了。静态代码块在每次创建对象的时候都会执行,而且会在构造方法之前执行。在代码块中也是可以调用类中的方法的,当然静态代码块只能调用静态方法。

静态代码块可以在需要进行一些逻辑处理后,再初始化静态变量的时候会用到,非静态代码块用的不多,一般使用构造方法就可以完成相同的功能。


需要注意,代码块和属性的显式赋值是同级的。谁写在后面,谁后生效。

举个栗子:

class Student {// 静态变量public static int staticValue = 20;// 静态代码块static {staticValue = 10;}
}class Teacher {// 静态代码块static {staticValue = 10;}// 静态变量public static int staticValue = 20;
}/*** 测试类*/
public class ObjectTest {public static void main(String[] args) {System.out.println(Student.staticValue);    // 10System.out.println(Teacher.staticValue);    // 20}
}

上面的 Student 和 Teacher 两个类中的静态变量,分别使用了显式赋值和静态代码块赋值,可以看到它们是同级的,谁在后面谁后执行,覆盖前面的初始化值。

11 属性的初始化顺序

类中的属性,有静态变量和成员变量,我们可以不初始化,会有默认值,也可以显式的进行初始化,也可以在静态代码块中对静态变量进行初始化,也可以构造方法中进行初始化。

这么多地方可以对属性进行初始化,那么初始化顺序是怎么样的呢?

  1. 静态变量默认初始化;
  2. 静态变量显式初始化;
  3. 静态代码块初始化;
  4. 成员变量默认初始化;
  5. 成员变量显式初始化;
  6. 构造方法中初始化;

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

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

相关文章

人物介绍模板 PSD 源文件免费获取

免费获取 下载链接在最后&#xff01; 下载链接在最后&#xff01; 下载链接在最后&#xff01; 下载链接在最后&#xff01; 下载链接在最后&#xff01; 链接&#xff1a;https://pan.baidu.com/s/1sq3e6djMdZt76Sh_uqVxWg 提取码&#xff1a;naun

论文阅读:基于改进 YOLOv5算法的密集动态目标检测方法

目录 概要 Motivation 整体架构流程 技术细节 小结 论文地址&#xff1a;基于改进YOLOv5算法的密集动态目标检测方法 - 中国知网 (cnki.net) 概要 目的&#xff1a;提出一种基于 YOLOv5改进的检测算法&#xff0c;解决密集动态目标检测精度低及易漏检的问题。 方法&…

C++ 中重写重载和隐藏的区别

重写&#xff08;override&#xff09;、重载&#xff08;overload&#xff09;和隐藏&#xff08;overwrite&#xff09;在C中是3个完全不同的概念。我们这里对其进行详细的说明 1、重写&#xff08;override&#xff09;是指派生类覆盖了基类的虚函数&#xff0c;这里的覆盖必…

基于Django的图书管理系统

文章目录 前言一、页面展示1.登录2.前端页面3.后端页面 总结 前言 本网站调用Django编写了图书管理网站&#xff0c;可以在后端控制书籍&#xff0c;前端进行书籍预览 一、页面展示 1.登录 2.前端页面 3.后端页面 — ![在这里插入图片描述](https://img-blog.csdnimg.cn/dir…

5.2 操作系统安装必备知识

目前操作系统安装方式接近于全自动化&#xff0c;用户无需做过多操作就能完成操作系统安装。但是操作系统安装也有其复杂的一面&#xff0c;例如固件及分区表的不同就会导致操作系统安装失败。本节主要介绍系统安装的一些必备知识。 5.2.1 BIOS 概述 BIOS(Basic Input/Output …

jspXMl标记语言基础

1.打开命令框进入数据库 打开eclipse创建需要连接的项目 粘贴驱动程序 查看驱动器 使用sql的包 int代表个 conlm代表列名 <%page import"java.sql.ResultSet"%> <%page import"java.sql.Statement"%> <%page import"java.sql.Connect…

Math.Round()函数说明

Math.Round()并不是严格意义上的是四舍五入函数。它默认的执行的是“银行家舍入”算法&#xff0c;即四舍六入五取偶。概括为&#xff1a;四舍六入五考虑、五后非零就进一&#xff0c;五后皆零看奇偶&#xff0c;五前为偶应舍去、五前为奇要进一。 当为5时&#xff0c;取离着最…

客观需求验证的常见5大步骤(实施版)

我们在挖掘用户需求时&#xff0c;往往容易犯伪需求或需求错位等问题&#xff0c;因此需要进行客观需求验证。通过客观的验证&#xff0c;我们可以有效减少主观判断误差问题&#xff0c;确保需求的准确性&#xff0c;从而降低需求变更和项目风险的概率&#xff0c;减少开发成本…

在做题中学习(58):和为K的子数组

560. 和为 K 的子数组 - 力扣&#xff08;LeetCode&#xff09; 因为是判断子数组的和 要返回 k 的次数&#xff0c;所以 解法&#xff1a;前缀和 哈希表 提出一个概念&#xff1a;以下标i为结尾的所有子数组 那要找出所有和 k的子数组 就相当于&#xff1a;找出所有值为…

[Cesium for Supermap]加载iserver发布的wms服务

1&#xff0c;wms服务 2&#xff0c;加载代码 let provider new Cesium.WebMapServiceImageryProvider({url: "http://support.supermap.com.cn:8090/iserver/services/map-china400/wms111/China_4326",enablePickFeatures:true,rectangle: Cesium.Rectangle.fromD…

dbeaver 链接 Oceanbase 数据库,dbeaver安装数据库驱动

新增驱动 提前到Oceanbase官网下载好驱动 1、点击数据库 -> 驱动管理器 -> 新建 2、添加驱动文件 联接数据库 1、选择你添加的驱动 2、测试

【OpenHarmony IDL工具规格及使用说明书】

OpenHarmony IDL工具规格及使用说明书 IDL接口描述语言简介 当客户端和服务器进行IPC通信时&#xff0c;需要定义双方都认可的接口&#xff0c;以保障双方可以成功通信&#xff0c;OpenHarmony IDL&#xff08;OpenHarmony Interface Definition Language&#xff09;则是一种…

【Apache Doris】周FAQ集锦:第 3 期

【Apache Doris】周FAQ集锦&#xff1a;第 3 期 SQL问题数据操作问题运维常见问题其它问题关于社区 欢迎查阅本周的 Apache Doris 社区 FAQ 栏目&#xff01; 在这个栏目中&#xff0c;每周将筛选社区反馈的热门问题和话题&#xff0c;重点回答并进行深入探讨。旨在为广大用户和…

[AI]-(第1期):OpenAI-API调用

文章目录 一、OpenAI API中使用GPT-3.5-turbo模型充值方式使用模型计费方式价格说明相关限制和条款 二、接入一个OpenAI API流程1. 获取OpenAI API 密钥2. 集成ChatGPT到小程序3. 处理用户输入4. 调用OpenAI API5. 返回回复至小程序6. 持续优化7. Postman请求示例 三、通用AI客…

河南广电与LiblibAI签署战略合作协议

5月15日&#xff0c;河南广电科技与LiblibAI战略签约仪式在郑州中原福塔新闻发布厅隆重举行。双方将本着“共商、共享、共建、共赢”原则&#xff0c;基于全面、可持续的战略合作伙伴关系&#xff0c;发挥各自优势&#xff0c;共同聚焦生成式AI领域&#xff0c;围绕内容创作、商…

内网环境ubuntu设置静态ip、DNS、路由,不影响网络访问

内网环境通常是有线的&#xff0c;通过服务器的ip、mac、dns地址访问网络才生效的&#xff0c;如果ip地址变了&#xff0c;就不能访问网络了。 如果你的ip地址变了&#xff0c;或者要防止ip变更影响网络访问&#xff0c;就要设置 1、依次点击右上角的电源-设置&#xff0c;在打…

如何管理测试用例?测试用例有什么管理工具?YesDev

3.1 测试用例 测试用例(Test Case) 是指对一项特定的软件产品进行测试任务的描述&#xff0c;体现测试方案、方法、技术和策略。其内容包括测试目标、测试环境、输入数据、测试步骤、预期结果等。简单地认为&#xff0c;测试用例是为某个特殊目标而编制的一组测试输入、执行条…

源代码防泄漏之沙盒技术分析

随着企业信息化的快速发展&#xff0c;对于单位来说&#xff0c;网络中包含了很多重要的信息资料&#xff0c;比如网络中积累和掌握了大量的研发数据、生产数据和运营信息等&#xff0c;组织不希望这些资料离开企业内部的网络环境&#xff0c;甚至不允许在网络外部传递与交流&a…

工单系统有哪些?

市面上的工单系统真的非常多&#xff0c;一个个列举肯定说不完&#xff0c;我大致给它们按照不同的依据&#xff0c;进行了一下分类&#xff1a; 1、按部署方式分类&#xff1a; 本地化部署工单系统&#xff1a;适用于对数据安全性要求较高的企业&#xff0c;需要企业在本地服…

[笔试训练](二十三)067:打怪068:字符串分类069:城市群数量

目录 067:打怪 068:字符串分类 069:城市群数量 067:打怪 题目链接:打怪 (nowcoder.com) 题目&#xff1a; 题解&#xff1a; 直接计算结果&#xff1a; 1.一只怪物能抗几次攻击 int m(H/a)(H%a0?0:1); 2.杀死一只怪物&#xff0c;玩家要抗几次攻击 int nm-1; *3.杀死一只…