黑马程序员——java语言——包

本文详细介绍了Java中的包(package)概念及其作用,包括如何定义和使用带包的类、编译及运行流程,并解释了不同访问权限在包间的作用。此外还介绍了jar文件的概念、压缩方法及运行方式。
---------------------- android培训、java培训、期待与您交流! ---------------------- .

(package)

l 作用:

对类文件进行分类管理。

给类提供多层命名空间。

写在程序文件的第一行。

类名的全称的是 

包名.类名 

包也是一种封装形式。

1.1. 包

Ø Java中常用的包

Ÿ java.lang

包含一些Java语言的核心类,如StringMathIntegerSystemThread,提供常用功能。

Ÿ java.awt

包含了构成抽象窗口工具集(abstract window toolkits)的多个类,这些类被用来构建和管理应用程序的图形用户界面(GUI)

Ÿ java.net

包含执行与网络相关的操作的类。 

Ÿ java.io

包含能提供多种输入/输出功能的类。

Ÿ java.util

包含一些实用工具类,如定义系统特性、使用与日期日历相关的函数。

Ø 定义带包类

Ÿ 使用package语句加上包名来定义类所属于的包,包名全部小写

Ÿ package语句为Java源文件的第一条语句

Ÿ 如果一个类中没有使用package语句,这个类为缺省无包名

Ÿ 一个类如果想被其他包中的类引用,必须使用public关键字修饰。构造函数也需要public

如果一个类被声明为public,那么必须和文件名同名

Ø 使用带包的类

Ÿ 在使用带包的类时需要使用全限定名(包名.类名)

Ÿ 在每次写类名时都使用全限定名很麻烦,我们可以使用import导入包,之后再使用就无需写包名了

星号*:导入一个包中所有类。优先匹配当前包中的类,如果当前包没有再匹配导入包中的类。

具体类名:导入指定一个类。无论当前包中是否有同名类,都直接匹配导入的类。

Ÿ 无包的类可以使用有包的类,有包的类不能使用无包的类。

Ø 编译运行带包的类

Ÿ 编译一个带包的源文件,在生成class文件的同时需要生成包文件

编译命令:javac –d <目录源文件名.java

Ÿ 运行有包的类时需要加上包名

运行命令:java 包名.类名   

 

 

 

建议,不要写通配符 ,需要用到包中的哪个类,就导入哪个类。

 

 

包与包之间进行访问,被访问的包中的类以及类中的成员,需要public修饰。

 

不同包中的子类还可以直接访问父类中被protected权限修饰的成员。

 

包与包之间可以使用的权限只有两种,public  protected

 

 

java.lang : java的核心包 jdk1.2版本以后,该包中的类自动导入。

java.awt: 用于制作图形界面。

java.io:input output  用于操作设备上的数据。

java.util : 这里定义是java的工具类。集合,日期。

java.net:用于网络通讯的。

java.applet:  application  let        server  let    servlet      java server page   jsp  

 

1.2. jar文件

Ø 什么是jar文件

Ÿ jar文件是Java文件的一种压缩格式

Ÿ 一般来讲,我们会将一个软件系统的所有class文件打成一个jar文件以供别人使用

Ÿ 当我们用到jar包中的类时,需要将jar文件的绝对路径加到classpath当中

Ø 如何压缩jar文件

Ÿ 将编译好的带包的class文件压缩成一个jar文件称为打jar

Ÿ 打jar命令:jar cvf jar包名.jar 要打包的文件/文件夹

Ÿ 运行jar文件命令: java -jar jar文件名.jar

 

 

 




---------------------- android培训、java培训、期待与您交流! ---------------------- .

转载于:https://www.cnblogs.com/heima-jieqi/archive/2012/04/08/2438237.html

### TCP传输原理与实现 TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层协议。其核心原理是通过建立端到端的连接,确保数据在不可靠的网络中能够可靠地传输。TCP 使用确认机制、流量控制、拥塞控制等机制来保障数据的完整性和有序性。 在 Java 中,TCP 通信可以通过 `Socket` 和 `ServerSocket` 实现。客户端使用 `Socket` 连接到服务器,服务器端使用 `ServerSocket` 监听连接请求。通信过程中,数据通过输入流和输出流进行传输。 #### 客户端实现 客户端的主要任务是与服务器建立连接,并通过输出流向服务器发送数据,同时可以通过输入流接收服务器的响应。例如: ```java Socket s = new Socket(InetAddress.getLocalHost(), 10004); OutputStream out = s.getOutputStream(); out.write("Hello TCPClient".getBytes()); InputStream is = s.getInputStream(); byte[] buffer = new byte[1024]; int len = is.read(buffer); System.out.println(new String(buffer, 0, len)); s.close(); ``` 该代码实现了客户端与服务器的连接,并发送了一条文本消息,同时接收服务器的响应[^1]。 #### 服务端实现 服务端通过 `ServerSocket` 监听指定端口,等待客户端连接。一旦连接建立,服务端通过输入流接收客户端发送的数据,并通过输出流向客户端发送响应。例如: ```java ServerSocket ss = new ServerSocket(10012); Socket s = ss.accept(); InputStream in = s.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println(new String(buffer, 0, len)); PrintWriter out = new PrintWriter(s.getOutputStream(), true); out.println("<font color='red' size=7>客户端s你好</font>"); s.close(); ss.close(); ``` 该代码展示了如何在服务端接收客户端发送的数据,并向客户端发送 HTML 格式的响应[^3]。 #### TCP连接的建立与释放 TCP 连接的建立采用三次握手(Three-way Handshake): 1. 客户端发送 SYN(同步)报文给服务器,表示请求建立连接。 2. 服务器收到 SYN 报文后,发送 SYN-ACK(同步-确认)报文作为响应。 3. 客户端收到 SYN-ACK 后,发送 ACK(确认)报文,连接建立。 连接的释放采用四次挥手(Four-way Handshake): 1. 客户端发送 FIN(结束)报文,表示数据发送完成。 2. 服务器发送 ACK 报文,确认收到 FIN。 3. 服务器发送 FIN 报文,表示数据发送完成。 4. 客户端发送 ACK 报文,连接关闭。 #### TCP的可靠性机制 TCP 通过以下机制确保数据的可靠传输: - **确认机制**:接收方收到数据后,向发送方发送确认信息。 - **重传机制**:如果发送方未收到确认信息,则重传数据。 - **流量控制**:通过滑动窗口机制,控制发送速率,避免接收方缓冲区溢出。 - **拥塞控制**:通过慢启动、拥塞避免等算法,防止网络拥塞。 #### TCP的编程模型 TCP 编程模型通常括以下几个步骤: 1. **创建 Socket**:客户端创建 `Socket` 对象,连接服务器;服务端创建 `ServerSocket` 对象,监听端口。 2. **获取流对象**:获取 `Socket` 的输入流和输出流,用于数据传输。 3. **数据读写**:通过输入流读取数据,通过输出流写入数据。 4. **关闭连接**:通信结束后,关闭 `Socket` 和流对象。 ### 示例代码:完整的 TCP 通信 以下是一个完整的 TCP 通信示例,含客户端和服务端的代码。 #### 客户端代码 ```java import java.io.*; import java.net.*; public class TcpClient { public static void main(String[] args) { try { Socket socket = new Socket("localhost", 8888); OutputStream out = socket.getOutputStream(); out.write("Hello Server!".getBytes()); InputStream in = socket.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println("Server response: " + new String(buffer, 0, len)); socket.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` #### 服务端代码 ```java import java.io.*; import java.net.*; public class TcpServer { public static void main(String[] args) { try { ServerSocket serverSocket = new ServerSocket(8888); System.out.println("Server is listening on port 8888..."); Socket socket = serverSocket.accept(); InputStream in = socket.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println("Client message: " + new String(buffer, 0, len)); OutputStream out = socket.getOutputStream(); out.write("Hello Client!".getBytes()); socket.close(); serverSocket.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值