Java中的constructor
Java中的构造方法总结今天写代码突然发现Java的构造方法也有不少说法呢,闲来无事,总结一下:构造方法和实例方法的区别:一、主要的区别在于三个方面:修饰符、返回值、命名1、和实例方法一样,构造器可以有任何访问的修饰符,public、private、protected或者没有修饰符 ,都可以对构造方法进行修饰。不同于实例方法的是构造方法不能有任何非访问性质的修饰符修饰,例如static、final、synchronized、abstract等都不能修饰构造方法。解释:构造方法用于初始化一个实例对象,所以static修饰是没有任何意义的;多个线程不会同时创建内存地址相同的同一个对象,所以synchronized修饰没有意义;构造方法不能被子类继承,所以final和abstract修饰没有意义。2、返回类型是非常重要的,实例方法可以返回任何类型的值或者是无返回值(void),而构造方法是没有返回类型的,void也不行。3、至于命名就是构造方法与类名相同,当然了实例方法也可以与类名相同,但是习惯上我们为实例方法命名的时候通常是小写的,另一方面也是与构造方法区分开。而构造方法与类名相同,所以首字母一般大写。下面看几个例子熟悉一下:public class Sample {private int x;public Sample() { // 不带参数的构造方法this(1);}public Sample(int x) { //带参数的构造方法this.x=x;}public int Sample(int x) { //不是构造方法return x++;}}上面的例子即使不通过注释我们也很容易能区分开的,再看下面一个例子public class Mystery {private String s;public void Mystery() { //不是构造方法s = "constructor";}void go() {System.out.println(s);}public static void main(String[] args) {Mystery m = new Mystery();m.go();}}程序执行的结果为null,虽然说Mystery m = new Mystery();调用了Mystery 类的构造方法,但是public void Mystery()并不是构造方法,他只是一个普通的实例方法而已,那该类的构造方法哪去了呢?二、说到这就得说一下java的默认构造方法我们知道,java语言中规定每个类至少要有一个构造方法,为了保证这一点,当用户没有给java类定义明确的构造方法的时候,java为我们提供了一个默认的构造方法,这个构造方法没有参数,修饰符是public并且方法体为空。其实默认的构造方法还分为两种,一种就是刚刚说过的隐藏的构造方法,另一种就是显示定义的默认构造方法.如果一个类中定义了一个或者多个构造方法,并且每一个构造方法都是带有参数形式的,那么这个类就没有默认的构造方法,看下面的例子。public class Sample1{}public class Sample2{public Sample2(int a){System.out.println("My Constructor");}}public class Sample3{public Sample3(){System.out.println("My Default Constructor");}}上面的三个类中Sample1有一个隐式的默认构造方法,下列语句Sample1 s1=new Sample()合法;Sample2没有默认的构造方法,下列语句Sample2 s2=new Sample2()不合法,执行会编译错误Sample3有一个显示的默认构造方法,所以以下语句Sample3 s3=new Sample3();合法。三、实例方法和构造方法中this、super的使用."this"的用法实例方法中可以使用this关键字,它指向正在执行方法的类的实例对象,当然static方法中是不可以使用this对象的,因为静态方法不属于类的实例对象;而构造方法中同样可以使用this关键字,构造器中的this是指向同一个对象中不同参数的另一个构造器。让我们来看下面的一段代码:public class Platypus {String name;Platypus(String input) {name = input;}Platypus() {this("John/Mary Doe");}public static void main(String args[]) {Platypus p1 = new Platypus("digger");Platypus p2 = new Platypus();System.out.println(p1.name + "----" + p2.name);}}上面的代码中 类有两个构造器,第一个构造器给类的成员name赋值,第二个构造器调用第一个构造器给类的成员name一个初始值Jonn/Mary Doe所以程序执行结果:digger----John/Mary Doe需要注意的两个地方是:1、构造方法中通过this关键字调用其他构造方法时,那么这句代码必须放在第一行,否则会编译错误。2、构造方法中只能通过this调用一次其他的构造方法。"super"的用法:实例方法和构造方法中的super关键字都用于去指向父类,实例方法中的super关键字是去调用父类当中的某个方法,看下面的代码:class getBirthInfo {void getBirthInfo() {System.out.println("born alive.");}}class Platypus1 extends getBirthInfo{void getBirthInfo() {System.out.println("hatch from eggs");System.out.println("a mammal normally is ");super.getBirthInfo();}}public class test1 {public static void main(String[] args) {Platypus1 p1=new Platypus1();p1.getBirthInfo();}}上面的例子使用super.getBirthInfo();调用了它的父类的void getBirthInfo()方法。构造器中使用super关键字调用父类中的构造器,看下面的代码:class getBirthInfo {getBirthInfo(){System.out.println("auto");}void aa() {System.out.println("born alive.");}}class Platypus1 extends getBirthInfo{Platypus1() {super();System.out.println("hatch from eggs");System.out.println("a mammal normally is ");}}public class test1 {&nbs补充:软件开发 , Java ,
上一个:Spring tool suite编译不通过:Access restriction: The type XXX is not accessible
下一个:java nio实现非阻塞Socket通信实例
- 更多JAVA疑问解答:
- java怎么在线读取ftp服务器上的文件内容
- 关于程序员的职业规划
- HTML和JSP矛盾吗?
- java小程序如何打包?
- java怎么split路径文件名?
- jsp+javaBean中Column 'ordersPrice' specified twice的错误
- Java TCP/IP Socket网络编程系列
- 大家来讨论一下我到底该用什么好?Swing 还是 JavaFX
- 关于Hibernate实体自身多对一的抓取问题
- 关于apache2+tomcat群集出现的问题
- spring 获取上下文问题
- SSH 导入导出excel 谁有这块的资料吗?
- Ext TreePanel 刷新问题
- springmvc 加载一个jsp页面执行多个方法 报404
- checkbox数组action怎么向页面传值