maven依赖管理
maven工程可以帮助我们管理jar包的依赖,他有一个jar包仓库,这导致我们自己的项目会非常小。
maven启动
1 | mvn tomcat:run |
maven仓库启动
先本地,然后私服,然后中央仓库
Java代码
核心代码+配置文件+测试代码+测试配置文件
传统项目
1 | workspace |
类似PCB
一个进程可以同时存在多个线程,各个线程之间可以并发执行,各个线程之间可以恭喜那个地址空间和文件资源。
一个线程崩溃会导致所属进程的所有线程崩溃。
进程是资源分配单位,线程是CPU调度单位
进程拥有完整的资源平台,线程只独享其中的寄存器和栈
线程也有就绪阻塞执行三种状态和状态转化关系
线程能减少并发执行的时间和空间开销,线程创建终止块,切换快,共享资源可直接进行不依赖内核通信。
用户线程操作系统看不到,内核线程操作系统看得到
线程的创建终止同步和调度都是线程库实现的。TCB在进程内部
当一个线程阻塞以后,整个进程都阻塞了,因为操作系统看不到用户心线程,只能看到进程。
优点: 一个程序的物理空间是非连续的,更好的内存利用,允许共享代码与数据(共享库等),支持动态加载和动态链接
程序等栈段、堆段、数据段、等等分散到多个物理空间,
段号+偏移量,高位为段号,低位为偏移量,用段表来映射,段表中存了起始地址和长度信息,CPU可以在访问前做安全检测,
让段的长度固定,就成了分页机制。
物理内存被分割为大小相等的帧
dirtybit+residentbit+clockbit+页帧号
访问一个内存单元需要两次访问: 页表+数据
页表太大怎么办,多个程序多个页表,更大了,这个不能放到cpu,放到内存又会很慢