在使用 aws-sdk-go 进行文件操作时,有时我们需要动态设置文件大小并将其存储在内存中。然而,当我们使用 getObject 方法来获取这个文件时,可能会发现获取时间较长。这是因为在 aws-sdk-go 中,getObject 方法是基于 HTTP 协议的,而 HTTP 协议对于大文件的传输需要更多的时间和资源。因此,当我们动态设置文件大小并存储在内存中时,可能会导致 getObject 方法的执行时间变长。为了减少这种情况的发生,我们可以考虑使用其他更适合大文件传输的方法,如分段下载或使用多线程下载等。
问题内容
我尝试理解ForkJoinPool。我实际上不明白 fork
方法在没有 join
和结束条件的情况下做什么。
如果fork
发送一个要在队列中执行的任务,那么为什么这段代码不会无限地运行呢?
import java.util.concurrent.ForkJoinPool; import java.util.concurrent.RecursiveAction; public class Main { public static void main(String[] args) { ForkJoinPool pool = new ForkJoinPool(); pool.invoke(new Test()); } static class Test extends RecursiveAction { @Override protected void compute() { System.out.println(Thread.currentThread().getName()); Test test = new Test(); test.fork(); } } }
结果总是不同的。
第二个问题:如果你在计算中调用 self fork
会发生什么?
@Override protected void compute() { System.out.println(1); fork(); }
计算将被调用 1 或 2 次。
或者这个:
protected void compute() { System.out.println(1); fork(); join(); }
计算将调用多次,然后停止。
解决方法
它确实无限地运行,但它们守护线程不会阻止 JVM 关闭,因此它们会在主线程完成后(即立即关闭)关闭。设置一个无限循环来阻止主线程完成,您将看到您的任务无限进行。
public static void main(String[] args) { ForkJoinPool pool = new ForkJoinPool(); pool.invoke(new Test()); while (true) {} } static class Test extends RecursiveAction { @Override protected void compute() { System.out.println(Thread.currentThread().getName()); Test test = new Test(); test.fork(); } }
以上是为什么在 aws-sdk-go 中动态设置文件大小并存储在内存中时 getObject 需要更长的时间?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Atom编辑器mac版下载
最流行的的开源编辑器

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)