• 互联网Java工程师面试题·Java 总结篇·第七弹


    目录

    68、Java 中如何实现序列化,有什么意义?

    69、Java 中有几种类型的流?

    70、写一个方法,输入一个文件名和一个字符串,统计这个字符串在这个文件中出现的次数。

    71、如何用 Java 代码列出一个目录下所有的文件?


    68、Java 中如何实现序列化,有什么意义?

            序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决对象流读写操作时可能引发的问题(如果不进行序列化可能会存在数据乱序的问题)。

            要实现序列化,需要让一个类实现 Serializable 接口,该接口是一个标识性接口,标注该类对象是可被序列化的,然后使用一个输出流来构造一个对象输出流并通过 writeObject(Object)方法就可以将实现对象写出(即保存其状态);如果需要反序列化则可以用一个输入流建立对象输入流,然后通过 readObject 方法从流中读取对象。序列化除了能够实现对象的持久化之外,还能够用于对象的深度克隆(可以参考第 29 题)。

    互联网Java工程师面试题·Java 总结篇·第三弹-CSDN博客


    69、Java 中有几种类型的流?

            字节流和字符流。字节流继承于 InputStream、OutputStream,字符流继承于Reader、Writer。在 java.io 包中还有许多其他的流,主要是为了提高性能和使用方便。关于 Java 的 I/O 需要注意的有两点:

    一是两种对称性(输入和输出的对称性,字节和字符的对称性);

    二是两种设计模式(适配器模式和装潢模式)。

    另外 Java 中的流不同于 C#的是它只有一个维度一个方向。

    面试题 - 编程实现文件拷贝。(这个题目在笔试的时候经常出现,下面的代码给出了两种实现方案)

    1. import java.io.FileInputStream;
    2. import java.io.FileOutputStream;
    3. import java.io.IOException;
    4. import java.io.InputStream;
    5. import java.io.OutputStream;
    6. import java.nio.ByteBuffer;
    7. import java.nio.channels.FileChannel;
    8. public final class MyUtil {
    9. private MyUtil() {
    10. throw new AssertionError();
    11. }
    12. public static void fileCopy(String source, String target) throws
    13. IOException {
    14. try (InputStream in = new FileInputStream(source)) {
    15. try (OutputStream out = new FileOutputStream(target)) {
    16. byte[] buffer = new byte[4096];
    17. int bytesToRead;
    18. while((bytesToRead = in.read(buffer)) != -1) {
    19. out.write(buffer, 0, bytesToRead);
    20. }
    21. }
    22. }
    23. }
    24. public static void fileCopyNIO(String source, String target) throws
    25. IOException {
    26. try (FileInputStream in = new FileInputStream(source)) {
    27. try (FileOutputStream out = new FileOutputStream(target)) {
    28. FileChannel inChannel = in.getChannel();
    29. FileChannel outChannel = out.getChannel();
    30. ByteBuffer buffer = ByteBuffer.allocate(4096);
    31. while(inChannel.read(buffer) != -1) {
    32. buffer.flip();
    33. outChannel.write(buffer);
    34. buffer.clear();
    35. }
    36. }
    37. }
    38. }
    39. }

    注意:上面用到 Java 7 的 TWR,使用 TWR 后可以不用在 finally 中释放外部资源 ,从而让代码更加优雅。


    70、写一个方法,输入一个文件名和一个字符串,统计这个字符串在这个文件中出现的次数。

    代码如下:

    1. import java.io.BufferedReader;
    2. import java.io.FileReader;
    3. public final class MyUtil {
    4. // 工具类中的方法都是静态方式访问的因此将构造器私有不允许创建对象(绝对好习惯)
    5. private MyUtil() {
    6. throw new AssertionError();
    7. }
    8. /**
    9. * 统计给定文件中给定字符串的出现次数
    10. *
    11. * @param filename 文件名
    12. * @param word 字符串
    13. * @return 字符串在文件中出现的次数
    14. */
    15. public static int countWordInFile(String filename, String word) {
    16. int counter = 0;
    17. try (FileReader fr = new FileReader(filename)) {
    18. try (BufferedReader br = new BufferedReader(fr)) {
    19. String line = null;
    20. while ((line = br.readLine()) != null) {
    21. int index = -1;
    22. while (line.length() >= word.length() && (index =
    23. line.indexOf(word)) >= 0) {
    24. counter++;
    25. line = line.substring(index + word.length());
    26. }
    27. }
    28. }
    29. } catch (Exception ex) {
    30. ex.printStackTrace();
    31. }
    32. return counter;
    33. }
    34. }

    71、如何用 Java 代码列出一个目录下所有的文件?

    如果只要求列出当前文件夹下的文件,代码如下所示:

    1. import java.io.File;
    2. class Test12 {
    3. public static void main(String[] args) {
    4. File f = new File("/Users/Hao/Downloads");
    5. for(File temp : f.listFiles()) {
    6. if(temp.isFile()) {
    7. System.out.println(temp.getName());
    8. }
    9. }
    10. }
    11. }

    如果需要对文件夹继续展开,代码如下所示:

    1. import java.io.File;
    2. class Test12 {
    3. public static void main(String[] args) {
    4. showDirectory(new File("/Users/Hao/Downloads"));
    5. }
    6. public static void showDirectory(File f) {
    7. _walkDirectory(f, 0);
    8. }
    9. private static void _walkDirectory(File f, int level) {
    10. if(f.isDirectory()) {
    11. for(File temp : f.listFiles()) {
    12. _walkDirectory(temp, level + 1);
    13. }
    14. }
    15. else {
    16. for(int i = 0; i < level - 1; i++) {
    17. System.out.print("\t");
    18. }
    19. System.out.println(f.getName());
    20. }
    21. }
    22. }

    在 Java 7 中可以使用 NIO.2 的 API 来做同样的事情,代码如下所示:

    1. class ShowFileTest {
    2. public static void main(String[] args) throws IOException {
    3. Path initPath = Paths.get("/Users/Hao/Downloads");
    4. Files.walkFileTree(initPath, new SimpleFileVisitor() {
    5. @Override
    6. public FileVisitResult visitFile(Path file, BasicFileAttributesattrs)
    7. throws IOException {
    8. System.out.println(file.getFileName().toString());
    9. return FileVisitResult.CONTINUE;
    10. }
    11. });
    12. }
    13. }

    要想了解更多:

    千题千解·Java面试宝典_时光の尘的博客-CSD

  • 相关阅读:
    关于netty的一些你需要知道的内容(4)
    树莓派玩转openwrt软路由:12.OpenWrt安装MySQL
    uos服务器系统安装达梦8数据库
    20220809NOI模拟赛
    如何搭建Wish、eBay、美客多 一天 成号测评环境系统?
    C++环形缓冲区设计与实现:从原理到应用的全方位解析
    PostgreSQL 索引优化与性能调优(十一)
    flask 发送ajax
    elasticSearch配置
    LeetCode刷题复盘笔记—一文搞懂343. 整数拆分(动态规划系列第四篇)
  • 原文地址:https://blog.csdn.net/MANONGDKY/article/details/133900562