首先我告诉你,php程序员要想发展到底层,必须要学习数据结构。
数据结构是基础,比如链表、二叉树、hash、排序算法等。写php代码的时候可能用不到,但是掌握了它们会让你对程序的运行原理有更深的理解。
我们经常使用php数组,既可以foreach的遍历,也可以k
1.首先打开phpstudy软件,然后打开mysql管理器,登录管理器。
2.单击数据库,输入要创建的数据库的名称,然后单击创建。
3.单击用户添加用户。一般主持人选择本地。密码设置有两种,一种是自己设置的,一种是系统自动生成的。
4.添加成功后,编辑用户权限,设置数据和结构的权限,然后单击执行。
5.以上操作完成后,数据库就建立好了。
首先,php流程模型
进程的概念是操作系统结构的基础。multics的设计者在60年代首次使用这个专业术语,比作业更笼统。流程的定义如下:
1.正在执行的程序。
2.计算机中正在运行的程序的例子。
3.可以分配给处理器并由处理器执行的实体。
4.由单个顺序执行线程、当前状态和一组相关系统资源描述的活动单元。
二、进程和线程的区别
进程是资源分配的基本单位。与过程相关的所有资源都记录在过程控制块pcb中。来表示进度。程拥有或正在使用这些资源。
另外,进程也是抢占式处理器的调度单元,它拥有完整的虚拟地址空间。在调度进程时,不同的进程有不同的虚拟地址空间,而同一进程中的不同线程共享相同的地址空间。
对应一个进程,线程与资源分配无关。它属于一个进程,并与该进程中的其他线程共享该进程的资源。
线程仅由相关的堆栈(系统堆栈或用户堆栈)寄存器和线程控制表tcb组成。寄存器可用于存储线程内的局部变量,但不能存储其他线程的相关变量。
通常,一个进程可以包含几个线程,这些线程可以利用进程所拥有的资源。在有线程的操作系统中,进程通常被视为分配资源的基本单位,而线程则被视为独立运行和独立调度的基本单位。由于线程比进程小,基本没有系统资源,其调度的成本会小很多,可以更高效地提高系统中多个程序并发执行的程度,从而显著提高系统资源的利用率和吞吐量。因此,近年来,通用操作系统为了进一步提高系统的并发性,纷纷引入线程,并将其作为现代操作系统的重要指标。
线程和进程之间的差异可以总结如下:
(1)进程是资源分配和调度的独立单位,而线程是cpu调度的基本单位。
(2)同一个进程中可以包含多个线程,线程共享整个进程的资源(寄存器、栈、上下文),每个进程至少包含一个线程。
(3)进程的创建调用fork或vfork,而线程的创建调用pthread_create。进程结束后,它拥有的所有线程都将被销毁,一个线程的结束不会影响同一进程中其他线程的结束。
(4)线程是轻量级进程,创建和销毁线程所需的时间比进程少得多。操作系统中所有的执行功能都是通过创建线程来完成的。
(5)在线程中执行时,一般需要同步和互斥,因为它们共享同一个进程的所有资源。
(6)线程有自己的私有属性tcb、线程id、寄存器和硬件上下文,而进程也有自己的私有属性进程控制块pcb,这些属性是不共享的,用来标记一个进程或线程。
第三,进程间的通信
1.管道和命名管道:管道可用于相关进程之间的通信。著名管道克服了管道没有名字的限制,因此除了管道的功能之外,它们还允许不相关的进程之间的通信。
2.信号:信号是一种复杂的通信,用于通知接收进程某个事件已经发生。除了进程间通信,进程还可以向进程本身发送信号。linux不仅支持unix的早期信号语义。除了sigal,还支持sigaction这种语义符合posix.1标准的信号函数(其实这个函数是基于bsd的,bsd为了实现可靠的信号机制和统一对外接口,用sigaction函数重新实现了信号函数);
3.消息队列(messagequeue):消息队列是消息的链表,包括posix消息队列systemvmessagequeue。拥有足够权限的进程可以将消息添加到队列中,拥有读取权限的进程可以从队列中读取消息。消息队列克服了信号携带信息量少、流水线只能携带无格式字节流和缓冲区大小有限的缺点。
4.共享内存:它允许多个进程访问同一个内存空间,这是最快的ipc形式。它是针对其他通信机制的低效率而设计的。它通常与其他通信机制(如信号量)结合使用,以实现进程间的同步和互斥。
信号量(semaphore):主要用作进程之间以及同一进程的不同线程之间的同步手段。
socket:一种更通用的进程间通信机制,可用于不同机器之间的进程间通信。它最初是由unix系统的bsd分支开发的,但现在它一般可以移植到其他类似unix的系统:linux和systemv支持套接字的变体。