您的位置:

java中输入流超时机制理解(java 超时机制实现)

本文目录一览:

java 方法 执行超时处理

java 1.5以上的Future类可以执行超时处理。

jdk1.5自带的并发库中Future类中重要方法包括get()和cancel(),get()获取数据对象,如果数据没有加载,就会阻塞直到取到数据,而 cancel()是取消数据加载。另外一个get(timeout)操作,表示如果在timeout时间内没有取到就失败返回,而不再阻塞。

代码如下:

import java.util.concurrent.Callable;

import java.util.concurrent.ExecutionException;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.TimeUnit;

import com.sun.corba.se.impl.orbutil.closure.Future;

import com.sun.corba.se.impl.orbutil.threadpool.TimeoutException;

public class ThreadTest {  

  

    public static void main(String[] args) throws InterruptedException,  

            ExecutionException {  

          

        final ExecutorService exec = Executors.newFixedThreadPool(1);  

          

        CallableString call = new CallableString() {  

            public String call() throws Exception {  

                //开始执行耗时操作  

                Thread.sleep(1000 * 5);  

                return "线程执行完成.";  

            }  

        };  

          

        try {  

            FutureString future = exec.submit(call);  

            String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); //任务处理超时时间设为 1 秒  

            System.out.println("任务成功返回:" + obj);  

        } catch (TimeoutException ex) {  

            System.out.println("处理超时啦....");  

            ex.printStackTrace();  

        } catch (Exception e) {  

            System.out.println("处理失败.");  

            e.printStackTrace();  

        }  

        // 关闭线程池  

        exec.shutdown();  

    }  

}

java中的输入输出流该怎么理解

 数据流是一串连续不断的数据的集合,就象水管里的水流,在水管的一端一点一点地供水,而在水管的另一端看到的是一股连续不断的水流。数据写入程序可以是一段、一段地向数据流管道中写入数据,这些数据段会按先后顺序形成一个长的数据流。对数据读取程序来说,看不到数据流在写入时的分段情况,每次可以读取其中的任意长度的数据,但只能先读取前面的数据后,再读取后面的数据。不管写入时是将数据分多次写入,还是作为一个整体一次写入,读取时的效果都是完全一样的。 

      “流是磁盘或其它外围设备中存储的数据的源点或终点。”

    在电脑上的数据有三种存储方式,一种是外存,一种是内存,一种是缓存。比如电脑上的硬盘,磁盘,U盘等都是外存,在电脑上有内存条,缓存是在CPU里面的。外存的存储量最大,其次是内存,最后是缓存,但是外存的数据的读取最慢,其次是内存,缓存最快。这里总结从外存读取数据到内存以及将数据从内存写到外存中。对于内存和外存的理解,我们可以简单的理解为容器,即外存是一个容器,内存又是另外一个容器。那又怎样把放在外存这个容器内的数据读取到内存这个容器以及怎么把内存这个容器里的数据存到外存中呢?

     在Java类库中,IO部分的内容是很庞大的,因为它涉及的领域很广泛:

         标准输入输出,文件的操作,网络上的数据流,字符串流,对象流,zip文件流等等,java中将输入输出抽象称为流,就好像水管,将两个容器连接起来。将数据冲外存中读取到内存中的称为输入流,将数据从内存写入外存中的称为输出流。

    流是一个很形象的概念,当程序需要读取数据的时候,就会开启一个通向数据源的流,这个数据源可以是文件,内存,或是网络连接。类似的,当程序需要写入数据的时候,就会开启一个通向目的地的流。

求java输入流输出流通俗解释

在程序中 输入流是用来读(读是读到程序)数据的:也就是说从外部读取数据到程序中(例如:从你电脑中的文件中读入一些数据到程序中;从键盘输入一些数据到程序中) 输出流是用来写数据的:也就是说从程序中把数据传到外部(例如:把程序中得到的数据放在一个电脑中指定的文件中; 把程序运行的结果显示在屏幕上) 不要被读 和写弄混淆 记住 读是读入到程序中 写是写入到外部(程序外)中

怎么理解Java的输入输出流?

输入输出是相对内存来说的,比方说,你站在内存的角度来看,有数据读进内存就是输入,数据被从内存取出就是输出,至于流是数据的一种形式不懂就去看看数据结构的书,知道这个答复不能利你满意,只是想让你找着方向而已,我以前也迷糊了好长时间……