“1.12 并发编程”属于编程语言中比较高级的部分了,让程序能同时服务更多的用户,能同时执行更多的任务,能同时处理更多的数据等等都属于并发编程的范畴。
这里面的本质原理就是单核的CPU分片执行和多核CPU同时执行的问题,一个是给人的感觉是并发执行的,一个是多个任务真正的并发执行。不管哪一种对用户来讲就是同时在处理。在计算机编程中,通过多进程可以实现并发编程,文中写到,基于中断的手段让主进程挂起,让其他子进程执行。我们很少会接触到对进程的编程,因为对我们来讲一个java程序就是一个进程,我们最多在一个进程里,通过多线程的方式实现并发。进程是一个很重量级的资源,一个java程序可以做很多事情,大到一个完整的系统,小到几个简单的接口服务。所以我们大多是在一个进程程序(或者叫应用)里编写多线程的代码,试下并发的效果。相比较进程,线程是个轻量级的概念,而且每个线程占用的资源比较少,线程的主要目的是为了切分任务,进程的主要任务是提供完整的服务。这部分在操作系统这门课程里会从系统层面详细介绍,可以去学习一下,放到编程语言层面也是通的。不管是进程和线程,他们都面临一个重要的问题:共享资源。让共享资源合理的利用,不会导致资源混乱和不可用是并发编程的主要任务,也是我们进阶为高手的重要考量。
“1.13 Java与Internet”这一节主要讲解的是Web技术的发展史,以及Java在Web技术发展过程中承担的作用。这一小节的篇幅比较长,跟这一章的主题对象导论没有关系,从1.11到1.13这四小节跟对象和抽象关系不大。不太清楚作者在这一章去讨论这些主题的目的是什么,大概是为了体现Java这门语言的价值吧。
Web技术大家每天都在接触,不管是pc端的浏览器还是移动手机上的应用,都会使用到Web技术。在讲到真正的Web技术之前,先谈到了客户/服务器计算技术。这里面就涉及到一个问题,就是客户端程序和服务器端程序存在形态的问题。在使用客户端程序的时候需要在我们的电脑上安装一个程序,服务器端程序部署在另一台服务器上,客户端程序会跟服务器端程序保持网络通信连接。服务器会为多个客户端提供服务,这里面就涉及到1.12小节中的并发技术。让服务器端程序为更多的客户端提供服务,能给客户端提供信息收集,数据处理,信息展示功能,这就是客户/服务器计算技术的主要逻辑流程。其实这个技术的基本概念并不复杂,就像书中说的,主要解决并发问题和数据处理问题。除了上面的问题以外,还有个问题就是客户端软件发生变更升级维护的问题。我们那不可能开发好一个客户端软件就不做更新升级,重新编译、调试和安装我们的客户端软件到客户端机器上比我们想像的要复杂和费力。还有支持不同类型的计算机和操作系统,需要付出很大的低价。
虽然现在客户端软件的形态还存在着,我们那手机上的app也是一种客户端程序的形式。但是为了尽可能的减轻客户端的工作量,现在很多客户端都一直到了浏览器里,让浏览器承载我们客户端程序提供的信息采集,信息展示的功能。书中提到服务器端提供交互性的静态页面,客户端浏览器负责显示,静态页面通过HTML编写的。客户端通过页面中的一些填写框填写数据,提交到一种称作CGI(通用网关接口)的地方(一个程序吧,听过但是没用过),然后转到cgi-bin目录下的一个程序进行数据处理存储,然后将结果返回给终端。可以把CGI理解为Nginx,cgi-bin目录下的一个程序理解为Springboot程序,Springboot程序通过Nginx代理出去。这么比喻是为了便于理解,因为现在的程序员对Nginx和Springboot比较熟悉。
CGI存在很多问题,主要是复杂性和维护性问题以及性能问题,所以现在不怎么用了。这一块大概了解一下即可。
下面书中讲到了客户端编程中技术演进,主要是浏览器中的技术,其中就涉及到我们java语言。现在浏览器中我们最熟悉的技术就是脚本语言JavaScript,这个技术一直到现在还在影响着Web客户端的发展,而且已经延伸到了服务器端NodeJS。Java当初在浏览器中的表现就是applet,现在使用的也少了。就是要在浏览器中安装一个插件,虽然是自动下载的,但是在使用体验上不那么友好。这种类似的插件还有ActiveX,Flash,虽然他们在以前持续了很长一段时间为我们的浏览器应用提供了很多富客户端的丝滑体验,奈何后来HTML5的出现,以及各个浏览器厂家的权衡博弈,纷纷淘汰掉了以插件形式存在的技术,也算是技术发展的形势吧。想要了解这部分历史的可以阅读其他网络资源。
服务器端编程涉及到东西就太多了,以现在的观点来梳理就是SpringBoot,SpringCloud,Nginx,Redis,数据库,消息中间件,搜索引擎,大数据套装等等。在书中提到的就是数据库技术以及使用我们Java语言编写的servlet程序,servlet以及衍生物JSP是许多开发网站的公司迁移都Java上的主要原因。这一部分有专门的Java Web技术的书籍进行详细的论述,就不在这里展开了。