线程的挂起join

package Thread;

import sample.Log;

/**
 * Created with IntelliJ IDEA.
 * User: shenzaih
 * Date: 13-10-16
 * Time: 下午1:55
 * 所谓的线程挂起就是指暂停执行,现在有两个线程A,B,如果在线程A中执行b.join()则a就会挂起 直到B终止
 * 线程终止
 */

class Sleeper extends Thread{
    private int duration;

    Sleeper(String name ,int duration) {
        super(name);
        this.duration = duration;
        start();
    }

    @Override
    public void run() {
        try {
            sleep(duration);
        } catch (InterruptedException e) {
            Log.d(getName()+" was interrupted ."+ "isInterrupted() = "+isInterrupted());
            return;
        }

        Log.d(getName()+" has awakened");
    }
}

class Joiner extends Thread{
    private Sleeper sleeper;

    Joiner(String name, Sleeper sleeper) {
        super(name);
        this.sleeper = sleeper;
        start();
    }

    @Override
    public void run() {
        try {
            sleeper.join();
        } catch (InterruptedException e) {
            Log.d("interrupted");
        }
        Log.d(getName()+" join completed");
    }
}
public class Joining {
    public static void main(String s[]){

        Sleeper sleepy = new Sleeper("Sleepy",3000),
                grumpy = new Sleeper("grumpy",3000);
        Joiner dopey = new Joiner("Dopey",sleepy),
                doc = new Joiner("Doc",grumpy);
        grumpy.interrupt();
    }

}

//   output:
//    grumpy was interrupted .isInterrupted() = false
//Doc join completed
//        Sleepy has awakened
//        Dopey join completed


下面是一个简单的 C++ 线程加锁让线程挂起的示例: ```cpp #include <iostream> #include <thread> #include <mutex> #include <chrono> std::mutex mtx; void func() { std::cout << "Thread starts" << std::endl; mtx.lock(); std::cout << "Thread is locked" << std::endl; std::this_thread::sleep_for(std::chrono::seconds(5)); // 让线程挂起 5 秒 mtx.unlock(); std::cout << "Thread is unlocked" << std::endl; } int main() { std::thread t(func); std::this_thread::sleep_for(std::chrono::seconds(1)); // 让主线程挂起 1 秒,确保子线程已经开始执行 mtx.lock(); // 主线程加锁 std::cout << "Main thread is locked" << std::endl; std::this_thread::sleep_for(std::chrono::seconds(5)); // 让主线程挂起 5 秒 mtx.unlock(); std::cout << "Main thread is unlocked" << std::endl; t.join(); // 等待子线程执行结束 return 0; } ``` 这个程序会创建一个子线程,在子线程中调用 `mtx.lock()` 加锁,然后调用 `std::this_thread::sleep_for(std::chrono::seconds(5));` 让线程挂起 5 秒,最后调用 `mtx.unlock()` 解锁。 在主线程中,先调用 `std::this_thread::sleep_for(std::chrono::seconds(1));` 让子线程运行一段时间,然后调用 `mtx.lock()` 加锁,也会让主线程挂起。在主线程挂起期间,子线程会被阻塞在加锁处,等待主线程释放锁。 当主线程挂起 5 秒后,调用 `mtx.unlock()` 解锁,子线程才会继续执行。最终,主线程会等待子线程执行结束,然后程序退出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值