java多线程运行机制
求解释:Java里是不是每个线程都有自己独立的运行空间(内存)?如果是这样,那吗mian进程出现错误之后,其他线程是不是完全不受影响呢?看下面的例子,如果我创建了更多的线...
求解释:Java里是不是每个线程都有自己独立的运行空间(内存)?如果是这样,那吗mian进程出现错误之后,其他线程是不是完全不受影响呢?看下面的例子,如果我创建了更多的线程是不是每个线程都创建了自己的r对象呢,只有这样才能保证main线程出现错误其他线程还能打印num啊?如果是这样,那么同步锁是如何保证每个线程的锁用的是同一个对象呢?
public class Threadtest
{
public static void main(String[] args)
{
int[] arr=new int[3];
Run r=new Run();
Thread t=new Thread(r);
t.start();
System.out.println(arr[3]);
}
}
class Run implements Runnable
{
private int num=5;
public void run()
{
for(int i=0;i<100;i++)
{
System.out.println("i=......"+i+"..num="+num);
}
}
} 展开
public class Threadtest
{
public static void main(String[] args)
{
int[] arr=new int[3];
Run r=new Run();
Thread t=new Thread(r);
t.start();
System.out.println(arr[3]);
}
}
class Run implements Runnable
{
private int num=5;
public void run()
{
for(int i=0;i<100;i++)
{
System.out.println("i=......"+i+"..num="+num);
}
}
} 展开
3个回答
展开全部
首先子线程不是独立的空间啊!要不也有同步锁了!
java中运行多线程时是一会运行这个线程,一会运行那个线程……随机运行的。因为运行的速度快时间短,所以就给人感觉线程是同时运行的。
只要出错了,java程序立马停止运行!
java中运行多线程时是一会运行这个线程,一会运行那个线程……随机运行的。因为运行的速度快时间短,所以就给人感觉线程是同时运行的。
只要出错了,java程序立马停止运行!
追问
完全没解答到关键点啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1、java的线程是用户级线程,在同一个进程内,没有独立的运行空间
2、如果出错,进程终止,所有的线程都没了
3、虽然每个线程都创建了自己的r对象,但不能保证main线程出现错误其他线程还能打印num,原因见上
4、用同一个对象还不容易,静态变量就可以
2、如果出错,进程终止,所有的线程都没了
3、虽然每个线程都创建了自己的r对象,但不能保证main线程出现错误其他线程还能打印num,原因见上
4、用同一个对象还不容易,静态变量就可以
追问
我上面写的程序main线程就出错了,但是子线程还在继续打印num,你没解答到关键点
追答
我说错了,主线程出错结束,子线程也不会结束。只有调用System.exit函数,退出虚拟机时,所有线程都会结束
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
main进程是顶级父进程, 如果父进程结束了, 那么由父进程派生出的子进程与线程也都会结束
追问
不对,java线程是相对独立的,你运行就知道了,我上面写的程序main线程就出错了,但是子线程还在继续,我说的是线程不是进程。。。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询