笔试:(润芯微)

1、hashmap允许用null作键值吗? 允许

2、编程题:使用使用Arrays.CopyOf 使用copyOfrange复制数组

在Java中,`java.util.Arrays` 类提供了 `copyOf` 和 `copyOfRange` 方法来复制数组的一部分或全部。下面是这两个方法的简要介绍及用法示例

Arrays.copyOf 方法用于创建一个新的数组,其中包含原始数组的全部元素或指定长度的部分元素。如果新的数组比原始数组短,则多余的元素会被截断;如果新的数组较长,则多余的位置会填充默认值
 示例代码:

int[] originalArray = {1, 2, 3, 4, 5};
int[] newArray = Arrays.copyOf(originalArray, 3); // 新数组只包含前三个元素
System.out.println(Arrays.toString(newArray)); // 输出 [1, 2, 3]

int[] longerArray = Arrays.copyOf(originalArray, 7);
System.out.println(Arrays.toString(longerArray)); // 输出 [1, 2, 3, 4, 5, 0, 0]

Arrays.copyOfRange方法用于复制原始数组的一部分到一个新的数组中。你可以指定起始索引和结束索引(包含起始索引,不包含结束索引),从而复制指定范围内的元素。

示例代码:

int[] originalArray = {1, 2, 3, 4, 5};
int[] rangeArray = Arrays.copyOfRange(originalArray, 1, 4); // 从索引1开始到索引3结束
System.out.println(Arrays.toString(rangeArray)); // 输出 [2, 3, 4]

注意:在上面的例子中,`from` 和 `to` 的索引都是基于0的,即数组的第一个元素索引为0。如果你尝试复制的范围超出了数组的实际大小,将会抛出 `ArrayIndexOutOfBoundsException` 异常。因此,在使用这些方法时,确保提供的索引值是有效的。

3、类中定义的方法可以与类名同名?可以

4、如何定义InputStreamReader对象

5、注释可以生成API文档吗?可以

API文档:

生成API文档是软件开发过程中的一个重要环节,它帮助开发者更好地理解和使用已有的代码库。在Java中,最常用的API文档生成工具是Javadoc。下面详细介绍如何使用Javadoc生成API文档,并提供一些基本的指南和示例。

Javadoc简介
Javadoc是一个命令行工具,可以从源代码中的注释中提取信息,并生成HTML格式的文档。这些文档不仅包括类、方法、字段等的说明,还包括继承关系图、包层次结构等丰富的信息。

Javadoc注释格式
Javadoc注释是一种特殊的多行注释,以 /** 开头,并且每个注释段落都以 * 开始。常见的Javadoc标签包括但不限于:

@param:描述方法参数。
@return:描述方法的返回值。
@throws 或 @exception:描述方法可能抛出的异常。
@author:描述作者信息。
@version:描述版本信息。
@see:提供指向相关类或方法的链接。
@since:描述该元素自何时开始可用。
@deprecated:标记一个元素已被弃用。
@todo:标记待办事项。
@code:在文档中显示代码片段。
@link 和 @linkplain:创建指向其他文档的链接。

6、简述线程池submit和execute()方法

线程池是Java并发编程中的重要组成部分,它允许复用一组预创建的线程来执行任务。在Java中,`java.util.concurrent.ExecutorService` 接口提供了两种主要的方法来提交任务给线程池:`submit()` 和 `execute()`。这两种方法在功能上有一定的差异,下面我们来详细探讨这两种方法的特点和使用场景。

1. execute()

`execute()` 方法用于向线程池提交一个 `Runnable` 任务。这个方法的返回类型是 `void`,并且不会返回任何结果。如果任务执行过程中抛出了异常,那么这些异常会被封装成 `ExecutionException` 并且由调用者捕获。

语法
```java

void execute(Runnable command);

#### 特点
- **无返回值**:`execute()` 不会返回任何结果,因此不适合那些需要返回结果的任务。
- **异常处理**:如果任务抛出未检查异常(unchecked exception),则该异常会被 `execute()` 方法捕获并记录,但不会直接传递给调用者。
- **适用场景**:适用于那些只需要执行任务但不需要等待结果的情况。

示例

ExecutorService executor = Executors.newFixedThreadPool(5);

executor.execute(() -> {
    // 执行任务...
    System.out.println("Executing task...");
});

// 关闭线程池
executor.shutdown();
```

### 2. submit()

`submit()` 方法用于向线程池提交一个 `Runnable` 或 `Callable` 任务。这个方法的返回类型是 `Future<V>`,其中 `V` 是任务执行结果的类型。`submit()` 方法可以接收 `Runnable` 或 `Callable` 类型的任务,并且总是返回一个 `Future` 对象,即使任务本身不返回任何结果。

#### 语法
```java
<T> Future<T> submit(Callable<T> task);
Future<?> submit(Runnable task);
```

#### 特点
- **有返回值**:`submit()` 可以返回一个 `Future` 对象,通过这个对象可以获取任务的执行结果或取消任务。
- **异常处理**:如果任务抛出未检查异常,那么这些异常会被封装到 `Future` 对象中,并且可以通过 `Future.get()` 方法获取时抛出 `ExecutionException`。
- **适用场景**:适用于那些需要执行任务并且需要等待结果的情况。

#### 示例
```java
ExecutorService executor = Executors.newFixedThreadPool(5);

Future<Integer> future = executor.submit(() -> {
    // 执行任务...
    System.out.println("Executing task...");
    return 42; // 返回结果
});

// 获取结果
try {
    Integer result = future.get(); // 阻塞直到任务完成
    System.out.println("Result: " + result);
} catch (InterruptedException | ExecutionException e) {
    e.printStackTrace();
}

// 关闭线程池
executor.shutdown();
```

### 总结

- **`execute()`** 更适合那些只需要执行任务但不需要返回结果的情况。
- **`submit()`** 则适用于需要返回结果的任务,同时也提供了更好的异常处理机制。

在选择使用 `execute()` 还是 `submit()` 时,主要取决于你的任务是否需要返回结果以及你希望如何处理任务执行过程中可能抛出的异常。如果需要获取任务执行结果或者更好地控制任务执行流程,建议使用 `submit()` 方法。如果仅仅是异步执行任务,并且不关心结果,那么 `execute()` 方法就足够了。

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值