java轮询3次查询接口_Java 使用轮询获取线程返回数据

本文介绍了在Java中如何通过轮询方式等待多线程任务完成并获取结果,讨论了轮询的简单实现以及其性能浪费的问题,并强调了这种做法通常不被推荐。
摘要由CSDN通过智能技术生成

1. 多线程的特点

一般程序中,只有一个主线程,自上而下顺序执行。

但是多线程程序中,多个线程的执行是并发的,程序员无法在设计时预测各个线程的执行结束时间。

看下面的线程类,用来读取文件大小,然后把结果放到线程局部变量中。

/**

* 读取文件大小

*/

public

class

ReadFileRunnable

implements

Runnable {

/**

* 文件名

*/

private String fileName;

public

ReadFileRunnable

(String fileName){

this.fileName = fileName;

}

/**

* 文件大小,默认为-2

*/

private

long length =

-2;

public

long

getLength

(){

return length;

}

@

Override

public

void

run

(){

File f =

new File(fileName);

if (f.exists() && f.isFile()) {

this.length = f.length();

}

else {

this.length =

-1;

// 文件不存在

}

}

}

如果按照一般的思维,我们先启动线程获取文件大小,然后输出文件大小。

public

static

void

main

(String[] args){

// 启动线程

ReadFileRunnable writeFileRunnable = new ReadFileRunnable("D:\\temp\\1.txt");

Thread thread = new Thread(writeFileRunnable);

thread.start();

// 输出结果

System.out.println("length:" + writeFileRunnable.getLength());// 输出-2

}

运行多次,输出均为-2,这是因为我们启动的线程尚未执行完成,下面输出结果的语句就已经执行了。这是因为我们启动的线程需要读取文件,属于IO操作,速度肯定是比较慢的。

effb1a92a992a957240827433996c87a.png

2. 使用轮询强制等待

最简单的解决办法,就是使用轮询,一直检查线程执行的结果。

public static void main(String[] args) {

// 启动线程

ReadFileRunnable writeFileRunnable = new ReadFileRunnable(

"D:\\temp\\1.txt");

Thread thread = new Thread(writeFileRunnable);

thread.start();

// 一直等待

while (

true) {

if (writeFileRunnable.getLength() == -

2) {

// 无结果

continue;

}

else {

System.out.println(

"length:" + writeFileRunnable.getLength());

// 输出-

2

break;

// 直到获取结果结束,此时可以输出文件大小

}

}

}

3. 轮询的弊端

使用轮询,看似解决了问题,但是实际上非常浪费性能。我们测试下:

public static void main(String[] args) {

// 启动线程

ReadFileRunnable writeFileRunnable = new ReadFileRunnable(

"D:\\temp\\1.txt");

Thread thread = new Thread(writeFileRunnable);

thread.start();

// 一直等待

int i =

0;

while (

true) {

i++;

if (writeFileRunnable.getLength() == -

2) {

// 无结果

continue;

}

else {

System.out.println(

"循环执行次数:" + i);

// 循环执行次数

:

14365

System.out.println(

"length:" + writeFileRunnable.getLength());

// 输出-

2

break;

// 直到获取结果结束

}

}

}

也就是说,我们检查了一万多次,只有一次是有效的,这不得不说是极大的浪费啊。

4. 小结

多线程程序中,可以使用轮询获取线程返回的数据,但是非常浪费性能,这种方法一般不推荐。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值