乙巳🐍年

acc8226 的博客

Java SE 提供 java.net 包,其中包含了网络编程所需要的最基础一些类和接口。

这些类和接口面向两个不同的层次:基于 Socket 的低层次网络编程和基于 URL 的高层次网络编程,所谓高低层次就是通信协议的高低层次,Socket 采用 TCP、UDP 等协议,这些协议属于低层次的通信协议;URL 采用 HTTP 和 HTTPS 这些属于高层次的通信协议。低层次网络编程,因为它面向底层,比较复杂,但是“低层次网络编程”并不等于它功能不强大。恰恰相反,正因为层次低,Socket 编程与基于 UR L的高层次网络编程比较,能够提供更强大的功能和更灵活的控制,但是要更复杂一些。

数据交换格式

数据交换格式主要分为纯文本格式、XML 格式和 JSON 格式,其中纯文本格式是一种简单的、无格式的数据交换方式。

JSON 文档结构

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。所谓轻量级,是与 XML 文档结构相比而言的,描述项目的字符少,所以描述相同数据所需的字符个数要少,那么传输速度就会提高,而流量却会减少。

构成 JSON 文档的两种结构为对象和数组。对象是“名称-值”对集合,它类似于Java中Map类型,而数组是一连串元素的集合。

JSON 对象

对象是一个无序的“名称/值”对集合,一个对象以{(左括号)开始,}(右括号)结束。每个“名称”后跟一个:(冒号),“名称-值”对之间使用,(逗号)分隔。JSON 对象的语法表如图。

阅读全文 »

三种基本结构

顺序结构、循环结构和选择结构是程序设计中常见的三种基本结构,它们共同构建了程序的执行流程:

  1. 顺序结构:就像一条直线,代码按照从上到下的顺序依次执行,一个步骤接着一个步骤。这种结构简单直接,适用于执行一系列连续的操作。
  2. 选择/分支结构:它就像是一个岔路口,根据不同的条件来决定走哪条路。通过选择结构,我们可以根据不同的情况执行不同的代码块,实现灵活的决策和分支处理。
  3. 循环结构:就像一个循环的圈圈,它让代码在满足特定条件的情况下,重复执行一段代码。循环结构可以帮助我们处理大量相似或重复的任务,节省代码量并提高效率。

这三种结构相互结合,使得程序能够根据不同的情况和需求进行灵活的控制和执行。它们是编程的基础,帮助开发者构建出各种功能和逻辑复杂的程序。

顺序结构详解

顺序结构是指按照代码的自然顺序依次执行语句,一个语句执行完后接着执行下一个语句。

选择/分支结构详解

选择结构根据特定的条件来决定执行哪部分代码,可以使用 if-else 语句、switch 语句等。

阅读全文 »

数据持久技术概述

把数据保存到数据库中只是一种数据持久化方式。凡是将数据保存到存储介质中,需要的时候能够找到它们,并能够对数据进行修改,这些就属于数据持久化。

Java 中数据持久化技术有很多:

1. 文本文件
通过 Java I/O 流技术将数据保存到文本文件中,然后进行读写操作,这些文件一般是结构化的文档,如 XML、JSON 和 CSV 等文件。结构化文档就是文件内部采取某种方式将数据组织起来。

2. 对象序列化
序列化用于将某个对象以及它的状态写到文件中,它保证了被写入的对象之间的关系,当需要这个对象时,可以完整地从文件重新构造出来,并保持原来的状态。在 Java 中实现 java.io.Serilizable 接口的对象才能被序列化和反序列化。Java 还提供了两个流:ObjectInputStream 和 ObjectOutputStream。但序列化不支持事务处理、查询或者向不同的用户共享数据。序列化只适用于最简单的应用,或者在某些无法有效地支持数据库的嵌入式系统中。

3. 数据库
将数据保存数据库中是不错的选择,数据库的后面是一个数据库管理系统,它支持事务处理、并发访问、高级查询和SQL语言。Java 对象保存到数据库中主要的技术有:JDBC1、EJB2 和 ORM3 框架等。JDBC 是本书重点介绍的技术。

MySQL 数据库管理系统

介绍 JDBC 技术一定会依托某个数据库管理系统 (Database Management System,缩写 DBMS),还会使用 SQL 语句,所以本节先介绍一下数据库管理系统。

数据库管理系统负责对数据进行管理、维护和使用。现在主流数据库管理系统有 Oracle、SQL Server、DB2、Sysbase 和 MySQL 等,本节介绍 MySQL 数据库管理系统使用和管理。

阅读全文 »

进程和线程

进程: 一个正在执行的程序。每个进程执行都有一个执行顺序,该顺序是一个执行路径,或叫一个控制单元。一个进程至少有一个线程。

线程:就是进程中的一个独立的控制单元. 线程控制这进程的执行。

多进程的缺点:进程切换开销大;进程间的通信不方便。

多线程: 指的是在单个程序中可以同时运行多个不同的线程,执行不同的任务,线程切换的开销小 。

在 Java 中,当我们启动 main 函数时其实就启动了一个 JVM 的进程,而 main 函数所在的线程就是这个进程中的一个线程,也称主线程。

线程创建与运行

Java 中表示线程,用到了 Thread 类。其构造方法如下:

阅读全文 »

多线程协作的基本机制 wait/notify

多线程之间除了竞争访问同一个资源外,也经常需要相互协作,怎么协作呢?本节就来介绍Java中多线程协作的基本机制 wait/notify

wait 实际上做了什么呢?它在等待什么?之前我们说过,每个对象都有一把锁和等待队列,一个线程在进入 synchronized 代码块时,会尝试获取锁,如果获取不到则会把当前线程加入等待队列中,其实,除了用于锁的等待队列,每个对象还有另一个等待队列,表示条件队列,该队列用于线程间的协作。

notify 做的事情就是从条件队列中选一个线程,将其从队列中移除并唤醒,notify 和 notifyAll 的区别是,它会移除条件队列中所有的线程并全部唤醒。

wait/notify 方法只能在 synchronized 代码块内被调用,如果调用 wait/notify 方法时,当前线程没有持有对象锁,会抛出异常 java.lang.IllegalMonitor-StateException。

阅读全文 »
0%