文章目录
前言
遇到了就简单写一下吧,如果能够对你有帮助,点个赞吧。首先清晰明了的了解到有参构造方法与无参构造方法、以及应用,然后实战项目一般会使用的Lombok,不会手动再生成get、set。
定义:
在编写一个类时没有添加无参构造方法,那么编译器会自动添加无参构造方法;(如果自己手动添加构造函数,无论有参数或是没参数,默认构造函数都将无效)
编写时添加有参构造方法而未添加无参构造方法,那么编译器只认有参构造方法而不会默认添加无参构造方法。
如果需要使用无参构造方法,一定要在类里面添加。
有参构造方法
在之前我们要为一个对象赋值,先要创建好对象之后然后“对象名.属性名”或者调用属性的setter为属性赋值。但是在很多时候觉得这样做很麻烦,最好的做法是在创建对象的时候完成属性的初始化操作,此时需要使用到有参数构造方法方能完成该功能(有人把构造方法叫做构造器)。
例子:(idea快捷键Alt+insert生成构造方法和get、set等)
1、定义一个Student类
package com.hn.yuan.common; /** * 有参构造方法 */ public class Student { private String name; private String age; public Student(String name, String age) { this.name = name; this.age = age; } public void setName(String name) { this.name = name; } public void setAge(String age) { this.age = age; } public String getName() { return name; } public String getAge() { return age; } public void start(){ System.out.println("我叫"+name+"今年"+age+"岁了"); } }
2、定义一个Test类,来进行查看运行效果
package com.hn.yuan.common; public class Test { public static void main(String[] args) { //使用有参数的构造方法实例化对象 Student st=new Student("张三","18"); st.start(); } }
运行效果
此时发现了我们不需要像之前一样,要为对象的属性赋值就必须先创建对象再使用“对象名.属性名”或者使用setter 方法去实现了,而是直接使用有参数的构造方法去实现。
3、定义原理呈现
在编写一个类时没有添加无参构造方法,那么编译器会自动添加无参构造方法;(如果自己手动添加构造函数,无论有参数或是没参数,默认构造函数都将无效)
编写时添加有参构造方法而未添加无参构造方法,那么编译器只认有参构造方法而不会默认添加无参构造方法。
如果需要使用无参构造方法,一定要在类里面添加。
无参构造方法
作用:无参构造方法一般是用来初始化:如为变量赋初值、初始化对象等。
在之前我们使用过方法,在调用的方法的是时候需要在方法名称之后加.上小括号,括号里面可以传递实参,那么我们在创建一个对象的时候使用的是“new类名()”的方式去实现,其实上这也是一种方法,但是这个方法我们没有明确的去定义,那为什么可以调用呢?观察代码。
例子:
1、首先,我们定义一个Student类
package com.hn.yuan.common; /** * 无参构造方法 */ public class Student { private String name; private String age; //含有 无参构造方法 public Student() { System.out.println("调用了无参构造方法"); } public void setName(String name) { this.name = name; } public void setAge(String age) { this.age = age; } public String getName() { return name; } public String getAge() { return age; } public void start(){ System.out.println("我叫"+name+"今年"+age+"岁了"); } }
2、定义一个Test类,来进行查看运行效果
package com.hn.yuan.common; public class Test { public static void main(String[] args) { //使用有参数的构造方法实例化对象 Student st=new Student(); System.out.println(st); } }
运行效果
定义四个类说明情况(如果还不清晰请看)
类Person1 自己不手动添加任何无参或有参数构造方法 (实例化对象时:编译通过)
类Person2 自己添加无参的构造方法 (实例化对象时:编译通过)
类Person3 有参数的构造方法 (实例化对象时:不通过)
类Person4 自己添加无参的构造方法,和有参数的构造方法 (实例化对象时:编译通过)
//定义类Person1 自己不手动添加任何无参或有参数构造方法 class Person1{ private int age; private String name; private String sex; } //定义类Person2 自己添加无参的构造方法 class Person2{ private int age; private String name; private String sex; public Person2(){ System.out.println("无参构造方法被调用"); } } //定义类Person3 有参数的构造方法 class Person3{ private int age; private String name; private String sex; public Person3(String name, String sex, int age ){ this.name = name; this.sex = sex; this.age = age; } } //定义类Person4 自己添加无参的构造方法,和有参数的构造方法 class Person4{ private int age; private String name; private String sex; //不带参数的构造函数,可以被重载 public Person4(){ System.out.println("无参构造方法被调用"); } //带参数对的构造函数 public Person4(String name, String sex, int age ){ this.name = name; this.sex = sex; this.age = age; } } public class ObjectInit_2 { public static void main(String[] args) { Person1 person1 = new Person1();//编译通过;①实例化Person对象 ②自动调用构造方法Person( ) Person2 person2 = new Person2();//编译通过;打印: 无参构造方法被调用 // 这样写,编译器会报错,原因是系统默认的无参构造方法被有参构造方法覆盖,编译器不能再提供无参构造方法 Person3 person3 = new Person3(); //Person4 person4 = new Person4();//编译通过;打印: 无参构造方法被调用 Person4 person4 = new Person4("qzz", "man", 18);//编译通过; } }
使用构造器时
1、构造器必须与类同名(如果一个源文件中有多个类,那么构造器必须与公共类同名)
2、每个类可以有一个以上的构造器
3、构造器可以有0个、1个或1个以上的参数
4、构造器没有返回值
5、构造器总是伴随着new操作一起调用
父类有有参构造方法有两种情况,一只有有参构造,那么子类的构造方法中的第一句必须调用父类的有参构造方法,也就是“super(…);”,…为你传入的参数如:
class Father { public Father(String lastname) { } } class Son extends Father { public Son() { super("aaaa");// 这句必须有 // 可以写其他代码 } }
二有有参也有无参构造方法,这时子类不显示调用super,这会默认自动调用父类无参的构造方法,
class Father { public Father() { } public Father(String lastname) { } } class Son extends Father { public Son() { super();// 这句可以有也可以没有,没有写的话会自动调用 // 可以写其他代码 } }
Lombok的基本使用
首先我们要了解的信息:
IntelliJ IDEA 2020.3及以上版本已经内置Lombok plugin了,所以不需要安装插件,只需要在项目添加Lombok依赖就能用了。(如果按照其它人给的办法通过非官方渠道安装Lombok plugin,反而可能出现版本兼容问题,所以IDEA 2020.3及以上版本的不要瞎搞去安装Lombok plugin了)
同时:lombok在2020.2就开始断更了,所以idea2021及之后的marketplace就不开始支持lombok了
信息来源1(IDEA 2020.3的更新说明):https://www.jetbrains.com/idea/whatsnew/2020-3/
开始应用:
注意:下载的版本要与idea版本对应,要不然可能会报错
1、官方下载之前对应idea版本的lombok
第一种:直接lombok官方:lombok各个版本下载地址
第二种:打开IDEA的File——setting——Plugins,搜索lombok,应用即可。
(一般内网状态下,会给你个Lombok压缩包,引入-应用-即可)
2、使用Lombok
第一种引入方式:直接在maven中添加依赖
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <!--这里由于采用springboot管理version,所以没有version标签--> </dependency>
第二种引入方式:在需要的类上面加注解@Data,会爆红
爆红之后,鼠标移到爆红位置,选择添加add ‘lombok’ to classpath即可,maven会自动帮我们添加依赖。
例子:
package com.hn.yuan.common; import lombok.AllArgsConstructor; import lombok.Data; /** * lombok的使用 */ @Data @AllArgsConstructor public class Student { private String name; private String age; }
常用注解作用:
@Data
等价于@Setter、@Getter、@RequiredArgsConstructor、@ToString、@EqualsAndHashCode
@NoArgsConstructor
@NoArgsConstructor在类上使用,这个注解可以生成无参构造方法,如下所示:
/** * 编译前代码 */ @RequiredArgsConstructor public class Student() { private String name; private String age; } /** * 编译后代码 */ public class Student() { private String name; private String age; public Student() { } }
@AllArgsConstructor
@AllArgsConstructor在类上使用,这个注解可以生成全参构造函数,且默认不生成无参构造函数。
不过需要注意的是,这里所说的全参并不包括已经被初始化的被final关键字修饰的字段,因为字段一旦被final关键字修饰被赋值后就不能再被修改,如下所示:
/** * 编译前代码 */ @RequiredArgsConstructor public class Student() { private final String gender; private final Integer ages = 18; private String name; private String age; } /** * 编译后代码 */ public class Student() { private final String gender; private final Integer ages = 18; private String name; private String age; public Student(String gender, String name, String age) { this.gender = gender; this.name = name; this.age = age; } }
@AllArgsConstructor :注在类上,提供类的全参构造
@NoArgsConstructor :注在类上,提供类的无参构造
@Setter :注在属性上,提供 set 方法
@Getter :注在属性上,提供 get 方法
@EqualsAndHashCode :注在类上,提供对应的 equals 和 hashCode 方法
@Log4j/@Slf4j :注在类上,提供对应的 Logger 对象,变量名为 log
各位看官》创作不易,点个赞!!!
诸君共勉:万事开头难,只愿肯放弃。
免责声明:本文章仅用于学习参考