[code=Java]
public class file
{
public static void main(String[] args)throws Exception
{
byte[] by=new byte[1024];
int len=0;
FileInputStream fis=new FileInputStream("e:\\123.txt");
FileOutputStream fos=new FileOutputStream("d:\\IO\\file.txt");

while(true)
{
len=fis.read(by,0,by.length);
fos.write(by,0,len);
if(len==-1)
{
break;
}
}
}
}  
code]public int read(byte[] b,int off,int len):从此输入流中将最多 len 个字节的数据读入一个 byte 数组中。如果 len 不为 0,则在输入可用之前,该方法将阻塞;否则,不读取任何字节并返回 0。 问题:为什么len不为0,在输入可用之前,该方法将阻塞.否则,不读取任何字节返回0呢?
上面程序中的by字节数组的length是1024.在len=fis.read(by,0,by.length);写的是by.length就能运行,如果写的是len就阻塞了,为什么呢?by.length也是不为0呀!

解决方案 »

  1.   

    不知你这句话从哪看到的?
    API中是这样定义的
    从此输入流中将最多 len 个字节的数据读入一个字节数组中。在某些输入可用之前,此方法将阻塞。 
    返回:
    读入缓冲区的字节总数,如果因为已经到达文件末尾而没有更多的数据,则返回 -1。 如果写len就阻塞了?什么地方写len?len=fis.read(by,0,len);这样写吗?
    你这样写的话,由于初始len为0,你每次读取0个字符,循环,自然阻塞了
      

  2.   

    public int read(byte[] b,int off,int len): 
    如果 len 为 0,则不读取任何字节并返回 0,因为len为0这句话的意思就是从文件中读0个字节;len不等于0时尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;
      

  3.   

    len=fis.read(by,0,by.length); 运用时正常的.
    改为
    len=fis.read(by,0,len); 也运用时阻塞了.从此输入流中将最多 len 个字节的数据读入一个 byte 数组中。如果 len 不为 0,则在输入可用之前,该方法将阻塞;否则,不读取任何字节并返回 0。(JDK API里的read方法这样说)
    len=fis.read(by,0,by.length); 写上by.length就正常了,by.length也不为0呀,怎么就不阻塞呢?
      

  4.   


    你到底明白不明白什么叫阻塞,阻塞是指一直执行read方法,直到没有可读的了
      

  5.   

    我明白了.我不明白的是:
    从此输入流中将最多 len 个字节的数据读入一个 byte 数组中。如果 len 不为 0,则在输入可用之前,该方法将阻塞;否则,不读取任何字节并返回 0。
    这句话.不明白的是为什么len=fis.read(by,0,by.length); 改成 len=fis.read(by,0,len); 运行时就阻塞了.
      

  6.   

     ...  你还是不明白,改成len=fis.read(by,0,len);
    while(true) { 
       len=fis.read(by,0,len); 
       fos.write(by,0,len); 
       if(len==-1) { 
          break;
       }
    }
    一开始len=0,执行len=fis.read(by,0,len); len始终为0,也就是说你这里根本没有跳出循环的条件,这就是个死循环