- 浏览: 429339 次
- 性别:
- 来自: 郑州
文章分类
最新评论
-
shenselongge:
/**
* Flips this buff ...
java.nio.Buffer flip()方法jdk中文翻译错误 -
tonyyan:
感谢,清晰了很多。
java.nio.Buffer flip()方法jdk中文翻译错误 -
frangejct:
jdluojing 写道你的说法也不完整,buffer中的 ...
java.nio.Buffer flip()方法jdk中文翻译错误 -
victor0535:
关于这段话,我有不同看法:2)如果instance变量是一个对 ...
Java线程同步机制synchronized关键字的理解 -
josico:
如果没有前台页面 只是作为服务端提供HTTP接口的话 可不可以 ...
Apache与Tomcat的区别
今天在看《Java编程思想》的时候,碰到java.nio.Buffer flip()方法,不明白是干什么用的,于是就赶快查看中文API,API上面翻译的是:"反转此缓冲区。首先对当前位置设置限制,然后将该位置设置为零。如果已定义了标记,则丢弃该标记。";
说实话,看了几遍,真还不明白说的是什么意思,于是就查看英文API,是这样说的:Flips this buffer. The limit is set to the current position and then the position is set to zero. If the mark is defined then it is discarded.,意思大概是这样的:调换这个buffer的当前位置,并且设置当前位置是0。说的意思就是:将缓存字节数组的指针设置为数组的开始序列即数组下标0。这样就可以从buffer开头,对该buffer进行遍历(读取)了。
实例代码(借用Java编程思想P552的代码):
注意:buffer.flip();一定得有,如果没有,就是从文件最后开始读取的,当然读出来的都是byte=0时候的字符。通过buffer.flip();这个语句,就能把buffer的当前位置更改为buffer缓冲区的第一个位置。
说的很明白。终于懂了
说实话,看了几遍,真还不明白说的是什么意思,于是就查看英文API,是这样说的:Flips this buffer. The limit is set to the current position and then the position is set to zero. If the mark is defined then it is discarded.,意思大概是这样的:调换这个buffer的当前位置,并且设置当前位置是0。说的意思就是:将缓存字节数组的指针设置为数组的开始序列即数组下标0。这样就可以从buffer开头,对该buffer进行遍历(读取)了。
实例代码(借用Java编程思想P552的代码):
package cn.com.newcom.ch18; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.RandomAccessFile; import java.nio.ByteBuffer; import java.nio.channels.FileChannel; /** * 获取通道 * * @author zhq * */ public class GetChannel { private static final int SIZE = 1024; public static void main(String[] args) throws Exception { // 获取通道,该通道允许写操作 FileChannel fc = new FileOutputStream("data.txt").getChannel(); // 将字节数组包装到缓冲区中 fc.write(ByteBuffer.wrap("Some text".getBytes())); // 关闭通道 fc.close(); // 随机读写文件流创建的管道 fc = new RandomAccessFile("data.txt", "rw").getChannel(); // fc.position()计算从文件的开始到当前位置之间的字节数 System.out.println("此通道的文件位置:" + fc.position()); // 设置此通道的文件位置,fc.size()此通道的文件的当前大小,该条语句执行后,通道位置处于文件的末尾 fc.position(fc.size()); // 在文件末尾写入字节 fc.write(ByteBuffer.wrap("Some more".getBytes())); fc.close(); // 用通道读取文件 fc = new FileInputStream("data.txt").getChannel(); ByteBuffer buffer = ByteBuffer.allocate(SIZE); // 将文件内容读到指定的缓冲区中 fc.read(buffer); buffer.flip();//此行语句一定要有 while (buffer.hasRemaining()) { System.out.print((char)buffer.get()); } fc.close(); } }
注意:buffer.flip();一定得有,如果没有,就是从文件最后开始读取的,当然读出来的都是byte=0时候的字符。通过buffer.flip();这个语句,就能把buffer的当前位置更改为buffer缓冲区的第一个位置。
评论
9 楼
shenselongge
2016-05-25
/** * Flips this buffer. The limit is set to the current position and then * the position is set to zero. If the mark is defined then it is * discarded. * * <p> After a sequence of channel-read or <i>put</i> operations, invoke * this method to prepare for a sequence of channel-write or relative * <i>get</i> operations. For example: * * <blockquote><pre> * buf.put(magic); // Prepend header * in.read(buf); // Read data into rest of buffer * buf.flip(); // Flip buffer * out.write(buf); // Write header + data to channel</pre></blockquote> * * <p> This method is often used in conjunction with the {@link * java.nio.ByteBuffer#compact compact} method when transferring data from * one place to another. </p> * * @return This buffer */ public final Buffer flip() { limit = position; position = 0; mark = -1; return this; }
8 楼
tonyyan
2015-11-24
感谢,清晰了很多。
7 楼
frangejct
2015-10-16
jdluojing 写道
你的说法也不完整,buffer中的flip方法涉及到bufer中的Capacity,Position和Limit三个概念。其中Capacity在读写模式下都是固定的,就是我们分配的缓冲大小,Position类似于读写指针,表示当前读(写)到什么位置,Limit在写模式下表示最多能写入多少数据,此时和Capacity相同,在读模式下表示最多能读多少数据,此时和缓存中的实际数据大小相同。在写模式下调用flip方法,那么limit就设置为了position当前的值(即当前写了多少数据),postion会被置为0,以表示读操作从缓存的头开始读。也就是说调用flip之后,读写指针指到缓存头部,并且设置了最多只能读出之前写入的数据长度(而不是整个缓存的容量大小)。
6 楼
zlc1094512300
2015-04-09
Wuaner 写道
jdluojing 写道
你的说法也不完整,buffer中的flip方法涉及到bufer中的Capacity,Position和Limit三个概念。其中Capacity在读写模式下都是固定的,就是我们分配的缓冲大小,Position类似于读写指针,表示当前读(写)到什么位置,Limit在写模式下表示最多能写入多少数据,此时和Capacity相同,在读模式下表示最多能读多少数据,此时和缓存中的实际数据大小相同。在写模式下调用flip方法,那么limit就设置为了position当前的值(即当前写了多少数据),postion会被置为0,以表示读操作从缓存的头开始读。也就是说调用flip之后,读写指针指到缓存头部,并且设置了最多只能读出之前写入的数据长度(而不是整个缓存的容量大小)。
说的很明白。终于懂了
5 楼
okooo00
2014-10-28
理解了,tks
4 楼
yangjing5514
2014-10-22
3 楼
Wuaner
2014-05-30
jdluojing 写道
你的说法也不完整,buffer中的flip方法涉及到bufer中的Capacity,Position和Limit三个概念。其中Capacity在读写模式下都是固定的,就是我们分配的缓冲大小,Position类似于读写指针,表示当前读(写)到什么位置,Limit在写模式下表示最多能写入多少数据,此时和Capacity相同,在读模式下表示最多能读多少数据,此时和缓存中的实际数据大小相同。在写模式下调用flip方法,那么limit就设置为了position当前的值(即当前写了多少数据),postion会被置为0,以表示读操作从缓存的头开始读。也就是说调用flip之后,读写指针指到缓存头部,并且设置了最多只能读出之前写入的数据长度(而不是整个缓存的容量大小)。
2 楼
ligf06
2014-05-16
楼上说的非常好,非常清晰,学习了
1 楼
jdluojing
2013-12-12
你的说法也不完整,buffer中的flip方法涉及到bufer中的Capacity,Position和Limit三个概念。其中Capacity在读写模式下都是固定的,就是我们分配的缓冲大小,Position类似于读写指针,表示当前读(写)到什么位置,Limit在写模式下表示最多能写入多少数据,此时和Capacity相同,在读模式下表示最多能读多少数据,此时和缓存中的实际数据大小相同。在写模式下调用flip方法,那么limit就设置为了position当前的值(即当前写了多少数据),postion会被置为0,以表示读操作从缓存的头开始读。也就是说调用flip之后,读写指针指到缓存头部,并且设置了最多只能读出之前写入的数据长度(而不是整个缓存的容量大小)。
发表评论
-
Thinking In Java P550(中文版)程序代码有误
2009-08-15 11:32 2483这一段时间在研究《J ... -
使用Java中的Runtime.exec()执行Windows命令
2009-08-15 00:33 17018转载地址:http://www.cheng-fu.com/no ... -
widows dos 操作
2009-08-15 00:20 1844======对进程的管理========== 结束一个进程( ... -
让CPU占用率划出一条直线(Java实现)
2009-08-13 10:31 7241CPU占用率:在任务管理器的一个刷新周期内,CPU忙(执行应用 ... -
如何自学java迅速成为java高手
2009-07-13 16:52 2143文章转载地址:http://www.sunxin.org/ar ... -
请问大牛:该段代码有几个对象符合垃圾收集条件?
2009-07-13 12:12 1293代码如下: public class Demo { Sho ... -
Java接口和抽象类的区别?
2009-03-06 22:07 3908转载地址:http://blog.csdn.net/fogu7 ... -
Java基础学习
2009-02-21 20:54 1447Java基础学习(02Java语言的特点、机制与规范)收藏 ... -
Java线程之守护线程(Daemon)收藏
2009-02-21 17:21 10000文章出处:http://blog.csdn.net/mq612 ... -
Java线程同步机制synchronized关键字的理解
2009-02-21 17:00 6070文章出处:http://tech.it16 ... -
深入浅出之正则表达式(二)
2008-10-29 22:06 1148前言: 本文 ... -
深入浅出之正则表达式(一)
2008-10-29 22:02 1181前言: 半年 ... -
System.getProperty()参数大全
2008-10-25 23:34 1262public static String getPropert ... -
动态代理类学习总结
2008-09-28 10:06 15561、动态代理类的特点: ... -
Java RMI 入门学习
2008-07-27 23:38 9359一 .RMI概述 RMI(Remote Method Invo ... -
Java Thread应该注意的问题
2008-07-27 21:43 1794Java的线程编程非常简单 ... -
Java 多线程的Thread类和Runnable接口
2008-07-27 21:42 29129Thread 类 Thread 类是一个具体的类,即不 ... -
一个完整的线程池的实例
2008-07-27 21:39 1540线程池用一个双向链表来表示,池中的元素是处于休眠状态的工作线程 ... -
100行java代码构建一个线程池
2008-07-27 21:36 1538在现代的操作系统中, ...
相关推荐
Java.NIO资源下载资源下载
找了好久,终于找到了,java刷新同步获取网络资源
Java.nio 与Java.io比较
java.io clojure.java.io 的 JK7 java.nio.file.Path 兼容性依赖信息该库托管在 Releases 上。 依赖: [me.moocar/java.io " 0.1.0 " ]用法是 JDK7 中引入的文件路径的抽象。 这个库提供了和 Paths 之间的兼容性。 ...
下面小编就为大家分享一篇JDK1.7 之java.nio.file.Files 读取文件仅需一行代码实现,具有很好的参考价值,希望对大家有所帮助
但 Java 在后期版本中引入了 java.nio.file 库来提高 Java 对文件操作的能力。还增加的流的功能,似乎使得文件变成更好用了。所以本章,我们就来主要介绍 java.nio.file 中常用的类和模块,大致如下: Path 路径:...
java.nio包的学习总结,看看确实有收获
Java的IO操作集中在java.io这个包中,是基于流的同步(blocking)API。对于大多数应用来说,这样...从JDK 1.4起,NIO API作为一个基于缓冲区,并能提供异步(non-blocking)IO操作的API被引入。本文对其进行深入的介绍。
此外,还有三个函数buffer-seq,buffer-nth和buffer-to-array,旨在使将java.nio类集成到Clojure中更加容易。 希望通过将它们的功能滚动到clojure.core中,它们将变得过时。 要使其他功能与ByteBuffers一起使用,还...
Java.NIO_网络编程_入门讲解,初学者适合的资料
java 1.4中推出的java.nio(新输入/输出)软件包允许像在其他低级语言——如C语言——中一样进行输入/输出。许多开发者认为这些新功能只能进行非阻塞操作;但是,这些新功能提供许多其他新鲜有趣的特性,它们包括:...
java NIO详细教程,包括使用背景,实现原理,代码实现
Apress.Pro.Java.7.NIO.2.2011
重新写的Java.nio的socket异步通讯,包含客户端及服务端完整版, 注:解析信息CLASS及进制转换CLASS需要自己去写,项目直接导入,需要自己写一些解析及转换类,这样你才能读懂SOCKET的异步,否则光拿代码没用 ...
java nio 编程一个实例子.服务端程序
在JDK 1.4以前,Java的IO操作集中在java.io这个包中,是基于流的同步(blocking)API。对于大多数应用来说,这样的API使用很方便,然而,一些对性能要求较高的应用,尤其是服务端应用,往往需要一个更为有效的方式来...
NULL 博文链接:https://shihuan830619.iteye.com/blog/1159544
java NIO.zip