功能不同:

  构造器是为了创建一个类的实例;命名与类相同;可以有任何访问的修饰: public, protected, private或者没有修饰,不能有以下非访问性质的修饰: abstract, final, native, static, 或者 synchronized;无返回值。

  方法是为了实现类的一个动作。

以下为复制别人的博客内容:

 

"this"的用法
构造器和方法使用关键字this有很大的区别。方法引用this指向正在执行方法的类的实例。静态方法不能使用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(); 
} 
}



在上面的代码中,有2个不同参数列表的构造器。第一个构造器,给类的成员name赋值,第二个构造器,调用第一个构造器,给成员变量name一个初始值 "John/Mary Doe". 

在构造器中,如果要使用关键字this,那么,必须放在第一行,如果不这样,将导致一个编译错误。 

"super"的用法 
构造器和方法,都用关键字super指向超类,但是用的方法不一样。方法用这个关键字去执行被重载的超类中的方法。看下面的例子: 

class Mammal { 
void getBirthInfo() { 
System.out.println("born alive."); 
} 
} 

class Platypus extends Mammal { 
void getBirthInfo() { 
System.out.println("hatch from eggs"); 
System.out.print("a mammal normally is "); 
super.getBirthInfo(); 
} 
}



在上面的例子中,使用super.getBirthInfo()去调用超类Mammal中被重载的方法。 

构造器使用super去调用超类中的构造器。而且这行代码必须放在第一行,否则编译将出错。看下面的例子: 

public class SuperClassDemo { 
SuperClassDemo() {} 
} 

class Child extends SuperClassDemo { 
Child() { 
super(); 
} 
}



在上面这个没有什么实际意义的例子中,构造器 Child()包含了 super,它的作用就是将超类中的构造器SuperClassDemo实例化,并加到 Child类中。 

编译器自动加入代码
编译器自动加入代码到构造器,对于这个,java程序员新手可能比较混淆。当我们写一个没有构造器的类,编译的时候,编译器会自动加上一个不带参数的构造器,例如:public class Example {} 
编译后将如下代码: 

public class Example { 
Example() {} 
}




在构造器的第一行,没有使用super,那么编译器也会自动加上,例如: 

public class TestConstructors { 
TestConstructors() {} 
}



编译器会加上代码,如下: 

public class TestConstructors { 
TestConstructors() { 
super; 
} 
}


仔细想一下,就知道下面的代码 

public class Example {}



经过会被编译器加代码形如: 

public class Example { 
Example() { 
super; 
} 
}



继承

构造器是不能被继承的。子类可以继承超类的任何方法。看看下面的代码: 

public class Example { 
public void sayHi { 
system.out.println("Hi"); 
} 

Example() {} 
} 

public class SubClass extends Example { 
}



类 SubClass 自动继承了父类中的sayHi方法,但是,父类中的构造器 Example()却不能被继承。