区别:
1、进程是操作系统资源分配的基本单位,线程是任务分配和调度的基本单位
2、进程的所有的资源都是独立的,包括数据段、代码段、堆空间、栈空间。线程的大部分资源都是共享进程的资源,栈空间独立占用进程的内存空间
3、所有的进程是独立的,所以进程奔溃不会影响其他进程,而线程是共享的进程资源,线程奔溃会导致整个进程奔溃
4、线程是共享数据段,所以数据同步比较方便,而进程间通信比较麻烦
5、进程的创建和销毁的开销比较大。线程的cpu利用率高,线程的编程和调试相对复杂
选择:
1、频繁的创建和消费,使用线程
2、需要cpu利用率高的,使用线程
3、强相关的应用场景,使用线程
4、大量的数据同步,使用线程
堆栈空间:
32位Linux,进程栈默认10M,可以通过ulimit修改,堆的大小理论上大概等于进程虚拟空间大小(4G)-内核虚拟内存大小(1G),所以堆空间大小小于3G
线程空间默认是8M,可以通过ulimit或在创建线程的时候修改,堆空间是共享进程的堆空间
最大进程和线程数:
因为线程的默认栈空间是8M,同时线程的栈空间是通过进程的内存空间分配的,所以默认的线程数大概是380个