概述
- 类的构造函数默认没有返回值(或者认为是本类实例的引用,使用new 类名()会返回一个本类实例的引用);
- private可以修饰构造函数,但一般不用于修饰类的构造函数,这会导致其他类中不能生成本类的实例(即使在同一个包中,或者使用import关键字);
- static 不能用于修饰构造函数(构造函数本身用于类实例化时自动调用,设置成static没有意义);
- void的函数修饰构造函数会引起歧义,“void 类名(){}”,void使得编译器认为"类名()"不再是构造函数(IDEA中,在主函数中实例化后,"函数名()"依然显示灰色表示没有调用),而是一个普通的实例方法,此时再用static修饰该函数,编译器不会报错;
- 构造方法可以被重载,但不能被重写(父子类名字不一样);
public ClassName {
private ClassName() {
//private 可以用于修饰构造函数,在同时拥有private ClassName()和
//ClassName()时,编译器会认为前者是构造函数,后者是成员方法;
}
/*
className() {
//构造函数;
}
void ClassName() {
//ClassName()不再是构造函数,而是普通的成员方法;
}
*/
static void ClassName() {
//编译器不会报错,这里static仅用于修饰一个成员方法;
}
}
在编写网络应用服务器端程序的时,出现错误空指针异常:java.lang.NullPointerException
package zcf.com;
import java.net.*;
public class Server extends Thread {
String str = "zcf";
int port = 9999;
InetAddress intads = null;
MulticastSocket socket = null;
//添加了void,导致Server()被视为成员方法,本类实例化的时,调用的默认构造方法,没有初始化socket,在run()线程任务中调用socket时,出现空指针异常;
void Server() {
try {
intads = InetAddress.getByName("224.255.1.0");
socket = new MulticastSocket(port);
socket.setTimeToLive(1);
socket.joinGroup(intads);
if(socket == null) {
System.out.println("null!");
}
}catch(Exception e) {
e.printStackTrace();
}
}
public void run() {
while (true) {
byte data[] = str.getBytes();
DatagramPacket dPacket = new DatagramPacket(data, data.length, intads, port);
System.out.println(str);
try {
socket.send(dPacket);
sleep(3000);
} catch (Exception e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
Server server = new Server();
server.start();
}
}
执行结果:
//报出异常;
java.lang.NullPointerException
at zcf.com.Server.run(Server.java:31)
去掉void修饰符:
//结果正常,间隔数秒发送一个信息;
zcf
zcf
最后
以上就是粗暴御姐为你收集整理的Java踩坑记录的全部内容,希望文章能够帮你解决Java踩坑记录所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复