node怎样模拟多进程?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了node怎样模拟多进程?相关的知识,希望对你有一定的参考价值。

node怎样模拟多进程

参考技术A 我们能使用 exec方法创建子进程,子进程的输出被缓存在 buffer 中。当子进程终止之后,exec的回调函数得到调用,将 buffer 一次性全部输出。
另外,我们还可以使用 spawn方法创建子进程:
参考技术B 这个话怎么样?就是模拟多进程的话,就是还是需要经过多家实验啊,等等。

Android开发中怎样用多进程用多进程的好处多进程的缺陷解决方法(转)

转自:http://blog.csdn.net/spencer_hale/article/details/54968092

 

1.怎样用多进程

Android多进程概念:一般情况下,一个应用程序就是一个进程,这个进程名称就是应用程序包名。我们知道进程是系统分配资源和调度的基本单位,所以每个进程都有自己独立的

资源和内存空间,别的进程是不能任意访问其他进程的内存和资源的。

如何让自己的应用拥有多个进程:

四大组件在AndroidManifest文件中注册的时候,有个属性android:process这里可以指定组件的所处的进程。

默认就是应用的主进程。指定为别的进程之后,系统在启动这个组件的时候,就先创建(如果还没创建的话)这个进程,然后再创建该组件。打印出它的进程名称:重

载Application类的onCreate方法即可。

设置android:process属性,要注意:如果是android:process=”:deamon”,以:开头的名字,表示这是一个应用程序的私有进程,否则它是一个全局进程。私有进程的进程名称是

会在冒号前自动加上包名,而全局进程则不会。一般我们都是有私有进程,很少使用全局进程。

 

2.用多进程的好处

好处:

(1)分担主进程的内存压力。

当应用越做越大,内存越来越多,将一些独立的组件放到不同的进程,它就不占用主进程的内存空间了。当然还有其他好处,有心人会发现

(2)使应用常驻后台,防止主进程被杀守护进程,守护进程和主进程之间相互监视,有一方被杀就重新启动它。

Android后台进程里有很多应用是多个进程的,因为它们要常驻后台,特别是即时通讯或者社交应用,不过现在多进程已经被用烂了。

典型用法是在启动一个不可见的轻量级私有进程,在后台收发消息,或者做一些耗时的事情,或者开机启动这个进程,然后做监听等。

#坏处:消耗用户的电量。

            多占用了系统的空间,若所有应用都这样占用,系统内存很容易占满而导致卡顿。

            应用程序架构会变得复杂,因为要处理多进程之间的通信。这里又是另外一个问题了。

 

3.多进程的缺陷

进程间的内存空间是不可见的。开启多进程后,会引发以下问题:

1)Application的多次重建。

2)静态成员的失效。

3)文件共享问题。

4)断点调试问题。

 

4.解决方法

1)针对Application的多次重建:

在Application的onCreate中获取进程Id来判断不同进程,然后做不同的事情。

public class MyApplication extends Application {

@Override

public void onCreate() {

super.onCreate();

//获取进程Id

int pid = android.os.Process.myPid();

Log.e("m_tag", "MyApplication onCreate pid is " + pid); //根据进程id获取进程名称

String pName = getProcessName(this,pid);

if("com.xyy.processtest".equals(pName)){

//处理该进程的业务

}

}

}

public String getProcessName(Context cxt, int pid) {

ActivityManager am = (ActivityManager)

cxt.getSystemService(Context.ACTIVITY_SERVICE);

List<RunningAppProcessInfo> runningApps = am.getRunningAppProcesses();

if (runningApps == null) {

return null;

}

for (RunningAppProcessInfo procInfo : runningApps) {

if (procInfo.pid == pid) {

return procInfo.processName;

}

}

return null;

}

2)针对静态成员的失效:

使用Intent或者aidl等进程通讯方式传递内容,不能用静态或单例模式。

3)针对文件共享问题:

多进程情况下会出现两个进程在同一时刻访问同一个数据库文件的情况。这就可能造成资源的竞争访问,导致诸如数据库损坏、数据丢失等。在多线程的情况下我们有锁机制控制资源的共享,但是在多进程中比较难,虽然有文件锁、排队等机制,但是在Android里很难实现。解决办法就是多进程的时候不并发访问同一个文件,比如子进程涉及到操作数据库,就可以考虑调用主进程进行数据库的操作。

4)针对断点调试问题:

调试就是跟踪程序运行过程中的堆栈信息,由于每个进程都有自己独立的内存空间和各自的堆栈,无法实现在不同的进程间调试。因此要改为同一进程:调试时去掉AndroidManifest.xml中android:process标签,这样保证调试状态下是在同一进程中,堆栈信息是连贯的。待调试完成后,再将标签复原。

以上是关于node怎样模拟多进程?的主要内容,如果未能解决你的问题,请参考以下文章

Android开发中怎样用多进程用多进程的好处多进程的缺陷解决方法(转)

Node.js 多进程

node 多进程学习

node 多进程学习

走进Node.js之多进程模型

系列3|走进Node.js之多进程模型