多线程的陷阱

1.有一个线程类对象(通过继承Thread类来实现),如果程序从未调用过该对象的start()方法来启动它,那么这个线程对象将一直处于“新建“状态,它永远不会作为线程获得执行的机会,只是一个普通的java对象,这时,直接调用其run()方法时,与普通的java对象的普通方法并没有什么区别。

2.静态方法通过加synchronized关键字来实现同步,则此时该方法锁定的对象是当前这个类,即XXX.class,而非静态方法实现同步时,可以直接在方法上加synchronized关键字,也可以synchronized(this){}来实现,而这时,锁定的对象则是该类的一个实例对象。因此静态同步方法和以this为同步监视器的同步代码块可以并发执行。而静态同步方法和以当前类为同步监视器的同步代码块不能并发执行。

3. 每个类首先会执行main线程来进行分配内存和初始化。

转载于:https://www.cnblogs.com/zhlblogs/p/9241398.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值