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加载时即执行,先于主方法执行,用 ...
随机推荐
- 6105 - deauth after EAPOL key exchange sequence
wifi无法连接公司的网络 Warning Error in Event Log - deauth after EAPOL key exchange sequence https://forums.i ...
- kubernetes安装部署
1.根据系统内核情况,选择对应的ali云上的镜像,作为仓库的路径指向来配置k8s https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes- ...
- Zlib not installed
若提示:zlib not installed wget http://zlib.net/zlib-1.2.8.tar.gz tar zxf zlib-1.2.8.tar.gz cd zlib- ...
- VB - 错误处理
1.最常见的错误是运行时错误,也就是说错误在脚本正在运行的时候发生,是脚本试图进行非法操作的结果.例如零被作为除数.在vbs中,任何运行时错误都是致命的,此时,脚本将停止运行,并在屏幕上显示一个错误消 ...
- Redis 系列
Redis 系列 [Redis 系列(01)安装配制] [Redis 系列(02)数据结构] [Redis 系列(03-1)进阶 - 发布订阅] [Redis 系列(03-2)进阶 - 事务] [Re ...
- js 屏蔽网页快捷键代码
<script> function KeyDown(){ //屏蔽鼠标右键.Ctrl+n.shift+F10.F5刷新.退格键 //alert("ASCII代码是:"+ ...
- 饿汉单例模式 and 懒汉单例模式
饿汉单例模式:主要就是利用static关键字,在类加载的时候生成实例,调用效率高 但是如果一直没有调用getInstance方法的话,就会造成资源浪费 具体实现如下: class Single{ pr ...
- C++中static的作用
tatic关键字有俩作用:(1).控制存储分配:(2).控制一个名字的可见性和连接. 随着C++名字空间的引入,我们有了更好的,更灵活的方法来控制一个大项目的名字增长. 在类的内部使用st ...
- 一、Redis的安装
1.下载.解压.编译.安装 # 下载地址 wget http://download.redis.io/redis-stable.tar.gz # 解压 tar xzf redis-stable.tar ...
- java 逻辑运算符
/* 与(并且) && 全部是true 否则就是false 或(或者) ||至少有一个是true ,就是true 全部是false 才是faalse 非(取反) ! 本来是true,变 ...