| Size: 7920 Comment:  | Size: 8425 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 85: | Line 85: | 
| ErLang正如我们一样进行处理的,所以理解Erlang 程序是非常容易的. ErLang 程序生成N多小进程自由运行 -- 就象人群. 每个ErLang 可以制造几十, 可能上千的小进程 -- 所有进程的运行是独立的. 它们相互沟通就是使用消息的发送. 每个进程都有私有的内存. 如同一大空间中的人群相互游离. | |
| Line 90: | Line 98: | 
| 这使得ErLang 程序天生的容易管理及衡量. 假定我们有10人(进程)而且都很忙,我们如果处理的? | 
[http://armstrongonsoftware.blogspot.com/2006/08/concurrency-is-easy.html Concurrency is easy] -- 并行计算轻松理解版 -- [:swordsp/2007-01-29:swordsp 07-01-29 发现并推荐]
::-- ZoomQuiet [DateTime(2007-01-30T06:25:45Z)] TableOfContents
1. 试译
http://photos1.blogger.com/blogger2/3098/640384196112295/320/many_cars.0.jpg
1.1. Concurrency is easy
我们本来就理解并发的.
大脑其实已经硬性植入了并发机制的.
我们对刺激响应极其的快捷,大脑有专门一部分进行对淋巴系统的调用,没有这,我们早死了, 而意识的反应就比较慢了,例如在我们意识到"要刹车!"之时,但是身体其实已经作了.
在高速公路,我们同时要跟踪几十种情况,或是上百辆车,这都没有经过意识的处理, 如果不是这样,我们可能已经死了.
We understand concurrency
A deep understanding of concurrency is hard-wired into our brains. We react to stimulation extremely quickly, in a part of the brain called the amygdala, without this reaction system we would die. Conscious thought is just too slow, by the time the thought "hit the brakes" has formed itself, we have already done it.
On a motorway, I mentally track the positions of dozens, or hundreds of cars, this is done without conscious thought. If I couldn't do this I would probably be dead.
1.1.1. 世界是平的
The world is parallel
如果我们想在现实世界中完成一种行为同其它对象一般规矩 的程序,它必然是并行的.
If we wish to write programs that behave as other objects behave in the real world then these programs will have a concurrent structure.
1.1.2. 这就是为什么我们要使用并发语言进行编程
This is why we should program in a concurrent programming language
当然我们在现实世界中最常见的是使用序列语言进行编程,想解放思想很难. ErLang 是被设计为天然进行并发处理的语言,使用它来编写并发程序非常简单.
And yet most often we program real-world applications in sequential programming languages. This is uncessarily difficult.
By programming in a language what was designed for programming concurrent applications (like Erlang) concurrent programming becomes a lot easier.
1.1.3. Erlang 程序模仿我们的思想和交互
Erlang programs model how we think and interact
我们没有共享记忆,各有各的,我们共有两个大脑,它们并没有合并在一起. 为了改变你的记忆,我得发出消息,说话或是挥动手臂. 你听到,看到,你的记忆就变更了,但是不问一下你或是不观察你的反应,我没有办法确认你接受了我的消息.
这就是Erlang 的处理过程, ErLang的进程没有分享内存,每个进程各用自个儿的. 改变另外进程,你必须给其发送渻,并期望它可以接受并理解.
为确认另外进程接受你的消息并变更了它的内存,你必须查询(通过消息的发送). 这恰恰是我们如何交互的过程.
We don't have shared memory. I have my memory, you have yours, we have two brains, one each, they are not joined together. To change your memory I send you a message, I talk or wave my arms. You listen, you see, your memory changes, but without asking you a question or observing your response I do not know that you have received my messages.
This is how it is with Erlang processes. Erlang processes have no shared memory. Each processes has its own memory. To change the memory of some other process you must send it a message and hope that it receives and understands the message.
To confirm that another process has received your message and changed its memory, you must ask it (by sending it a message). This is exactly how we interact.
李四:"嘿,张三我电话是 12345678 "
李四:"听到? "
张三:"是,你电话是 12345678"
Sue: "Hi Bill, my telephone number is 45 67 89 12"
Sue: "Did you hear me?"
Bill: "sure, your number is 45 67 89 12"
这种交互模型,我们都明白,一出生,我们就一直在学习如何通过发送消息和观察反应来同世界交互.
These interaction patterns well-know to us, from birth onwards we learn to interact with the world by observing it and by sending it messages and observing the responses.
1.1.4. 人们作为独立应用运行使用消息的发送进行沟通
People function as independent entities that communicate by sending messages
ErLang正如我们一样进行处理的,所以理解Erlang 程序是非常容易的.
ErLang 程序生成N多小进程自由运行 -- 就象人群.
每个ErLang 可以制造几十, 可能上千的小进程 -- 所有进程的运行是独立的. 它们相互沟通就是使用消息的发送. 每个进程都有私有的内存. 如同一大空间中的人群相互游离.
That's how Erlang processes work, and that's how we work so it's very easy to understand an Erlang program.
Erlang programs are made up of lots of little processes all chattering away to each other - just like people.
An Erlang program is made up of dozens, possible thousands or even hundreds of thousands of small processes - all these processes operate independently. They communicate with each other by sending messages. Each process has a private memory. They behave like a huge room of people all chattering away to each other.
这使得ErLang 程序天生的容易管理及衡量. 假定我们有10人(进程)而且都很忙,我们如果处理的?
This makes Erlang program inherently easy to manage and scale. Suppose we have ten people (processes) and they have too much work to do, what can we do? get more people. How can we manage these groups of people, easy just shout instructions at them (broadcasting).
Erlang processes don't have shared memory, so there is no need to lock the memory while it is being used. Where there are locks, there are keys, and when there are keys the keys will one day get lost and what happens when you loose a key? - you panic.
Distributed software systems with locks and keys always go wrong.
1.1.5. If somebody dies other people will notice
I I'm in a room and suddenly keel over and die, somebody will probably notice, well at least I hope so. Erlang processes are just like people, they can on occasions die. Unlike people when they die they shout out in their last breath exactly what they have died from.
Imagine a room full of people, suddenly one person will keel over and die and just as they die, they say "I'm dying of a heart attack" or "I'm dying of an exploded gastric wobbledgog". That's what Erlang processes do. One process might die saying.
"I'm dying because I was asked to divide by zero", another might say
"I'm dying because because I was asked what the last element in an empty list was"
Now in our room full of people we might imagine there are specially assigned people whose job it is to clear away the bodies. Let's imagine two people Jane and John. If Jane dies then John will fix any problems associated with Jane's death. If Jane dies then John will fix the problems. Jane and John are linked together with an invisible agreement which says that if one of them dies the other will fix up any problems caused by the death.
That's is how error detection in Erlang works, processes can be linked together. If one of the processes dies, the other process gets an error message saying why the first process dies.
That's basically it.
That's how Erlang programs work.
1.1.6. What we've learnt so far
Erlang programs are made of lots of processes. These processes can send messages to each other.
These message may or may not be received and understood. If you want to know if a message was received and understood you must send the process a message and wait for a reply.
Pairs of processes can be linked together. If one processes in a linked pair dies the other process in the pair will be sent a message containing the reason why the first process died.
This simple model of programming is part of a model I call Concurrency Oriented Programming. You can read more about this here.
Posted by Joe Armstrong at 12:14 AM
Labels: concurrency, erlang, message passing
