我是靠谱客的博主 粗暴御姐,最近开发中收集的这篇文章主要介绍Java踩坑记录,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  • 类的构造函数默认没有返回值(或者认为是本类实例的引用,使用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踩坑记录所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部