构造方法与方法的区别详解_构造方法和普通方法之间的区别-程序员宅基地

技术标签: 笔记  java  

 

结论!!!

学生类当中虽然没有构造方法 但是测试代码当中Student对象也创建完成了。是因为当类中没有任何构造方法的时候系统默认构造一个无参数的构造方法 

构造方法和普通方法结构的区别如下:

 [修饰符列表] 构造方法名(形式参数列表){
            构造方法体;
            // 通常在构造方法体当中给属性赋值,完成属性的初始化。
        }
        注意:
            第一:修饰符列表目前统一写成:public 千万不能写成public static
            第二:构造方法名和类名必须一致
            第三: 构造方法不需要指定返回值类型,也不能写void,写的话成了普通方法。

普通方法结构为:
        [修饰符列表] 返回值类型 方法名(形式参数列表){
            方法体;
        }
        注意: 修饰符列表为: public static

调用构造方法怎么调用呢?

构造方法和普通方法调用的区别:

普通方法:

public class OOTest01
{
	public static void main(String[] args){
			// 调用普通方法
			dosome();   // 同一个类当中不用 类名.dosome(); 也可以
            

	
	// 普通方法
		public static void dosome(){
			System.out.println("dosome");
		}
}

构造方法:

使用new运算符来调用构造方法。
        语法格式:
            new 构造方法名(形式参数列表);

        // Student s =new Student();当中 Student(); 实际上是一个构造方法

学生类: 

public class Student
{
	//学号
	int no;
	//姓名
	String name;
	//年龄
	int age;

	//当前的Student这个类当中并没有定义任何构造方法
	//但是系统会默认的给Student类提供一个无参数的构造方法

	// 将无参数的构造方法(缺省构造器)写出来如下:
	public Student(){
		System.out.println("无参数构造方法执行了~");
	}

}

测试代码:

public class OOTest01
{
	public static void main(String[] args){
			// 调用构造方法
			new Student();	// 第一次执行
			
			// 调用普通方法
			dosome();

		// 创建Student类型的对象
		Student s =new Student();	// 第二次执行   new Student() 

		//System.out.println(s.name);   // null

		// 输出"引用s"
		// 只要输出结果不是null 说明这个对象一定是创建完成了。
	    // 输出结果: Student@15db9742
		System.out.println(s);
		}
	
	// 普通方法
		public static void dosome(){
			System.out.println("dosome");
		}
}

运行结果:

当定义一个有参数的构造方法时:

public class Student
{
	//学号
	int no;
	//姓名
	String name;
	//年龄
	int age;

	//当前的Student这个类当中并没有定义任何构造方法
	//但是系统会默认的给Student类提供一个无参数的构造方法

	//将无参数的构造方法(缺省构造器)写出来如下:
	/*
	public Student(){
		System.out.println("无参数构造方法执行了~");
	}
	*/

	//定义一个有参数的构造方法
	public Student(int i){
		System.out.println("~");
	}
}

测试代码:

public class OOTest01
{
	public static void main(String[] args){
			// 调用构造方法
			new Student();	// 第一次执行
			
			// 调用普通方法
			dosome();

		// 创建Student类型的对象
		Student s =new Student();	// 第二次执行   new Student() 

		// 只要输出结果不是null 说明这个对象一定是创建完成了。
	    // 输出结果: Student@15db9742
		System.out.println(s);
		}
	
	// 普通方法
		public static void dosome(){
			System.out.println("dosome");
		}
}

 运行结果如下:

 当定义一个无参数构造方法和有参数构造方法时:【类似方法重载机制】

public class Student
{
	//学号
	int no;
	//姓名
	String name;
	//年龄
	int age;

	//当前的Student这个类当中并没有定义任何构造方法
	//但是系统会默认的给Student类提供一个无参数的构造方法

	//将无参数的构造方法(缺省构造器)写出来如下:
	
	public Student(){
		System.out.println("无参数构造方法执行了~");
	}
	

	//定义一个有参数的构造方法
	public Student(int i){
		System.out.println("~");
	}
}

测试代码:

public class OOTest01
{
	public static void main(String[] args){
			// 调用构造方法
			new Student();	// 第一次执行
			
			// 调用普通方法
			dosome();

		// 创建Student类型的对象
		Student s =new Student();	// 第二次执行   new Student() 

		// 只要输出结果不是null 说明这个对象一定是创建完成了。
	    // 输出结果: Student@15db9742
		System.out.println(s);
		}
	
	// 普通方法
		public static void dosome(){
			System.out.println("dosome");
		}
}

运行结果:

 当给测试代码Student();传参数时:

public class OOTest01
{
	public static void main(String[] args){
			// 调用构造方法
			new Student(100);	// 第一次执行
			
			// 调用普通方法
			dosome();

		// 创建Student类型的对象
		Student s =new Student(100);	// 第二次执行   new Student() 

		// 只要输出结果不是null 说明这个对象一定是创建完成了。
	    // 输出结果: Student@15db9742
		System.out.println(s);
		}
	
	// 普通方法
		public static void dosome(){
			System.out.println("dosome");
		}
}

运行结果:

 思考:【以后尽量把无参数构造方法写出来】

    1、思考:实例变量没有手动赋值的时候,实际上系统会默认赋值,
    那么这个默认赋值操作是在什么时间进行的?
        是在类加载的时候给这些实例变量赋值的吗?
            不是(类加载发生在方法区 这时候还没有在堆区new一个对象)
            实例变量是在构造方法执行的过程中完成初始化的,完成赋值的。
            【因为当new对象时 如new Student(); Student();实际上是一个构造方法】

public class User
{
	int id;
	String name;
	int age;
	
	// 无参数构造方法
	public User(){
		//这里实际上有三行代码你看不见。
		//无参数构造方法体当中虽然什么代码都没写,
		//但是实际上是在这个方法体里面进行的实例变量默认值初始化(实例变量可进行修改)
		/*
		id =0;
		name ="junker";
		age =0;
		*/
	}

	// 有参数构造方法
	public User(int i){
		/*
		id =0;
		name =null;
		age =0;
		*/
	}
}
public class OOTest02
{
	public static void main(String[] args){
		
		User u =new User();
		System.out.println(u.name);//junker
		User a =new User(100);
		System.out.println(a.name);//null
	}
}

构造方法代码演练

public class Vip
{
	//会员号
	long no;
	//会员姓名
	String name;
	//生日
	String birth;
	//性别
	boolean sex;

	//无参数构造方法
	public Vip(){
		
	}
	
	//有参数构造方法
	public Vip(long huiyuanHao){
		no =huiyuanHao;
		//默认name =null;birth =null;sex =false; 
		
	}
	public Vip(long huiyuanHao,String xingMing){
		no =huiyuanHao;
		name =xingMing;
	}
	public Vip(long huiyuanHao,String xingMing,String shengRi){
		no =huiyuanHao;
		name =xingMing;
		birth =shengRi;
	}
	public Vip(long huiyuanHao,String xingMing,String shengRi,boolean xingBie){
		no =huiyuanHao;
		name =xingMing;
		birth =shengRi;
		sex =xingBie;
	}	
}
public class OOTest03
{
	public static void main(String[] args){
		
		Vip v1 =new Vip();
		System.out.println(v1.no);//0
		System.out.println(v1.name);//null
		System.out.println(v1.birth);//null
		System.out.println(v1.sex);//false

		Vip v2 =new Vip(11111L);
		System.out.println(v2.no);//11111L
		System.out.println(v2.name);//null
		System.out.println(v2.birth);//null
		System.out.println(v2.sex);//false

		Vip v3 =new Vip(22222L,"小绵羊");
		System.out.println(v3.no);//22222L
		System.out.println(v3.name);//小绵羊
		System.out.println(v3.birth);//null
		System.out.println(v3.sex);//false

		Vip v4 =new Vip(33333L,"大灰狼","60-6-6");
		System.out.println(v4.no);//33333L
		System.out.println(v4.name);//大灰狼
		System.out.println(v4.birth);//60-6-6
		System.out.println(v4.sex);//false

		Vip v5 =new Vip(44444L,"钢铁侠","10-1-1",false);
		System.out.println(v4.no);//44444L
		System.out.println(v4.name);//钢铁侠
		System.out.println(v4.birth);//10-1-1
		System.out.println(v4.sex);//false
		
	}
}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lwj_07/article/details/123149255

智能推荐

Hibernate(映射继承关系、 Hibernate 检索策略、Hibernate 检索方式HQL (迫切)左外连接HQL (迫切)内连接QBC 检索和本地 SQL 检索二级缓存,管理session_hql 非空约束-程序员宅基地

文章浏览阅读203次。上一篇映射继承关系Hibernate支持三种继承映射策略:使用 subclass 进行映射:将域模型中的每一个实体对象映射到一个独立的表中,也就是说不用在关系数据模型中考虑域模型中的继承关系和多态。使用 joined-subclass 进行映射: 对于继承关系中的子类使用同一个表,这就需要在数据库表中增加额外的区分子类类型的字段。使用 union-subclass 进行映射:域模型中的每个类映射到一个表,通过关系数据模型中的外键来描述表之间的继承关系。这也就相当于按照域模型的结构来建立数据库中的_hql 非空约束

软件卸载不掉的解决办法_xsplit vcam 卸载不了-程序员宅基地

文章浏览阅读9.7k次,点赞4次,收藏9次。文章目录背景卸载软件正确步骤总结扩展文档卸载一个软件,倒腾了半天,说出来连我自己都不信。下面记录下卸载软件流程,以及遇到的问题解决办法,希望对遇到问题的同仁有帮助和建议参考。背景在自己的办公电脑上安装了一个老版本的软件A,后来由于产品变更,需要更新软件A到最新的版本。我是直接在安装新版本的软件A,提示“this update is not valid”,我就傻逼兮兮的,直接删掉老版本的软..._xsplit vcam 卸载不了

在 CentOS7 下安装 Cadence IC验证平台 INCISIVE152_cadence incisive-程序员宅基地

文章浏览阅读1.8w次,点赞18次,收藏122次。前言本文所使用的软件虚拟机软件:VMware Workstation 15 PRO 如何安装?操作系统:CentOS-7, CentOS-7-x86_64-DVD-1810.iso 如何安装?简介INCISIVEIncisive是nc_verilog, nc_sim, nc_lauch,以及ABV,TBV的集合,用于仿真和验证。InstallScapeInstallSc..._cadence incisive

CEF中JavaScript与C++交互_duilib使用封装cef的js和c++交互-程序员宅基地

文章浏览阅读4.3w次,点赞12次,收藏62次。在CEF里,JS和Native(C/C++)代码可以很方便的交互,我实现了一个简单的交互示例。_duilib使用封装cef的js和c++交互

STM32接GSM模块(只用TX RX)_32板子上连接gsm模块的串口是哪个-程序员宅基地

文章浏览阅读5.5k次,点赞2次,收藏9次。这几天尝试了下STM32的USART3去接gsm模块。整了好久没整出来,甚是纠结。途中遇到两个问题:1.USART3配置问题 2.接线问题USART3也是重映射到PC10 PC11这两个口的,所以要有GPIO_PinRemapConfig(GPIO_PartialRemap_USART3, ENABLE);其实最主要的问题就是接线问题,即模块电压和MCU电压不一样。我的GSM模块_32板子上连接gsm模块的串口是哪个

阅读笔记-HTTP返回状态码-程序员宅基地

文章浏览阅读124次。HTTP返回状态码1 HTTP超文本协议HTTP是基于客户端/服务端(C/S)的框架模型,通过一个可靠的链接来交换信息,是一个无状态的请求/响应协议。一个HTTP“客户端”是一个应用程序(Web浏览器或其他任何客户端),通过连接到服务器达到向服务器发送一个或多个HTTP请求的目的。一个HTTP“服务器”同样也是一个应用程序(通常是一个Web服务,如Apache Web服务器或IIS服务器..._nginx 请求头太大(nginx) nginx 内置代码和 431 类似。

随便推点

spring数据源配置:Tomcat/weblogic数据源切换配置_tomcat 数据库切换-程序员宅基地

文章浏览阅读1.4k次。数据配置方式一般是三种:1.org.springframework.jdbc.datasource.DriverManagerDataSource(没有池概念,有连接就建立一个connection)2.org.apache.commons.dbcp.BasicDataSource(连接池技术)3.org.springframework.jndi.JndiObjectFactoryBea..._tomcat 数据库切换

计算机组成原理 之 计算题、分析题 题解详细总结(已完结)_计算机组成原理计算题-程序员宅基地

文章浏览阅读1.7w次,点赞62次,收藏544次。第1章 计算机系统概述0、1编码第2章 存储系统磁盘存储器第6章 控制器逻辑Intel 8086 指令简介第1章 计算机系统概述0、1编码1、分别求出+1111B和-1001B的真值及其机器数的原码、反码、补码形式。答案:+1111B的真值:15原码01111 反码01111 补码01111-1001B 的真值:-9原码11001 反码10110 补码10111另一种写法:解: +1111B 真值:15D [x]原=01111B [x]反=01111B [x]补=011._计算机组成原理计算题

react-native 0.57 版本更新日志-程序员宅基地

文章浏览阅读647次。[0.57]欢迎来到React Native版本的0.57版!这个版本解决了许多问题,并有一些令人兴奋的改进。我们再次跳过了一个月发布,通过扩展发布候选阶段关注质量,并且兼容之前的版本这个版本包括599提交由73个不同的贡献者!为了响应反馈,我们准备了一个只包含用户影响的更改的变更日志。请分享您的意见,并让我们知道我们如何使这更有用,如果您对此有任何反馈,和往常一样请告知我们let us kn..._react-native 0.57版本文档

【IDEA&Eclipse快捷键对照表】_eclipse的folder对应idea的哪个-程序员宅基地

文章浏览阅读4.6k次,点赞8次,收藏44次。IDEA Comment Eclipse Comment Remark Ctrl+Alt+H 调用层次 Ctrl+Alt+H 开放的调用层次结构 Ctrl+E 展示打开的文件(快速转换编辑器) Alt+7 当前文件结构 Ctrl+O 当前文件结构 Ctrl+H 查看Java类层次结构 Ctrl+....._eclipse的folder对应idea的哪个

修改pycharm目录后,无法打开的问题!!!_为什么修改已安装的pycharm的安装路径会打不开软件-程序员宅基地

文章浏览阅读2.1k次。最近因为一些操作,想将命名不规范的pycharm安装目录的空格删掉,但是删掉以后,发现pycharm怎么也打不开了。在将脑汁都绞尽以后,参考一篇博客,终于发现了问题所在https://blog.csdn.net/weixin_45696455/article/details/106414316在看了上面一篇博客后,谢谢哥,茅塞顿开,原来是我破解的.vmoption文件问题,里面写了破解包路径,一旦修改pycharm路径后,将无法找到该破解包。但当我在文件夹打开.vmoption文件以后,发现我并没有写破_为什么修改已安装的pycharm的安装路径会打不开软件

labview中visa插件安装教程_nivisa安装教程-程序员宅基地

文章浏览阅读2.2w次,点赞7次,收藏29次。1.在NI官网下载VISA,上一篇文章中已经讲到,此处不再赘述。2.关到电脑的所有杀毒软件,非常重要。3.点击运行。4.一直点击next,在需要更改安装目录时,自己更改(最好不要安装在C盘)。5.安装结束后,在最新安装目录下查找NI-MAX。可以直接将他拖动到桌面即可。打开后查看设备与接口若发现里面含有内容,则安装成功,如下图所示。..._nivisa安装教程

推荐文章

热门文章

相关标签