进程是一个可执行的应用程序,任何进程都有一个主线程作为入口,是线程的集合
多线程可以提高效率,我们在电脑操作的时候,开多个窗口,并不是多线程并发,是cpu在切换,只不过速度很快,我们感觉不到,多线程是在同一个时刻同时进行
假设你有100桶水,你一个小时能打20桶,现在我们需要你一个小时内都把这些谁打完?怎么办?这时候需要多叫几个人一起打水
1.继承thread类,实现run方法
2.匿名内部类
3.实现runable接口
4.callable
5.使用线程池创建
当我们启动多线程的时候,代码不是顺序执行,而是交替执行(异步,俩个线程互不印象),单线程是从上往下执行(同步)
class threadtest extends thread{ @override public void run() { for (int i=0;i<30;i++){ system.out.println("run:"+i); } } } public class threaddemo { public static void main(string[] args) { threadtest t1 = new threadtest(); t1.start(); for (int i = 0; i <30 ; i++) { system.out.println("main:"+i); } } }
实现runable接口
这方式比继承接口的方式要好用,因为java中是单继承,多实现的方式,你如果是继承了thread类就不能在继承别的类了
class threadtest02 implements runnable{ @override public void run() { for (int i=0;i<30;i++){ system.out.println("runable:"+i); } } } public class threaddemo02 { public static void main(string[] args) { new thread(new threadtest02()).start(); for (int i = 0; i <30 ; i++) { system.out.println("main:"+i); } } }
匿名内部类的方式创建
thread t1 = new thread(new runnable() { @override public void run() { for (int i = 0; i <10 ; i++) { system.out.println("nei bu lei "+ i); } } }); t1.start(); }
如对本文有疑问, 点击进行留言回复!!
解决idea中出现“illegal character U+200B” 问题
荐 为什么加了@Transactional注解,事务没有回滚?
Attribute ‘sklearn.linear_model._logistic.LogisticRegression.multi_class‘ must be explicitly set to
Java/Python实现 LeetCode剑指Offer 14-I.剪绳子(动态规划)
网友评论