Java语法细节

Java申请DirectBuffer

/*-------JAVA直接操作内存-------------

   * 申请100m的直接内存,不会申请在java堆上面

   * 打开资源管理器可以看到内存占用会增加100m,但是java堆上的内存却没有增加!

   */

ByteBuffer buffer = ByteBuffer.allocateDirect(100 * 1024 * 1024);

System.out.println("------------------start----------------------");

Thread.sleep(10 * 1000);

// 清理刚刚申请的内存
((DirectBuffer)(buffer)).cleaner().clean();     

System.out.println("------------------end----------------------");

 

ByteBuffer的position,limit,capacity,flip操作之间的关系

以下面的代码为例

/**

* 描述:测试ByteBuffer的相关操作

* position:写模式下当前写的位置,读模式下当前读的位置

* limit:写模式下能写多少数据,读模式下能读多少数据

* capacity:即byteBuffer的总大小,不区分读写

* flip:将limit置为position,position置为0,一般用于写完之后开始进行读取

*/

   privatestaticvoid testByteBufferOperation() throws InterruptedException

   {
      ByteBuffer buffer = ByteBuffer.allocate(20);

      buffer.putInt(123);   //java 1个int  4个字节

      //默认limit和capacity的值是相同的,第一次put之后,position移动到当前写的位置
      System.out.println("*************initial status***************");
      System.out.println("position:" + buffer.position() + "
limit:" + buffer.limit() + "
"
            + "capacity:" + buffer.capacity());

      //flip之后,limit变为position,position置为0
      buffer.flip();
      System.out.println("*************after flip***************");
      System.out.println("position:" + buffer.position() + "
limit:" + buffer.limit() + "
"
            + "capacity:" + buffer.capacity());

      //get之后,position移动1位,其他不变
      buffer.get();
      System.out.println("*************after first get***************");
      System.out.println("position:" + buffer.position() + "
limit:" + buffer.limit() + "
"
            + "capacity:" + buffer.capacity());
   }

枚举实现单例模式

/*

 * 枚举实现单例,一方面保证了线程安全,另一方面会“免费”得到了序列化的功能
 */

publicenum ChildEnum {
   //枚举里面默认的实例
   INSTANCE;
   private Child childInstance;

   private ChildEnum()
   {
  		childInstance = new Child();
   }

   public Child getInstance()
   {
  		returnchildInstance;
   }
}
原文地址:https://www.cnblogs.com/seancheer/p/10708237.html