跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 大家来探讨一下 Java 方法执行问题!
未分類
14 5 月 2020

大家来探讨一下 Java 方法执行问题!

大家来探讨一下 Java 方法执行问题!

資深大佬 : xhf1024 10

就是比如一个 a 方法,会执行很多遍,第一次执行的时候执行完的时候,期间有 100 个执行了 a 方法,现在又什么方法就是第一次执行完 a 方法,期间 100 次就等着,等第一次 a 方法执行完然后再执行一次?就好比送快递的,我手里拿一个快递,那我执行送快递这个操作,我送的期间快递站有络绎不绝的快递送到服务站等着我送,等我送完之后回来,我再拿起所有的快递去实行送快递这个操作,而不是有一个快递就得派一个人送。

大佬有話說 (32)

  • 主 資深大佬 : xhf1024

    送快递这个操作==执行 a 方法

  • 資深大佬 : xgfan

    锁

  • 資深大佬 : superJava

    队列

  • 資深大佬 : evoluc97

    单机 synchronized ReentrantLock
    分布式 上分布式锁

  • 資深大佬 : KentY

    典型的 use case of synchronized method?

  • 資深大佬 : victooory

    Thread Join()

  • 資深大佬 : imzhoukunqiang

    Executors.newSingleThreadExecutor(),这个有 oom 风险,也可以自己设定队列最大数量

  • 資深大佬 : singerll

    程序不太懂,但这个是不是单片机原理里面讲的中断。。。

  • 資深大佬 : duwan

    这不就是只有一个生产者的生产者消费者问题吗。

  • 資深大佬 : MisakaTang

    服务站(缓存) 拿起所有的快递(批处理)

  • 資深大佬 : luckyrayyy

    单线程任务队列?

  • 資深大佬 : duwan

    说错了 只有一个消费者的生产者消费者问题

  • 資深大佬 : Hanggi

    换 go 语言,逃

  • 資深大佬 : teawithlife

    没用过 java,不知道是否有高级的办法。纯手撸的话,就是用一个 FIFO 队列。

  • 資深大佬 : soulzz

    https://gist.github.com/zgl018/31e8e599c2f882e92597ef98fbc79083

  • 資深大佬 : chibupang

    CountDownLatch 了解一下

  • 資深大佬 : soulzz

    我上面的代码好像没有概括清楚
    接收快递装箱定义为一个单独的线程或很多线程,把待发的件收集到一个 list 中,list 到了一定大小后调用派件任务

  • 資深大佬 : freebird1994

    多对一的生产消费模型?

  • 資深大佬 : guyeu

    实在没看明白主在讲什么。。上大佬们好像都看懂了,谁能不能给翻译一下。。

  • 資深大佬 : Aynamic

    @guyeu 我也不知道主讲什么

  • 資深大佬 : zzkde

    CountDownLatch 或者 CyclicBarrier ?

  • 資深大佬 : Aruforce

    看你的意思是在第一次任务执行后,由一个线程 batch 执行在第一次任务执行间提交的批量任务?

    如果是这样的话,无法做到,因为一个线程在任意时刻执行一个方法…

    如果理解错误的话,当我没说……

  • 資深大佬 : gaius

    单线程消费阻塞队列

  • 資深大佬 : 719465553

    怀疑没用过锁

  • 資深大佬 : Devin

    给 a 方法加个锁,谁拿到谁执行,其他的等待。如果需要顺序,就只能队列

  • 資深大佬 : yeqizhang

    感觉 22 翻译的对。
    但我不知道是不是无法做到。
    下一位

  • 資深大佬 : tairan2006

    这就是普通的多生产单一消费吧?生产者把东西塞队列里,消费者一次性把队列清空…

  • 資深大佬 : kmyzzy

    实在看不懂你在说什么,建议先从三年级语文学起。

  • 資深大佬 : oneisall8955

    主的问题是这样?最开始,快递员等了一段时间,只有一个快递(需要执行方法 A 的次数),于是,送了这个快递(执行方法 A ),在送这个快递这个期间,快递站收到了很多快递(收到很多方法 A ???),快递员送完第一个快递,回头一看,有那么多快递,这次就一次性送完(执行多次方法 A )。

    生产者消费者模型?

  • 資深大佬 : luozic

    生产者消费者模型,但是任务加了限定策略:任务是分包的,要么是现在包里持有的单个任务,要么是任务包(用队列打包成批处理)一次执行。
    异步+队列,这个不就是典型的执行 hold,再继续?
    实际用锁也行。

  • 資深大佬 : Aresxue

    最简单的就是锁喽, 比较适合单机情况。单机下还可以使用 LinkedBlockingQueue 、线程池(其实也是 LinkedBlockingQueue)等 juc 下的并发容器处理
    分布式下可以考虑用消息队列, 前提是本身系统已经引入了一种消息队列, 不然额外引入一种消息队列的成本还有待商榷
    想要轻量级就用个分布式锁,实现方式最好也与当前中间件结合,有 zk 用 zk,有 redis 用 redis, 啥都没有就用数据库或者文件去做

  • 資深大佬 : kongch

    第一个进去的初始化一个全局的 volatile 的 countdownlatch 到 100,然后 await,接下来进去的每次调用 countdown 一下

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具