重温经典《Thinking in java》第四版之第一章 对象导论(八)

简介: 重温经典《Thinking in java》第四版之第一章 对象导论(八)

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技术的书籍进行详细的论述,就不在这里展开了。

目录
相关文章
|
1月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
2月前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
50 17
|
1月前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
2月前
|
存储 Java 数据管理
Java零基础-Java对象详解
【10月更文挑战第7天】Java零基础教学篇,手把手实践教学!
31 6
|
2月前
|
Oracle Java 关系型数据库
重新定义 Java 对象相等性
本文探讨了Java中的对象相等性问题,包括自反性、对称性、传递性和一致性等原则,并通过LaptopCharger类的例子展示了引用相等与内容相等的区别。文章还介绍了如何通过重写`equals`方法和使用`Comparator`接口来实现更复杂的相等度量,以满足特定的业务需求。
29 3
|
1月前
|
存储 缓存 NoSQL
一篇搞懂!Java对象序列化与反序列化的底层逻辑
本文介绍了Java中的序列化与反序列化,包括基本概念、应用场景、实现方式及注意事项。序列化是将对象转换为字节流,便于存储和传输;反序列化则是将字节流还原为对象。文中详细讲解了实现序列化的步骤,以及常见的反序列化失败原因和最佳实践。通过实例和代码示例,帮助读者更好地理解和应用这一重要技术。
43 0
|
2月前
|
存储 前端开发 Java
你还没有对象吗?java带你创建一个吧
你还没有对象吗?java带你创建一个吧
14 0
|
5天前
|
安全 Java API
java如何请求接口然后终止某个线程
通过本文的介绍,您应该能够理解如何在Java中请求接口并根据返回结果终止某个线程。合理使用标志位或 `interrupt`方法可以确保线程的安全终止,而处理好网络请求中的各种异常情况,可以提高程序的稳定性和可靠性。
35 6
|
20天前
|
设计模式 Java 开发者
Java多线程编程的陷阱与解决方案####
本文深入探讨了Java多线程编程中常见的问题及其解决策略。通过分析竞态条件、死锁、活锁等典型场景,并结合代码示例和实用技巧,帮助开发者有效避免这些陷阱,提升并发程序的稳定性和性能。 ####
|
18天前
|
存储 监控 小程序
Java中的线程池优化实践####
本文深入探讨了Java中线程池的工作原理,分析了常见的线程池类型及其适用场景,并通过实际案例展示了如何根据应用需求进行线程池的优化配置。文章首先介绍了线程池的基本概念和核心参数,随后详细阐述了几种常见的线程池实现(如FixedThreadPool、CachedThreadPool、ScheduledThreadPool等)的特点及使用场景。接着,通过一个电商系统订单处理的实际案例,分析了线程池参数设置不当导致的性能问题,并提出了相应的优化策略。最终,总结了线程池优化的最佳实践,旨在帮助开发者更好地利用Java线程池提升应用性能和稳定性。 ####