java中的类语法和前端的类语法几乎是一致的。
JAVA的面向对象编程和JS的类语法十分接近,我们看一段代码
public class Object_oriented {
public static void main(String[] args) {
// 打工人 前的PeoPle是类型
People dagongren =new People();
dagongren.name = "zhangsan";
dagongren.speak();
}
}
class People {
String name;
void speak(){
System.out.println("卧槽," + name +"讲话了!");
}
}
上述代码包含一个名为Object_oriented的Java类和一个名为People的Java类。
Object_oriented类是程序的入口点,具有一个静态的main方法,是程序的执行起点。
在main方法中,创建了一个People对象,名为dagongren,并设置了其name属性为"zhangsan"。接着调用了dagongren对象的speak方法。
People类是一个自定义的类,具有一个name属性和一个speak方法。name属性是一个字符串,存储了一个人的名字。
在Java类中,属性也称为成员变量或实例变量,是类的特征和状态的表示。
属性可以是任何基本数据类型(如整数、浮点数、字符、布尔值等)或引用数据类型(如字符串、数组、对象等)。
属性的声明语法如下:
<访问修饰符> <数据类型> <属性名>;
访问修饰符用于控制属性的可见性和访问范围:
例如,以下是一个包含三个属性的示例:
public class Person {
public String name; // 公开的name属性
private int age; // 私有的age属性
protected boolean sex; // 受保护的sex属性
// 构造方法和其他方法...
}
在上面的示例中,Person类有三个属性:name、age和sex。name属性是公开的,可以从类外部访问。age属性是私有的,只能在Person类内部访问。sex属性是受保护的,可以在同一个包内或Person类的子类中访问。
类的方法和TS中的方法基本一致,类中的方法需要添加返回类型
方法由方法头和方法体组成。方法头包括方法的修饰符、返回类型、方法名称和参数列表。
修饰符 返回类型 方法名(参数列表) {
// 方法体
}
我们可以看一个简单的demo
public class Object_oriented {
public static void main(String[] args) {
People dagongren =new People();
dagongren.eat = true;
dagongren.speak();
}
}
class People {
boolean eat;
void speak(){
System.out.println(getText());
}
String getText(){
if(this.eat) {
return "我吃饭了";
}else {
return "我没吃饭";
}
}
}
方法中引入类的属性可以使用this关键词
方法中可以引入类中的其他方法
如果类中的方法需要参数,其写法和js也是一致的,不过需要指定参数的类型,如
public void add(int num1, int num2) {
// 方法体
}
静态变量是与类关联的变量,可以理解为类自身的属性,实例对象是木有的。静态变量可以用类名直接访问,而不需要创建类的实例。例如:
public class MyClass {
static int count;
}
使用类名访问静态成员变量。例如:MyClass.count = 10;
静态方法是与类关联的方法。与静态变量一样,无需创建类的实例即可访问静态方法。
使用类名调用静态方法。例如:MyClass.printMessage();
通过使用 ****static ****关键字定义,用于在类加载时执行一次的初始化操作。静态代码块在类首次被加载时执行,并且在类中的其他静态成员之前执行。
public class test {
public static void main(String[] args) {
new People();
new People();
}
}
class People {
static {
System.out.println("静态代码块1-------------------------------");
}
static {
System.out.println("静态代码块3-------------------------------");
}
}
根据代码运行结果,我们可以知道:第二次实例代码时,类中的静态块没有被执行
没有使用任何关键字定义,直接写在类中的代码块。实例代码块在创建对象时被调用,每次创建对象都会执行。通常用于在创建对象时进行一些通用的初始化操作。
public class test {
public static void main(String[] args) {
new People();
new People();
}
}
class People {
{
System.out.println("实例代码块2-------------------------------");
}
}
public class test {
public static void main(String[] args) {
new People();
new People();
}
}
class People {
static {
System.out.println("静态代码块1-------------------------------");
}
{
System.out.println("实例代码块2-------------------------------");
}
static {
System.out.println("静态代码块3-------------------------------");
}
}
可见:
构造方法是一种特殊的方法,用于创建并初始化对象。构造方法的名称必须与类名相同,并且没有返回类型。
这和js类中的constructor是一致的
构造方法有以下特点:
public class test {
public static void main(String[] args) {
new People();
new People();
}
}
class People {
// java提供的构造方法
People(){
System.out.println("构造方法-------------------------------");
}
}
public class test {
public static void main(String[] args) {
new People();
new People();
}
}
class People {
static {
System.out.println("静态代码块1-------------------------------");
}
{
System.out.println("实例代码块2-------------------------------");
}
People(){
System.out.println("构造方法-------------------------------");
}
static {
System.out.println("静态代码块3-------------------------------");
}
}
可见,优先级顺序 静态块 > 实例块 > 构造方法
Java中的继承语法格式如下:
class Subclass extends Superclass {
// 子类的方法和属性
}
其中,Subclass是子类,Superclass是父类。
我们看下面这个具体示例:
class Animal {
public void eat() {
System.out.println("Animal is eating");
}
}
class Dog extends Animal {
public void bark() {
System.out.println("Dog is barking");
}
}
public class Test {
public static void main(String args[]) {
Dog d = new Dog();
d.eat(); // 继承自Animal类
d.bark(); // 继承自Dog类
}
}
在上面的例子中,Dog类继承了Animal类。因此,Dog类可以使用Animal类中定义的eat() 方法。同时,Dog类还定义了自己的bark() 方法。
如果上述Animal类需要一个入参来指定eat的内容,Animal类需要做一些更改
class Animal {
String food;
// 我们在构造方法中使用this改变了类的属性food的值
public Animal(String food){
this.food = food;
}
public void eat() {
System.out.println("狗吃了" + this.food);
}
}
this关键字可以用于访问当前类的成员变量和方法。
此时,Dog在继承Animal类时,也需要访问父类的成员变量food
class Dog extends Animal {
public Dog(String food){
// 使用super()可以调用父类的构造方法
super(food);
}
public void bark() {
System.out.println("Dog is barking");
}
}
super关键字用于访问父类的成员变量和方法,super() 必须是构造方法中的第一条语句
完整代码
public class Test {
public static void main(String args[]) {
Dog d = new Dog("火腿肠");
d.eat(); // 继承自Animal类
d.bark(); // 继承自Dog类
}
}
class Animal {
String food;
public Animal(String food){
this.food = food;
}
public void eat() {
System.out.println("狗吃了" + this.food);
}
}
class Dog extends Animal {
public Dog(String food){
super(food);
}
public void bark() {
System.out.println("Dog is barking");
}
}