`
vyloy
  • 浏览: 80724 次
  • 性别: Icon_minigender_1
  • 来自: 佛山
社区版块
存档分类
最新评论

ByteBuffer使用实例

    博客分类:
  • Java
阅读更多
package com.vyloy.server;

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.Channels;
import java.nio.channels.ReadableByteChannel;
import java.nio.charset.Charset;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.vyloy.server.db.File;
import com.vyloy.server.db.service.FileService;
import com.vyloy.server.fileupload.FileUpload;

/**
 * Servlet implementation class UploadServlet
 */
public class UploadServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public UploadServlet() {
        super();
    }

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		ByteBuffer result = ByteBuffer.allocate(3*1024*1024);
		try {
			ReadableByteChannel in = Channels.newChannel(request
					.getInputStream());
			ByteBuffer tempbytes = ByteBuffer.allocate(1024*1024);
			while ((in.read(tempbytes)) != -1) {
				tempbytes.flip();
				//重点--比较临时字节数是否比输出字节缓存剩余容量大
				if(result.remaining()<tempbytes.limit()){
					ByteBuffer _result=ByteBuffer.allocate(result.capacity()*2);
					result.flip();
					_result.put(result);
					result=_result;
				}
				result.put(tempbytes);
				tempbytes.clear();
			}
			result.flip();
		} catch (IOException e) {
			e.printStackTrace();
			response.getWriter().write("0");
			return;
		}
		try{
			//重点--result.array()会返回底层数组,如果有效数据少于容量,
			//则数据中会包含很多没用的值为0的字节 
			//所以这里创建一个新的数组再把有效数据存入
			byte[] bytes=new byte[result.limit()];
			result.get(bytes);
			result.clear();
			FileUpload fileUpload = new FileUpload(bytes);
			String fileName=new String(fileUpload.get("Filename"),Charset.forName("utf-8"));
			byte[] data=fileUpload.get("Filedata");
			File file = new File(fileName);
			FileService.getInstance().save(file, data);
			response.getWriter().write("1");
		}catch(Exception e){
			e.printStackTrace();
			response.getWriter().write("0");
		}
	}

}



不变式
标记、位置、限制和容量值遵守以下不变式:

0 <= 标记 <= 位置 <= 限制 <= 容量
新创建的缓冲区总有一个 0 位置和一个未定义的标记。初始限制可以为 0,也可以为其他值,这取决于缓冲区类型及其构建方式。一般情况下,缓冲区的初始内容是未定义的。

清除、反转和重绕
除了访问位置、限制、容量值的方法以及做标记和重置的方法外,此类还定义了以下可对缓冲区进行的操作:

clear() 使缓冲区为一系列新的通道读取或相对放置 操作做好准备:它将限制设置为容量大小,将位置设置为 0。

flip() 使缓冲区为一系列新的通道写入或相对获取 操作做好准备:它将限制设置为当前位置,然后将位置设置为 0。

rewind() 使缓冲区为重新读取已包含的数据做好准备:它使限制保持不变,将位置设置为 0。


作者:翁志艺
分享到:
评论

相关推荐

    Android中的ByteBuffer解析

    3. **复用缓冲区**:在多次读写操作中,尽可能复用已有的ByteBuffer实例,减少对象创建。 总的来说,ByteBuffer是Android开发中处理二进制数据的强大工具,熟练掌握其用法和优化策略,可以显著提高应用程序的性能。...

    protobuf+long+bytebuffer

    从网络或者存储中获取到protobuf编码的二进制数据后,可以创建一个`ByteBuffer`实例,然后调用protobuf编译器生成的类的解析方法,传入`ByteBuffer`实例进行解码。`ByteBuffer`会根据protobuf编码规则正确地读取和...

    ByteBuffer.zip

    - 缓冲区分配:创建一个足够大的ByteBuffer实例,以便容纳所有的字节数据。 - 写入数据:使用ByteBuffer的put方法将转换后的字节序列写入缓冲区,可以按单个字节、短整型、整型、长整型或其他自定义字节数组进行...

    Java NIO学习笔记——ByteBuffer用法

    1. 创建ByteBuffer实例,分配一定的容量。 2. 使用put()方法填充数据。 3. 调用flip()切换到读模式。 4. 使用get()方法读取数据,可能配合其他Buffer或Channel进行数据传输。 5. 根据需要调用clear()或compact()(只...

    Android在JNI中使用ByteBuffer的方法

    同时,使用相同的ByteBuffer实例并清除或回绕它,可以避免频繁创建新缓冲区带来的性能损失。 总结来说,Android在JNI中使用ByteBuffer主要是为了提高数据传输的效率,通过直接访问内存,减少数据拷贝,从而提升应用...

    深入理解Apache Mina (6)---- Java Nio ByteBuffer与Mina ByteBuffer的区别

    2. 基于池化的管理:Mina通过缓冲区池来复用ByteBuffer实例,减少频繁的创建和销毁操作,提高性能。 3. 多种类型支持:Mina提供多种类型的ByteBuffer,如HeapByteBuffer、DirectByteBuffer和复合缓冲区,可以根据...

    java api之ByteBuffer基础、应用场景、实战讲解

    java api之ByteBuffer基础、应用场景、实战讲解 文档中有丰富的例子代码实现

    dena-bytebuffer:dena-bytebuffer

    1. **初始化**:创建一个新的`dena-bytebuffer`实例,可以指定初始大小或者传递一个现有的`ArrayBuffer`。 ```javascript var ByteBuffer = require('dena-bytebuffer'); var buffer = new ByteBuffer(10); // 创建...

    MongoDB之Java使用例子

    在这个“MongoDB之Java使用例子”中,我们将深入探讨如何在Java环境中操作MongoDB数据库,包括增、删、改、查(CRUD)操作以及图像数据的存储和检索。 首先,Java与MongoDB的交互主要通过MongoDB的Java驱动程序实现...

    protobuf.js

    3. **在JavaScript中使用**:在JavaScript代码中,你可以实例化protobuf消息类,填充数据,然后使用protobuf.js库进行序列化。同样,接收到的protobuf序列化数据可以通过反序列化恢复为消息对象。 4. **处理数据**...

    实现java网络与nio例子

    - 缓冲区(ByteBuffer)用于存储数据,可以使用`ByteBuffer.allocate()`分配内存,`put()`写入数据,`flip()`切换到读模式,`get()`读取数据,`clear()`或`compact()`清空缓冲区。 2. **客户端实现**: - 客户端...

    javaNIO实例

    此外,这个例子应该包含了异常处理,确保在出现错误时能够正确关闭资源,防止资源泄露。 总的来说,这个javaNIO实例是一个很好的学习资源,通过实践了解NIO的基本用法和优势。对于希望提升Java I/O性能或者处理高...

    java-nio.rar_java nio_nio 对象实例化

    实例化一个缓冲区通常通过`Buffer.allocate(size)`来创建,如`ByteBuffer buffer = ByteBuffer.allocate(1024)`。 3. **选择器(Selector)**:选择器允许单个线程监控多个通道的事件。这对于管理多个并发连接非常...

    摄像头JNI例子教程.zip

    本教程通过一个摄像头的例子,深入浅出地讲解JNI的使用方法。 【环境配置】 在开始JNI编程之前,我们需要搭建好开发环境。首先,确保你安装了Java Development Kit(JDK)和Android Studio,因为这个教程是基于...

    java NIO原理和使用

    #### 三、Java NIO 使用实例 下面是一个简单的 Java NIO 示例,展示了如何使用 `FileChannel` 和 `ByteBuffer` 进行文件复制: ```java package nio; import java.io.FileInputStream; import java.io....

    MD5加密算法的VB6.0类模块实例.doc

    该类模块实例将MD5加密算法封装在一个VB6.0类模块中,使得开发者能够方便地使用MD5加密算法来实现文本字符串的加密和文件的加密。 类模块代码解析 该类模块代码主要包括以下几个部分: 1. 常量定义:该类模块定义...

    Netty4.0 官网例子(免费)

    4. **Pipeline**:Netty 使用 ChannelPipeline 来处理进来的数据。Pipeline 是一系列处理器(ChannelHandler)的链,每个处理器可以处理特定类型的数据或事件,如解码、编码、业务逻辑处理等。 5. **...

    使用RandomAccessFile流将一个文本文件读出,并导致写入到另一个文件当中。

    1. 创建`RandomAccessFile`实例,以读写模式打开文件`F:\\rain.txt`。 2. 获取文件长度,并根据长度创建一个`ByteBuffer`。 3. 通过`RandomAccessFile`的`getChannel()`方法获取文件通道,并通过该通道读取数据到`...

Global site tag (gtag.js) - Google Analytics