Java 多线程程序。java先执行主程序,并行执行线程?调用线程的结果是空

Java 多线程程序。java先执行主程序,并行执行线程?调用线程的结果是空,第1张

java创建的线程在调用start方法后,进入就绪状态,但通常不会马上分配到CPU,处于线程就绪队列,需要等待时间片轮转到该线程获得CPU后才能执行。

如果你需要先执行新的线程,可以使用Thread类的join方法来等待该线程终止后,再继续往下执行,下面举个代码例子:

public class Test {

 int i = 0

 public static void main(String[] args) {

  Test test = new Test()

  MyThread1 myThread = new MyThread1(test)

  Thread thread = new Thread(myThread)

  thread.start()

  try {

   thread.join()//如果不调用此方法,打印结果为0

  } catch (InterruptedException e) {

   // TODO Auto-generated catch block

   e.printStackTrace()

  }

  System.out.println(test.i)

 }

}

class MyThread1 implements Runnable{

 

 Test test

 public MyThread1(Test test){

  this.test = test

 }

 @Override

 public void run() {

  test.i = 1 

 }

}

首先,java里的线程没有主和子的说法,只有线程优先级的说法,也许你说的是进程和线程吧,下面是详细资料

线程是指进程内的一个执行单元,也是进程内的可调度实体.与进程的区别:

(1)地址空间:进程内的一个执行单元进程至少有一个线程它们共享进程的地址空间而进程有自己独立的地址空间

(2)资源拥有:进程是资源分配和拥有的单位,同一个进程内的线程共享进程的资源

(3)线程是处理器调度的基本单位,但进程不是.

(4)二者均可并发执行.

进程和线程都是由 *** 作系统所体会的程序运行的基本单元,系统利用该基本单元实现系统对应用的并发性。进程和线程的区别在于:

简而言之,一个程序至少有一个进程,一个进程至少有一个线程. 

线程的划分尺度小于进程,使得多线程程序的并发性高。 

另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。 

线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。 

从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但 *** 作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。

进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 

线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源. 

一个线程可以创建和撤销另一个线程同一个进程中的多个线程之间可以并发执行.


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11346955.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存