allocatedirect用glDrawElements时怎么计算纹理坐标????
allocatedirect 时间:2021-06-08 阅读:(
)
C#像有java中的ByteBuffer这样的类吗?
在HeapByteBuffer中,每个存储单元都是一个byte,byte是大多数计算机中最基本的数据单元。
ByteBuffer的构造器允许以一个特定的容量构造ByteBuffer对象,也可以从一个已存在的byte数组对象上构建ByteBuffer对象。
ByteBuffer.allocate用于设置一个新的capacity,而ByteBuffer.warp方法则是使用一个byte数组对象取代当前的byte数组对象。
ByteBuffer.allocateDirect方法也是设置一个新的capacity,但在此之前它会销毁掉已经存在的ByteHeapBuffer对象,重新建立DirectByteBuffer
对象,经过查看源代码,可以得知DirectByteBuffer是没有安全检测能力的,也就是说它是分配在非托管内存空间里的,所以ByteDirectBuffer缓冲区可能无法捕获诸如溢出,数据类型错误等等异常,它也不受垃圾回收的管理,而是使用类似于C++的显式内存释放,但可以肯定的是,ByteDirectBuffer的速度要快的多。
由于DirectByteBuffer也是Buffer的子类,所以ByteBuffer是无法分辨出来它和ByteHeapBuffer的区别的,操作方法都是完全相同的。
除了将ByteBuffer对象转变成诸如DoubleBuffer对象外,ByteBuffer对象本身也可以直接返回各种数据类型,例如使用ByteBuffer.getInt方法就可以返回Integer类型的数据。
ByteBuffer.order方法用于获取和设置当前数据的字节顺序,包括大头数据,小头数据等,由于数据跨越多种主机传送,而每一种机器表示数据的方式不同,所以做一些转换是必要的。
Java使用ByteOrder类处理字节顺序,ByteOrder.nativeOrder就可以得到当前JVM确定的字节顺序。
你好,我想写一个java服务器端程序,当客户端给出一个请求,就会访问数据库中的内容,并且返回!
public class ServerConnect {
private static final int BUF_SIZE = 1024;
private static final int PORT = 8080;
private static final int TIMEOUT = 3000;
public static void main(String[] args) {
selector();
}
public static void ept(SelectionKey key) throws IOException {
ServerSocketChannel ssChannel = (ServerSocketChannel) key.channel();
SocketChannel sc = ept();
sc.configureBlocking(false);
sc.register(key.selector(), SelectionKey.OP_READ,
ByteBuffer.allocateDirect(BUF_SIZE));
}
public static void handleRead(SelectionKey key) throws IOException {
SocketChannel sc = (SocketChannel) key.channel();
ByteBuffer buf = (ByteBuffer) key.attachment();
long bytesRead = sc.read(buf);
while (bytesRead > 0) {
buf.flip();
while (buf.hasRemaining()) {
byte b= buf.get();
System.out.print((char) buf.get());
}
System.out.println();
buf.clear();
bytesRead = sc.read(buf);
}
if (bytesRead == -1) {
sc.close();
}
}
public static void handleWrite(SelectionKey key) throws IOException {
ByteBuffer buf = (ByteBuffer) key.attachment();
buf.flip();
SocketChannel sc = (SocketChannel) key.channel();
while (buf.hasRemaining()) {
sc.write(buf);
}
pact();
}
public static void selector() {
Selector selector = null;
ServerSocketChannel ssc = null;
try {
selector = Selector.open();
ssc = ServerSocketChannel.open();
ssc.socket().bind(new SocketAddress(PORT));
ssc.configureBlocking(false);
ssc.register(selector, SelectionKey.OP_ACCEPT);
while (true) {
if (selector.select(TIMEOUT) == 0) {
System.out.println("==");
continue;
}
Iterator iter = selector.selectedKeys()
.iterator();
int count = 0;
while (iter.hasNext()) {
count++;
SelectionKey key = iter.next();
if (eptable()) {
ept(key);
}
if (key.isReadable()) {
handleRead(key);
}
if (key.isWritable() && key.isValid()) {
handleWrite(key);
}
if (key.isConnectable()) {
System.out.println("isConnectable = true");
}
iter.remove();
}
System.out.println(count);
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (selector != null) {
selector.close();
}
if (ssc != null) {
ssc.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
不知道客户端的请求是什么形式的请求socket?webservice?http?
你这个这是用nio写的一个socket服务端程序,监听的是本地8080端口,在handleWrite方法体类处理jdbc获取数据放入ByteBuffer里就可以了,jdbc操作这里就不写了。
把d盘的文件拷贝到E盘用java语言怎么编程
下面这两个方法可以
public static boolean copyFile(String srcFileName, String destFileName,boolean overlay);
public static boolean copyDirectory(String srcDirName, String destDirName,boolean overlay) ;Java 的 DirectBuffer 是什么东西?
DirectByteBuffer 类有一个内部的静态类 Deallocator,这个类实现了 Runnable 接口并在 run() 方法内释放了内存:?View CodeJAVA unsafe.freeMemory(address); 那这个 Deallocator 线程是哪里调用了呢?这里就用到了 Java 的虚引用(PhantomReference),Java 虚引用允许对象被回收之前做一些清理工作。
在 DirectByteBuffer 的构造方法中创建了一个 Cleaner:?View CodeJAVA cleaner = Cleaner.create(this , new Deallocator(address, cap) ); 而Cleaner 类继承了 PhantomReference 类,并且在自己的 clean() 方法中启动了清理线程,当 DirectByteBuffer 被 GC 之前 cleaner 对象会被放入一个引用队列(ReferenceQueue),JVM 会启动一个低优先级线程扫描这个队列,并且执行 Cleaner 的 clean 方法来做清理工作。
OK,DirectByteBuffer 的实现大概搞清楚了,那我们是否该在自己的代码中使用 DirectByteBuffer 呢?我个人认为可以适当的使用,使用直接内存确实避免了 GC 问题和内存拷贝的问题,但是我们不得不考虑两个问题:1)操作系统可能会把 DirectByteBuffer 的内存交换到磁盘上,这样势必会影响性能,为了避免这个问题我们不得不对操作系统做相应的配置;2)DirectByteBuffer 申请内存失败会直接抛出 OutOfMemoryError,对于这种情况,还是要想办法处理。
用glDrawElements时怎么计算纹理坐标????
我可以private int[] texCoordelement = { one,one,0,0,one,0,0,one, one,one,0,0,one,0,0,one, one,one,0,0,one,0,0,one, one,one,0,0,one,0,0,one, one,one,0,0,one,0,0,one, one,one,0,0,one,0,0,one, };改成6X6的二维数组,每次用glTexCoordPointer设进去,但问题是怎么通过private byte[][] indices = { new byte[]{0, 4, 5, 0, 5, 1,}, new byte[]{1, 5, 6, 1, 6, 2,}, new byte[]{2, 6, 7, 2, 7, 3,}, new byte[]{3, 7, 4, 3, 4, 0,}, new byte[]{4, 7, 6, 4, 6, 5,}, new byte[]{3, 0, 1, 3, 1, 2,}, };来确定6X6的纹理坐标,比如4--------5| |0--------1这是正方体的底面顶点序号,怎么确定其纹理坐标呢???
Friendhosting发布了针对“系统管理日”(每年7月的最后一个星期五)的优惠活动,针对VPS主机提供55%的优惠(相当于四五折),支持1-6个月付款使用,首付折扣非永久,优惠后最低套餐首半年7.18欧元起。这是一家保加利亚主机商,成立于2009年4月,商家提供VDS和独立服务器租用等,数据中心目前可选美国洛杉矶、保加利亚、乌克兰、荷兰、拉脱维亚、捷克和波兰等8个地区机房。下面以最低套餐为例...
SpinServers服务商也不算是老牌的服务商,商家看介绍是是2018年成立的主机品牌,隶属于Majestic Hosting Solutions LLC旗下。商家主要经营独立服务器租用和Hybrid Dedicated服务器等,目前包含的数据中心在美国达拉斯、圣何塞机房,自有硬件和IP资源等,商家还自定义支持用户IP广播到机房。看到SpinServers推出了美国独服的夏季优惠促销活动,最低月...
专心做抗投诉服务器的VirtVPS上线瑞士机房,看中的就是瑞士对隐私的保护,有需要欧洲抗投诉VPS的朋友不要错过了。VirtVPS这次上新的瑞士服务器采用E-2276G处理器,Windows/Linux操作系统可选。VirtVPS成立于2018年,主营荷兰、芬兰、德国、英国机房的离岸虚拟主机托管、VPS、独立服务器、游戏服务器和外汇服务器业务。VirtVPS 提供世界上最全面的安全、完全受保护和私...
allocatedirect为你推荐
搜索引擎的概念7 什么是搜索引擎?如何在Internet上搜索图片和文字资料的?自定义表情手机qq添加的自定义表情怎么分组部署工具win10 评估和部署工具包有什么用点心os点心操作系统?监控插件观看远程监控时,提示需要一个插件来显示微粒群算法多目标粒子群算法源程序私服发布站程序怎么做游戏私服发布网站?包括网页游戏tokenstreamtokenerror是什么意思smo优化vivo手机一直反复优化要怎么弄?鸿道集团不是说收回了商标权了吗?为什么红罐王老吉还有“王老吉”三个字?红罐不是属于鸿道公司的么?
lnmp buyvm a2hosting themeforest 163网 rak机房 http500内部服务器错误 52测评网 lol台服官网 空间合租 33456 ca187 优酷黄金会员账号共享 七夕快乐英语 创建邮箱 1元域名 lamp怎么读 阿里云手机官网 贵州电信 register.com 更多