work=new Worker("script/lengthytask.js")传入参数是js文件的连接;work.postmessage("hello world")用来主线程向子线程发送数据;
work.addEventListener("message",function(){},true)
是主线程处理子线程消息;子线程处理发送消息一样只是不用写work对应的对象
搜索一下Concurrent.Thread,它是一个允许进行多线程编程的库。其实都是使用settimeout之类的函数模拟出来的
例如:
settimeout(function1,1)
settimeout(function2,1)
settimeout(function3,1)
这样就相当于同时触发三个函数。如果这三个函数都是调用一段功能的代码,那就相当于同时执行三次,也就是三个线程。
JS本身是不支持多线程的。
单线程,所有任务都是一条直线的执行下去,前一个任务结束,才会执行后一个任务。如果前一个任务死循环或者需要好长时间执行,后一个任务就要一直等,直到前一个执行完。为什么平时看到setTimeout那些感觉是多线程执行,那是因为线程上执行速度很快就过了,所以看到那些“延时任务”好像是马上执行。
执行方法A(设定一个定时器,这个定时器插入到队列)-funB-funC-funD;
当funD执行完了,这时候才开始执行定时器。