×

线程和进程的关系和区别 线程

线程与进程的区别和联系?线程同步的方法都有什么

admin admin 发表于2022-05-20 12:44:55 浏览121 评论0

抢沙发发表评论

线程与进程的区别和联系


1:线程定义

  • 线程是进程的基本执行单元,一个进程的所有任务都在线程中执行

  • 进程要想执行任务,必须得有线程,进程至少要有一条线程

  • 程序启动会默认开启一条线程,这条线程被称为主线程或 UI 线程
    2:进程定义

  • 进程是指在系统中正在运行的一个应用程序

  • 每个进程之间是独立的,每个进程均运行在其专用的且受保护的内存
    3:进程与线程的区别

  • 地址空间:同一进程的线程共享本进程的地址空间,而进程之间则是独立的地址空间。

  • 资源拥有:同一进程内的线程共享本进程的资源如内存、I/O、cpu等,但是进程之间的资源是独立的。

  • 一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮。

  • 进程切换时,消耗的资源大,效率高。所以涉及到频繁的切换时,使用线程要好于进程。同样如果要求同时进行并且又要共享某些变量的并发操作,只能用线程不能用进程

  • 执行过程:每个独立的进程有一个程序运行的入口、顺序执行序列和程序入口。但是线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

  • 线程是处理器调度的基本单位,但是进程不是。

  • 4:多线程的意义

  • 优点

  • 能适当提高程序的执行效率

  • 能适当提高资源的利用率(CPU,内存)

  • 线程上的任务执行完成后,线程会自动销毁

  • 缺点

  • 开启线程需要占用一定的内存空间(默认情况下,每一个线程都占 512 KB)

  • 如果开启大量的线程,会占用大量的内存空间,降低程序的性能

  • 线程越多,CPU 在调用线程上的开销就越大

  • 程序设计更加复杂,比如线程间的通信、多线程的数据共享
    5:多线程的原理

  • (单核cpu)同一时间,cpu只能处理 1 个线程。换言之,同一时间只有 1 个线程在执行

  • 多线程同时执行:
    *是 cpu 快速的在多个线程之间的切换
    * cpu 调度线程的时间足够快,就造成了多线程的“同时”执行效果

  • 如果线程数非常多
    * cpu 会在 N 个线程直接切换,消耗大量的 cpu 资源
    * 每个线程调度的次数会降低,线程的执行效率降低


线程同步的方法都有什么


同步的实现方面有两种,分别是synchronized,wait与notify wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程。
-线程和进程的关系和区别

php多线程


以下都是转载, 简单说下, php是不支持多线程的。。。。

PHP语言本身是不支持多线程的. 总结了一下网上关于PHP模拟多线程的方法, 总的来说, 都是利用了PHP的好伙伴们本身所具有的多线程能力. PHP的好伙伴指的就是LINUX和APACHE啦, LAMP嘛.

另外, 既然是模拟的, 就不是真正的多线程. 其实只是多进程. 进程和线程是两个不同的概念. 好了, 以下方法都是从网上找来的.

1. 利用LINUX操作系统

《?php
for ($i=0;$i《10;$i++) {
echo $i;
sleep(5);
}
?》

上面存成test.php, 然后写一段SHELL代码

#!/bin/bash
for i in 1 2 3 4 5 6 7 8 9 10
do
php -q test.php &
done

2. 利用fork子进程(其实同样是利用LINUX操作系统)

《?php
declare(ticks=1);
$bWaitFlag = FALSE; /// 是否等待进程结束
$intNum = 10; /// 进程总数
$pids = array(); /// 进程PID数组
echo (“Startn“);
for($i = 0; $i 《 $intNum; $i++) {
$pids[$i] = pcntl_fork();/// 产生子进程,而且从当前行之下开试运行代码,而且不继承父进程的数据信息
if(!$pids[$i]) {
// 子进程进程代码段_Start
$str=““;
sleep(5+$i);
for ($j=0;$j《$i;$j++) {$str.=“*“;}
echo “$i -》 “ . time() . “ $str n“;
exit();
// 子进程进程代码段_End
}
}
if ($bWaitFlag)
{
for($i = 0; $i 《 $intNum; $i++) {
pcntl_waitpid($pids[$i], $status, WUNTRACED);
echo “wait $i -》 “ . time() . “n“;
}
}
echo (“Endn“);
?》

3. 利用WEB SERVER, PHP不支持多线程, APACHE可是支持的, 呵呵.

假设我们现在运行的是a.php这个文档. 但是我在程式中又请求WEB服务器运行另一个b.php

那么这两个文档将是同时执行的.

《?php
function runThread()
{
$fp = fsockopen(’localhost’, 80, $errno, $errmsg);
fputs($fp, “GET /a.php?act=brnrn“);
fclose($fp);
}
function a()
{
$fp = fopen(’result_a.log’, ’w’);
fputs($fp, ’Set in ’ . Date(’h:i:s’, time()) . (double)microtime() . “rn“);
fclose($fp);
}
function b()
{
$fp = fopen(’result_b.log’, ’w’);
fputs($fp, ’Set in ’ . Date(’h:i:s’, time()) . (double)microtime() . “rn“);
fclose($fp);
}
if(!isset($_GET[’act’])) $_GET[’act’] = ’a’;
if($_GET[’act’] == ’a’)
{
runThread();
a();
}
else if($_GET[’act’] == ’b’) b();
?》

当然啦,也可以把需要多线程处理的部分交给JAVA去处理, 然后在PHP里调用, 哈哈.

《?php
system(’java multiThread.java’);
?》
-线程