Java7

    xiaoxiao2026-01-04  5

    java7相关的注意点

    Path

    path并不仅仅限于传统的文件系统,也能表示zip或者jar文件path 不一定真实的文件或目录,可以随意的创建path中可能有其他冗余项,比如符号链接,获取真实位置可以使用toRealPath() 或者normalize()合并两个path 使用 resolve() ,或者获取相对位置relative()转化Path file.toPath() path.toFile()

    处理单个文件目录

    String path = "F:\\mavenproject\\SpringProject"; Files.newDirectoryStream(Paths.get(path),"*.xml") .forEach(e-> System.out.println(e.getFileName()));

    递归处理文件件

    static class FileFindXMLVisitor extends SimpleFileVisitor<Path>{ @Override public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException { if(file.toString().endsWith(".xml")&& (!file.toString().startsWith("Maven"))) System.out.println(file.getFileName()); return FileVisitResult.CONTINUE; } } String path = "F:\\mavenproject\\SpringProject"; Files.walkFileTree(Paths.get(path),new FileFindXMLVisitor());
    Asynchronous IO 这是将来式,例如用Future.get()返回结果

    如果在创建AsynchronousFileChannel 时没有为其指明线程池,那就会为其分配一个系统默认的线程池(可能会和其他通道共用),默认线程池是由AsynchronousChannelGroup类定义的系统属性进行配置的.

    回调式

    主线程回派一个侦查员CompletionHandler到独立的线程中执行IO操作,这个侦查员会将IO操作的结果返回到主线程中,这个结果会触发他自己的completed或者failed方法(一般重写这两个方法)

    String filepath = "C:\\code\\temp.txt"; Path filePath = Paths.get(filepath); AsynchronousFileChannel fileChannel = AsynchronousFileChannel.open(filePath); ByteBuffer byteBuffer = ByteBuffer.allocate(1000); fileChannel.read(byteBuffer, 0, byteBuffer, new CompletionHandler<Integer, ByteBuffer>() { @Override public void completed(Integer result, ByteBuffer attachment) { System.out.println("Bytes read: "+result); } @Override public void failed(Throwable exc, ByteBuffer attachment) { System.out.println(exc.getMessage()); } });

    并发安全

    Java线程模型建立在(1)共享的,默认可见的可变状态`(2)抢占式线程调度`

    1.所有线程可以很容易的共享同一进程中的对象2.能引用这些对象的任何线程都能修改这些对象

    设计理念 安全性(并发类型安全) 活跃度 性能 重用性安全性是指: 不管同时发生多少操作都能确保对象保持自相一致 系统开销之源: 锁与监测 环境切换次数 线程的个数 调度 内存的局部性 算法设计

    scala 部分

    1.类的定义(就他的参数而言)和类的构造方法是同一个东西,scala中也有辅助函数2.类默认是公开的,所以没有必要加上public关键字的3.方法的返回值是通过类型推断确定的,但要在定义方法的def从句中用等号告诉编译器做类型推断4.scala不像java有原始类型,数字也是对象5.关键字object告诉scala这是一个单利类6.scala用方括号来表示泛型,所以类型参数的表示方法是Array[String]而不是String[]7.Array是纯正的泛型8.集合类型必须指明泛型(不能像java那样声明raw type like: List list = new ArrayList )9.单个case不会像java中那样进入下一个case,所以不需要break10.数组的访问用圆括号,例如 args(0)11.类型推断有两个例外(1):方法声明中的参数类型(2):递归函数,scala编译器不能推断递归函数的返回类型12.scala中没有static关键字,必须放在obejct半生对象中13.scala中局部函数,定义在函数内部的函数...不想暴露细节给外部...14.Any的子类AnyVal 和 AnyRef ,AnyVal的子类Unit Boolean Fload Long ,null是AnyRef的所有子类,Nothing是所有(AnyVal和AnyRef)的子类15.scala类必须有个主构造方法来定义该类的所需的参数,辅助构造函数只提供一个默认参数16.如果类里面的方法没有括号,调用时也没有括号17.伴生对象在相关类那里有特权,既可以访问私有函数和私有构造函数18.在创建新的case类实例时,关键字new可以省略,实际上case类的底层实现上是一个创建新实例的工厂方法19.scala默认是不可变集合,但也有可变集合

    最新回复(0)