|
x*******6 发帖数: 262 | 2 请问和threadpool之类的工具有什么区别?总得给个Callable或者Runnable来提交任务
吧 |
|
|
N***m 发帖数: 4460 | 4 恕冒昧,我不懂,你这个和自己创建的thread有啥区别? |
|
o**2 发帖数: 168 | 5
这个区别有点象汽车的自动档和手动档的区别。你直接用thread,可以最贴心地控制硬
件的功能。但是对大多数的应用来说,更关心的是易用性和productivity。
我这样回答太虚了一点,要不你举个实际应用中的实例,我们用两种方法来讨论讨论? |
|
N***m 发帖数: 4460 | 6 你说的易用性是怎么回事?我觉得用thread已经很简单了 |
|
s******e 发帖数: 493 | 7 read your blog. what is the difference between your stuff and java 1.5/1.6
executor framework? is it a wrapper on top of executor framework? |
|
o**2 发帖数: 168 | 8 的确,对有些问题来说,thread已经是很简单的了。 |
|
o**2 发帖数: 168 | 9 在blog post里,我把Java的executor framework归类成thread pool这一大类了。
Fast Messenger是用thread pool来实现的,因为最终来说硬件只有一种concurrency的
手段,就是threads。
FM有自己的一套programming model,所以不能算是thread pool的一层wrapper。但反
过来,FM可以模拟thread pool的功能。用thread pool的程序可以几乎结构不变地用FM
改写。 |
|
o**2 发帖数: 168 | 10 因为没有资源,FM这个project现在还没有什么文档,我计划在6个月到1年左右慢慢完
善。
各位提的问题都非常合理,只是在论坛的环境下,很多问题不能长篇大论地答复了,非
常抱歉。
我争取发一些具体的代码段啊什么的,这样可以讨论得起来。 |
|
e***l 发帖数: 710 | 11 感觉工作量并没有简化,只是换个形式,把逻辑放到那些objects里面去了。 |
|
o**2 发帖数: 168 | 12 你说得对,business logic放到那些object里去了。这是FM提供benefit给programmer
的开始:
1,这些object是active的,也就是你不需要安排thread什么的了。这很象browser和
website的关系,你发request,可以得到response。做dataflow也很方便。
2,这些object是有名字的,你用名字access它们,而不需要管它们的reference。
3,这些object的里面,你的business logic是在一个single threaded的环境里执行,
减少了race condition。
先想到这几点。 |
|
g*****g 发帖数: 34805 | 13 估计就是Actor model吧。不知道跟Akka比起来有何优势? |
|
o**2 发帖数: 168 | 14 从making object active这个角度来说,actor/agent/active object应该都算这一大
类的了。和普通的object比,这是决定性的一点。但在所有的actor-like的系统里,大
家都有这个基本点,所以反而是最不值一提的东西了。
我简单看过Akka的文档,觉得是一个很完善的系统,比如支持transactional
messaging。
FM和其他actor-like的系统比,优势在于:
1)紧抱着OO model的大腿,把自己看成OO的扩展,而不是actor model。作为结果,FM
目前提供在Java,C#和JavaScript上的implementation。
2)紧贴着developer for general programming,而不是research。完全没有陌生的
framework和syntax。
先写这两点,过几天我用FM写一个Akka tutorial里的PI示范程序,来比较比较。 |
|
o**2 发帖数: 168 | 15 By the way, how can I get email notifications for new replies as the
original poster? Thanks. |
|
s*******e 发帖数: 3042 | 16 仔细看了一下,感觉没有太多吸引力啊,现在的java thread model很成熟很好用,你
的tool的确是有新东西,但是看不出解决了什么问题,或者提供了什么更好的服务。 |
|
o**2 发帖数: 168 | 17 这个问题提得很好,只是不好回复,因为太open了,要等FM的文档齐了才能全面解释得
好。
这里我只是针对性地讨论一下。Thread相关的编程技术很成熟说明了对它的研究比较透
彻了。对它懂得更多并不等于它本身的性质和能力就更强更广了,同时,也并不等于大
多数人都掌握了。
其实对thread了解得更深,越发理解它只是bolts&nuts级别的coding工具,而在设计级
别上并不给力。比如,Brian Goetz 的书 Java concurrency in practice算不错了的
吧。全书通篇都是编码级别的东西,只有第6章从设计的角度谈了一下task,也就是众
所周知的thread pool的编程模式。
Thread没有提供有用的工具让程序员在设计软件结构等总体architecture的时候有所帮
助。Thread在设计的时候只是作为一个独立执行的概念出现的,比如这个模块要有自己
的thread独立执行,然后安排和其他模块如何交接task。在编码的时候thread相关的
API才会出来,这样在设计和编码阶段,thread在程序员脑子里的概念是不统一的。
即使对thread很了解了,可... 阅读全帖 |
|
|
z*******3 发帖数: 13709 | 19 木有认真看你在做啥
不过从前面的人的说法看
貌似有两个东西你最好看看
一个是akka,akka有一个不好就是annotation支持比较差
如果你能做一个annotation支持的thread lib的话,还是有戏的
另外一个是work flow
work flow engine有一个标准叫做bpm
java的是jbpm,这个标准相对成熟
而且很多产品都已经可视化了,拖拖拽拽就搞定了
所以如果你想要继续
不妨认真思考一下这两个成型的产品系列会不会对你这个产品的生存造成冲击
programmer |
|
t*******e 发帖数: 684 | 20 这个看上去和akka差不多,都是message based concurrency model.
Camel, Zookeeper都有akka的实现了,估计spring integration也快有了。 |
|
o**2 发帖数: 168 | 21 这个 post 已经放弃很久了,现在转战到 Programming 版了。 |
|
Y**G 发帖数: 1089 | 22 亚麻有个SWF - simple workflow framework |
|
A*******s 发帖数: 3942 | 23 我要是没记错的话,这些proc会自动判断是否需要multithread。如果你加上thread/
nothread option的话,就会强制(非)多线程。应该和rsubmit/endrsubmit无关 |
|