main()和代码块
main方法
* main()方法的使用说明
* main方法是程序的主入口(一个主程序 先从main开始进行执行)
*
*
* main方法也可以是一个普通的静态方法
由于Java虚拟机需要调用类的main()方法,所以该方法的访问权限必须是 public,又因为Java虚拟机在执行main()方法时不必创建对象,所以该方法必须 是static的,该方法接收一个String类型的数组参数,该数组中保存执行Java命令
时传递给所运行的类的参数。
又因为main() 方法是静态的,我们不能直接访问该类中的非静态成员,必须创
建该类的一个实例对象后,才能通过这个对象去访问类中的非静态成员,这种情
况,我们在之前的例子中多次碰到。
代码块
代码块也是类的成员变量之一, 分为静态代码块和非静态代码块
static{ // 静态代码块
}
//非静态代码块
{
}
* 类的成员之四: 代码块(或初始化代码块) 类的成员: 属性 方法 ,构造器 ,代码块
* <p>
* <p>
* 1. 代码块的作用: 用来初始化类或对象
* 2. 代码块如果有修饰的话, 只能使用static
* 3. 分类: 静态代码块,非静态代码块
eg:
public class CodeBlock {
public static void main(String[] args) {
String desc = BlockPerson.desc; // 当我是静态代码块
BlockPerson blockPersonOnew = new BlockPerson(); //我是非静态代码块
}
}
class BlockPerson {
String name;
int age;
static String desc = "我是一个人";
//构造器
public BlockPerson() {
}
public BlockPerson(String name, int age) {
this.name = name;
this.age = age;
}
//代码块
static{ //静态代码块 随着类的加载而加载
System.out.println("我是静态代码块");
}
{ //非静态代码块
System.out.println("我是非静态代码块");
}
@Override
public String toString() {
return "Person[ name:"+name+"age:"+age+"]";
}
public static void info(){
System.out.println("我是一个人");
}
}
非静态代码块可调用静态的方法和属性
{ //非静态代码块
System.out.println("我是非静态代码块");
age = 1;
desc = "我是一个爱学习的人"; //非静态代码块可以调用静态结构
info();
}
静态代码块和非静态代码块的区别
4. 静态代码:
* > 内部可以有输出语句
* > 随着类的加载而执行,而且只执行一次
* > 初始化类的属性
* > 如果一个类中定义了多个静态代码块,按照声明的先后顺序执行
* > 静态代码块的执行要优先于非静态代码块执行(因为静态代码块是随着类的加载而执行,非静态是需要对象实例化后执行的)
* >静态代码块内只能调用静态的属性和方法 不能调用非静态的 * 5. 非静态代码块
* > 内部可以有输出语句
* > 随着对象的创建而执行
* > 每创建一个对象就执行一次非静态代码块,只要类不重新加载就不会重新执行
* > 作用: 可以在创建对象是 对对象的属性赋值
* > 可以调用静态和非静态的属性和方法
对象赋值的方法:
对象赋值的方法: * 对属性可以赋值的位置:
* 1. 默认初始化
* 2. 显示初始化 / 5. 在代码块中赋值(谁先写就先赋值谁)
* 3. 构造器初始化
* 4. 有了对象之后, 可以通过"对象.属性" 或" 对象.方法" 赋值
顺序是: 1 >2 /5 > 3 >4
eg:
public class OrderTest {
public static void main(String[] args) {
Rder rder = new Rder();
System.out.println(rder.age); //
}
}
class Rder{
int age = 3; // 显示赋值
{
age = 4;
}
}
对象赋值的
面试题:
此处,Something类的文件名叫OtherThing.java
class Something {
public static void main(String[] something_to_do) {
System.out.println("Do something ..."); }
}
上述程序是否可以正常编译、运行?
结果:
可以编译运行,只不过无法输出语句 因为主类没有main方法主类没有执行
结果
练习题:
说出以下内容的执行结果:
class Person {
public static int total;
static {
total = 100;
System.out.println("in static block!"); }
}
public class PersonTest {
public static void main(String[] args) {
System.out.println("total = " + Person.total);
System.out.println("total = " + Person.total);
} }
结果:
因为静态代码块是随着类的加载而执行 因为类的加载优先于对象的创建 所以先执行静态代码块中的输出语句,然后再输出下面对面的调用的属性
in static block
total=100
total=100
结果
下面题目的输出是:
//总结: 由父及子,静态先行
public class LeftTest {
public static void main(String[] args) {
new Left();
}
}
class Root {
static {
System.out.println("我是Root的静态代码块");
}
{
System.out.println("我是Root的非静态代码块");
}
public Root() {
System.out.println("我是Root的无参构造器");
}
}
class Mid extends Root{
static {
System.out.println("我是Mid的静态代码块");
}
{
System.out.println("我是Mid的非静态代码块");
}
public Mid() {
System.out.println("我是Mid的无参构造器");
}
public Mid(String msg){
this();
System.out.println("Mid的参数构造器,参数是:msg:"+msg);
}
}
class Left extends Mid {
static {
System.out.println("我是Left的静态代码块");
}
{
System.out.println("我是left的非静态代码块");
}
public Left() {
System.out.println("我是left的无参构造器");
}
public Left(String msg){
super();
System.out.println("我是Left的参数构造器,参数是msg:"+msg);
}
}
结果:
* 我是Root的静态代码块
* 我是Mid的静态代码块
* 我是Left的静态代码块
* 我是Root的非静态代码块
* 我是Root的无参构造器
* 我是Mid的非静态代码块
* 我是Mid的无参构造器
* 我是left的非静态代码块
* 我是left的无参构造器
结果
下面的输出是:
class FatherTest {
static {
System.out.println("111111");
}
{
System.out.println(22222);
}
public FatherTest() {
System.out.println(33333);
}
}
public class SonTest extends FatherTest {
static {
System.out.println("44444444");
}
{
System.out.println("55555555");
}
public static void main(String[] args) {
System.out.println("777777777");
System.out.println("**********");
new SonTest();
System.out.println("+++++++++++");
new SonTest();
System.out.println("========");
new FatherTest();
}
}
结果:
111111
44444444
777777777
**********
22222
33333
55555555
+++++++++++
22222
33333
55555555
========
22222
33333
main()和代码块的更多相关文章
- 静态代码块,构造代码块,main()
静态代码块 随Class 加载而加载,为Class 作初始化: 在main() 之前加载: 只执行一次: 构造代码块 随对象的创建而加载,为对象作初始化 public class day04 { pu ...
- 关于java中普通代码块、构造代码块与静态代码块
1.普通代码块 public static void main(String[] args) { /*普通代码块: *直接定义在在方法或语句中出现”{普通代码的执行语句}“的就称为普通代码块. *普通 ...
- Java基础之数据类型、内存、修饰符、代码块
Java 数据类型 基本数据类型 数值:int.short.long 字符:char 布尔:boolean 引用数据类型 class(类) interface(接口) 数组[] 所占字节数(1 byt ...
- 10、代码块、构造代码块、静态代码块及main方法之间的关系
1.普通代码块: 在方法或语句中出现在{}之间的类容就称为普通代码块,简称代码块.普通代码块和一般的语句执行顺序由他们在代码中出现的次序决定--“先出现先执行”,即顺序执行. /*下面第一个类时合法的 ...
- 黑马程序员——JAVA基础之主函数main和静态static,静态代码块
------- android培训.java培训.期待与您交流! ---------- 主函数:是一个特殊的函数.作为程序的入口,可以被jvm调用. 主函数的定义: public:代表着该函数访问权限 ...
- JAVA之旅(五)——this,static,关键字,main函数,封装工具类,生成javadoc说明书,静态代码块
JAVA之旅(五)--this,static,关键字,main函数,封装工具类,生成javadoc说明书,静态代码块 周末收获颇多,继续学习 一.this关键字 用于区分局部变量和成员变量同名的情况 ...
- 【Java面试题】16 静态代码块,main方法,构造代码块,构造方法
public class HelloB extends HelloA{ public HelloB() { System.out.println("HelloB"); } { Sy ...
- this、static、main方法、静态代码块、final关键字、Runtime类、Cloneable类、类成员的访问控制权限、异常体系
this表示当前对象,用在方法内部,当某对象调用该方法时,该方法中的this就代表调用该方法的对象: static关键字: 修饰类属性后,该属性就成为该类所有实例的公共属性,修改该属性值,所有的实例的 ...
- java子父类初始化顺序 (1)父类静态代码块(2)父类静态变量初始化(3)子类静态代码块(4)子类静态变量初始化(5)main(6)有对象开辟空间都为0(7)父类显示初始化(8)父类构造(9)子类显示初始化(10)子类构造
标题 静态代码块与静态成员变量还要看代码的先后顺序 看程序,说出结果 结果为: x=0 看程序,说出结果 结果如下: 补充 : 静态代码块:static{ } 在JVM加载时即执行,先于主方法执行,用 ...
随机推荐
- 基础复习之HTML (doctype、标签语义化)
这段时间找实习看的眼花缭乱的,然后也被拒得落花流水,啊哈哈-还是写博客好玩儿-嘿嘿,下面正题 一.doctype 标准模式 (Full Standards Mode) 接近标准模式 (Almost S ...
- centos7下zookeeper安装配置
1.下载zookeeper文件 cd /opt/ wget http://mirrors.hust.edu.cn/apache/zookeeper/stable/zookeeper-3.4.9.tar ...
- jenkins-参数化构建插件:Choice Parameter
参考: 谢谢大佬的总结: https://www.cnblogs.com/zhaojingyu/p/9862371.html 使用方式 step1: 添加参数,选择Choice Parameter,并 ...
- jQuery:unbind方法的使用详解
一.概述: unbind方法只能解绑用jQuery的bind方法以及用jQuery方法注册的事件处理程序.比如:$(‘a’).click(function(){})可以通过unbind解绑.用原生ad ...
- Python中生成器和yield语句的用法详解
Python中生成器和yield语句的用法详解 在开始课程之前,我要求学生们填写一份调查表,这个调查表反映了它们对Python中一些概念的理解情况.一些话题("if/else控制流" ...
- 斯坦福【概率与统计】课程笔记(二):从EDA开始
探索性数据分析(Exploratory Data Analysis) 本节课程先从统计分析四步骤中的第二步:EDA开始. 课程定义了若干个术语,如果学习过机器学习的同学,应该很容易类比理解: popu ...
- java中Comparator比较器顺序问题,源码分析
提示: 分析过程是个人的一些理解,如有不对的地方,还请大家见谅,指出错误,共同学习. 源码分析过程中由于我写的注释比较啰嗦.比较多,导致文中源代码不清晰,还请一遍参照源代码,一遍参照本文进行阅读. 原 ...
- Compile Linux Kernel on Ubuntu 12.04 LTS (Detailed)
This tutorial will outline the process to compile your own kernel for Ubuntu. It will demonstrate bo ...
- [Fw] assembly code in gas syntax
Address operand syntax There are up to 4 parameters of an address operand that are presented in the ...
- ASP.NET Core 2.1 JWT Token 使用 (二) - 简书
原文:ASP.NET Core 2.1 JWT Token 使用 (二) - 简书 接上文,https://www.jianshu.com/p/c5f9ea3b4b65 ASP.NET Core 2. ...