多线程c语言面试题,多线程面试题_c#多线程面试题_c 多线程面试题

第二题,解法二,是可以换成if的吧。

因为休眠了,没有人唤醒是不会起来的。

这里又是精确唤醒。上一家只有自己的完全搞定了才会来唤醒。

搂主的第二种思路具有很高的研究价值

对于第一种方法,我这里有个思路要简单些,这个题目其实是3个运行中的线程,在某一个时刻只有一是可以打印数字的,其他2个都必须是等待状态。给每一个线程一个id,state表示打印序列,75/5/3,可以得出来共有15个打印序列,如果state%3==id,表示当前线程可以打印,否则必须等到一个可打印的序列完成才可以进行下一轮循环。那么可以在方法级上用synchronized关键字声明。虽然有线程竞争的情形出现,但不会出现思锁。

class NumberPrinter extends Thread {

static int c = 0;

static int state = 0;

private int id;

@Override

public synchronized void run() {

while (state < 15) {

if (state % 3 == id) {

for (int j = 0; j < 5; j++) {

c++;

System.out.format("Thread %d: %d %n", id, c);

}

state++;

}

}

}

public NumberPrinter(int id) {

this.id = id;

}

public static void main(String[] args) {

for (int i = 0; i < 3; i++) {

new NumberPrinter(i).start();

}

}

}

这段代码有问题,会产生死循环。可以把state 变量改为 volatile state

搂主的第二种思路具有很高的研究价值

对于第一种方法,我这里有个思路要简单些,这个题目其实是3个运行中的线程,在某一个时刻只有一是可以打印数字的,其他2个都必须是等待状态。给每一个线程一个id,state表示打印序列,75/5/3,可以得出来共有15个打印序列,如果state%3==id,表示当前线程可以打印,否则必须等到一个可打印的序列完成才可以进行下一轮循环。那么可以在方法级上用synchronized关键字声明。虽然有线程竞争的情形出现,但不会出现思锁。

class NumberPrinter extends Thread {

static int c = 0;

static int state = 0;

private int id;

@Override

public synchronized void run() {

while (state < 15) {

if (state % 3 == id) {

for (int j = 0; j < 5; j++) {

c++;

System.out.format("Thread %d: %d %n", id, c);

}

state++;

}

}

}

public NumberPrinter(int id) {

this.id = id;

}

public static void main(String[] args) {

for (int i = 0; i < 3; i++) {

new NumberPrinter(i).start();

}

}

}

本文来自电脑杂谈,转载请注明本文网址:

http://www.pc-fly.com/a/jisuanjixue/article-35308-1.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值