56 主子线程循环执行

public class Demo {
    public static Object o = new Object();
    public static boolean flag = true;

    public static void main(String[] args) {
        Thread sub = new Thread(new Sub());
        sub.start();
        mainRun();
    }

    public static void mainRun() {
        try {
            for (int i = 1; i <= 5; i++) {
                mainExec(i);
                Thread.sleep(1000);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void mainExec(int num) throws Exception {
        synchronized (o) {
            if (flag) {
                o.wait();
            }
            for (int i = 1; i <= 20; i++) {
                System.out.println(String.format("main-第%s次--%s", num + "", i + ""));
            }
            flag = true;
            o.notify();
        }

    }

    static class Sub extends Thread {
        public void run() {
            try {
                for (int i = 1; i <= 5; i++) {
                    subExec(i);
                    Thread.sleep(1000);
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

        public void subExec(int num) throws Exception {
            synchronized (o) {
                if (!flag) {
                    o.wait();
                }
                for (int i = 1; i <= 10; i++) {
                    System.out.println(String.format("sub-第%s次--%s", num + "", i + ""));
                }
                flag = false;
                o.notify();
            }

        }
    }

}
时间: 2024-10-29 09:28:06

56 主子线程循环执行的相关文章

delphi.thread.线程循环执行体结构

线程话题太大,又都是些坑,不知从哪方面讲起,所以,想一出是一出了. 不管怎样,我们从开始使用D,不管有没有用线程,其实它已经帮我们做了一个最完整的线程执行处理:Application.Run. 这行App.Run,在dpr,想来各位都经常能够看到,如果跟踪下去,我们就会发现,它其实就是一个最完整的线程执行体的结构了: 我将里面一些代码删除掉了,再将HandleMessage的代码复制过来,然后,代码如下: procedure TApplication.Run; var Msg: TMsg; be

Qt 的线程与事件循环——可打印threadid进行观察槽函数到底是在哪个线程里执行,学习moveToThread的使用)

周末天冷,索性把电脑抱到床上上网,这几天看了 dbzhang800 博客关于 Qt 事件循环的几篇 Blog,发现自己对 Qt 的事件循环有不少误解.从来只看到现象,这次借 dbzhang800 的博客,就代码论事,因此了解到一些 Qt 深层的实现,虽然是在 Qt 庞大的构架里只算的是冰山的一角,确让人颇为收益. 从 dbzhang800 的博客中转载两篇关于事件循环的文章,放在一起,写作备忘. 再次提到的一点是:事件循环和线程没有必然关系. QThread 的 run() 方法始终是在一个单独

面试题,子线程10次子线程2执行20次与主线程100次来回循环执行50次

// 面试题,子线程2执行10次子线程2执行20次 与主线程100次来回循环执行50次 public class interview { public static void main(String[] args) { final Business b = new Business(); new Thread(new Runnable(){ @Override public void run() { for (int i = 1; i <= 50; i++) { b.sub2(i); } } }

java三线程循环有序打印ABC

迅雷笔试题: 编写一个程序,开启3个线程,这3个线程的ID分别为A.B.C,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示:如:ABCABC….依次递推. 解决思路:每个线程运行时先检查他依赖的线程是否已完成工作,线程B依赖线程A的完成,线程C依赖线程B和线程A的完成,线程A依赖线程C的完成.如果当前线程依赖的线程没有执行完,则阻塞当前线程直到条件满足再执行. Condition.await()会使当前线程暂时阻塞,并释放ReentrantLock锁. Conditi

java中等待所有线程都执行结束

转自:http://blog.csdn.net/liweisnake/article/details/12966761 今天看到一篇文章,是关于java中如何等待所有线程都执行结束,文章总结得很好,原文如下http://software.intel.com/zh-cn/blogs/2013/10/15/java-countdownlatchcyclicbarrier/?utm_campaign=CSDN&utm_source=intel.csdn.net&utm_medium=Link&a

子线程循环 10 次,接着主线程循环 100,接着又回到子线程循环 10 次, 接着再回到主线程又循环 100,如此循环 50 次

子线程循环 10 次,接着主线程循环 100,接着又回到子线程循环 10 次, 接着再回到主线程又循环 100,如此循环 50 次 1 package TestThread; 2 3 /** 4 * 子线程循环 10 次, 接着主线程循环 100, 接着又回到子线程循环 10 次, 接着再回到主线程又循环 100, 如此循环 50 次 5 * 6 * @author trfizeng 7 * 8 */ 9 public class ThreadTest { 10 static int round

Qt中暂停线程的执行

在线程中定义一个信号量 QMutex pause; 把run()函数中循环执行的部分用信号量pause锁住: void run() { while(1) { pause.lock(); //循环执行的内容,比如视频播放 pause.unlock(); } } 在主线程(UI线程)中,如果想暂停线程执行,就将pause加锁: thread->pause.lock(); //thread是线程指针 如果想继续线程,就将pause解锁: thread->pause.unlock();

Qt中暂停线程的执行(利用QMutex,超级简单明了)

在线程中定义一个信号量: QMutex pause;把run()函数中循环执行的部分用信号量pause锁住: void run() { while(1) { pause.lock(); //循环执行的内容,比如视频播放 pause.unlock(); } } 在主线程(UI线程)中,如果想暂停线程执行,就将pause加锁: thread->pause.lock(); //thread是线程指针如果想继续线程,就将pause解锁:thread->pause.unlock(); http://ww

Java知多少(56)线程模型

Java运行系统在很多方面依赖于线程,所有的类库设计都考虑到多线程.实际上,Java使用线程来使整个环境异步.这有利于通过防止CPU循环的浪费来减少无效部分. 为更好的理解多线程环境的优势可以将它与它的对照物相比较.单线程系统的处理途径是使用一种叫作轮询的事件循环方法.在该模型中,单线程控制在一无限循环中运行,轮询一个事件序列来决定下一步做什么.一旦轮询装置返回信号表明,已准备好读取网络文件,事件循环调度控制管理到适当的事件处理程序.直到事件处理程序返回,系统中没有其他事件发生.这就浪费了CPU