Java18:网络编程

一.对象序列化:

1.对象流:

ObjectInputStream 和 ObjectOutputStream

2.作用:

ObjectOutputSteam:内存中的对象-->存储中的文件,通过网络传输出去
ObjectInputStream:存储中的文件,通过网络传输出去-->内存中的对象

3.对象的序列化机制:

对象序列化机制允许把内存中的java对象转换成平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另外一个网络节点。//当其他程序获取了这种二进制流,就可以恢复成原来的java对象

4.序列化和反序列化过程:

代码实现:

public static void main(String[] args) throws IOException, ClassNotFoundException {//创建对象流ObjectOutputStream oos = new ObjectOutputStream( new FileOutputStream("object.txt"));//字符串序列化oos.writeObject("北京欢迎你!");oos.flush();System.out.println("***************************************");//对象序列化Person p  = new Person("tom",20);oos.writeObject(p);oos.flush();oos.close();System.out.println("***************************************");//反序列化:把对象从文件或数据库中读取到内存中ObjectInputStream ois = new ObjectInputStream(new FileInputStream("object.txt"));Object o = ois.readObject();System.out.println(o);Object o1 = ois.readObject();System.out.println(o1);ois.close();
}

5.实现序列化的对象所属的类需要满足:

1)需要实现接口:Serializable

2)当前类提供一个全局常量:SerialVersionUid

3)除了当前类需要实现Serializable接口之外,还需要保证其内部所有属性也必须是可序列化的

补充:ObjectOutputStream和ObjectInputStream不能序列化static和transient修饰的成员变量

二.随机存取文件流:

1.随机存取文件流:RandomAccessFile

2.使用说明:

1)RandomAccessFile直接继承于java.lang.Object类,实现了数据读取和输出

2)RandomAccessFile即可以是输入流又可以是输出流

3)RandomAccessFile作为输出流时,写出文件如果不存在,则在执行过程中自动创建,

如果写出的文件存在,则会对原文件内容进行覆盖

4)可以通过相关的操作,实现RandomAccessFile"插入"数据的效果。seek(int pos)

3.典型代码:

@Test
public void test() throws IOException {RandomAccessFile acf1 = new RandomAccessFile("cat.jpg", "r");RandomAccessFile acf2 = new RandomAccessFile("cat3.jpg", "rw");byte[] bute = new byte[1024];int len;while ((len = acf1.read(bute)) != -1) {acf2.write(bute, 0, len);}acf1.close();acf2.close();}@Test
public void test2() throws IOException {RandomAccessFile acf1 = new RandomAccessFile("hello1.txt", "rw");acf1.seek(3);acf1.write("xyz".getBytes());acf1.close();}@Test
public void test3() throws IOException {/*使用  RandomAccessFile 实现插入功能*/RandomAccessFile acf1 = new RandomAccessFile("h.txt", "rw");acf1.seek(3);StringBuilder sb  = new StringBuilder((int)new File("h.txt").length());//把剩余内容存到StringBuilder对象byte[] bute = new byte[1024];int len;while ((len = acf1.read(bute)) != -1) {sb.append(new String(bute,0,len));}//把指针从写指到3acf1.seek(3);acf1.write("xyz".getBytes());acf1.write(sb.toString().getBytes());acf1.close();}

三.网络传输:

1.实现网络通信需要解决的两个问题

1)如何准确地定位网络上一台或多台主机:定位主机上的特定应用

2)找到主机后如何可靠高效地进行数据传输

2.网络通信的两个要素:

1)对应问题一:ip和端口号

2)对应问题二:提供网络通信协议:TCP/IP参考模型(应用层,传输层,网络层,物理+数据链路层)

3.通信要素一:ip和端口号

1)ip的理解

》ip:唯一标识Internet上计算机(通信实体)

》在java 中使用InetAddress类代表ip

》ip分类:ipv4和ipv6 ;万维网和局域网

》域名:www.baidu.com  ,www.jd.com

2)InetAddress类:

2.1 实例化

getByName(String host),getLocalHost()

2.2 常用方法

getHostName() /getHostAddress()

3.端口号:正在计算机上运行的进程

要求:不同的进程不同的端口号

范围:被规定为一个正整数 0-65535

端口号与ip地址组合得出一个网络套接字:Socket

4.通信要素二:网络通信协议:

1)分类模型

2)TCP和UDP的区别

TCP协议:使用协议前建立TCP连接,形成传输通道,传输前使用三次握手方式,点对点通信,是可靠的;在连接中可进行大数据量的传输;传输完毕,需释放已建立的连接,效率低

UDP协议:将数据,源,目的封装成数据包,不需要建立连接,每个数据报的大小限制在64k内;

发送不管对方是否准备好,接收方收到也不确认,故是不可靠的;可以广播发送;发送数据结束时,无需释放资源,开销小,速度快

5.代码实例:

1)IP地址代码实例:

public class InetAddressTest {public static void main(String[] args) throws UnknownHostException {//根据ip地址创建ip地址对象InetAddress ina1 =InetAddress.getByName("192.168.1.1");System.out.println(ina1);//根据域名创建ip地址对象InetAddress ina2= InetAddress.getByName("www.baidu.com");System.out.println(ina2);byte[] address = ina1.getAddress();System.out.println(ina1.getHostName());System.out.println(ina1.getHostAddress());System.out.println(ina2.getHostName());System.out.println(ina2.getHostAddress());}
}

2)TCP代码实例:

public class Tcp1Test {
//发送信息@Testpublic void test() throws IOException {Socket  clent = new Socket(InetAddress.getByName("127.0.0.1"),8899);OutputStream outputStream = clent.getOutputStream();outputStream.write("我是客户端".getBytes());outputStream.close();clent.close();}@Testpublic void test2() throws IOException {ServerSocket  server  =new ServerSocket(8899);Socket accept = server.accept();InputStream inputStream = accept.getInputStream();ByteArrayOutputStream byteout =new ByteArrayOutputStream();byte[] buffer =new byte[20];int len;while((len=inputStream.read(buffer))!=-1){byteout.write(buffer,0,len);System.out.println(byteout.toString());}server.close();inputStream.close();byteout.close();}}
public class Tcp2Test {//发送文件@Testpublic void test1() throws IOException {InetAddress  inet= InetAddress.getByName("127.0.0.1");Socket clent =new Socket(inet,8851);OutputStream outputStream = clent.getOutputStream();FileInputStream fis= new FileInputStream("leaf.jpg");byte[] buffer= new byte[10];int len;while((len=fis.read(buffer))!=-1){outputStream.write(buffer,0,len);}fis.close();outputStream.close();clent.close();}@Testpublic  void  test2() throws IOException {ServerSocket server =new ServerSocket(8851);Socket accept = server.accept();InputStream inputStream = accept.getInputStream();FileOutputStream fos=new FileOutputStream("leaf2.jpg");byte[] bufferr = new byte[10];int len;while((len=inputStream.read(bufferr))!=-1){fos.write(bufferr,0,len);}fos.close();inputStream.close();server.close();}}
public class Tcp3Test {//发送文件,服务器返回信息@Testpublic void test() throws IOException {InetAddress   inet = InetAddress.getByName("127.0.0.1");Socket  client  =new Socket(inet,7788);OutputStream outputStream = client.getOutputStream();//从本地读取文件并发送到服务器FileInputStream fis =new FileInputStream("leaf.jpg");byte[] buffer =new byte[20];int len;while((len=fis.read(buffer))!=-1){outputStream.write(buffer,0,len);}//关闭数据输出client.shutdownOutput();//接受服务器发送的信息,并输出到控制台InputStream inputStream = client.getInputStream();ByteArrayOutputStream bos =new ByteArrayOutputStream();byte[] bu =new byte[20];int len1;while((len1=inputStream.read(bu))!=-1){bos.write(bu,0,len1);}System.out.println(bos.toString());fis.close();outputStream.close();client.close();}@Testpublic void test2() throws IOException {ServerSocket server = new ServerSocket(7788);Socket accept = server.accept();InputStream inputStream = accept.getInputStream();//接受客户端发送文件并存到本地FileOutputStream  fos= new FileOutputStream("leaf3.jpg");byte[] buff =new byte[20];int len;while((len=inputStream.read(buff))!=-1){fos.write(buff,0,len);}//给客户端发送已接收消息OutputStream outputStream = accept.getOutputStream();outputStream.write("图片已收到,谢谢".getBytes());fos.close();inputStream.close();server.close();outputStream.close();}}

3)UDP代码实例:

public class UdpTest {@Testpublic  void test() throws IOException {//发送端DatagramSocket socket =new DatagramSocket();InetAddress inet =InetAddress.getLocalHost();String str="我是udp方式发送的数据";byte[] buff = str.getBytes();DatagramPacket  packet =new DatagramPacket(buff,0,buff.length,inet,8890);socket.send(packet);socket.close();}@Testpublic void test2() throws IOException {//接收者DatagramSocket  socket =new DatagramSocket(8890);byte[] buffer =new byte[100];DatagramPacket packet =new DatagramPacket(buffer,0,buffer.length);socket.receive(packet);System.out.println(new String(packet.getData(),0,packet.getLength()));}
}

4)URL代码实例:

public class UrlTest {@Testpublic void test() throws MalformedURLException {//获取url对象URL url =new URL("http://localhost:8080/examples/leaf.jpg");//url 主要方法System.out.println(url.getProtocol());//获取协议System.out.println(url.getHost());//获取主机System.out.println(url.getPort());//获取端口System.out.println(url.getQuery());//获取查询内容}@Testpublic void test2() throws IOException {//服务器下载图片
URL url =new URL("http://localhost:8080/examples/leaf.jpg");HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();urlConnection.connect();InputStream inputStream = urlConnection.getInputStream();byte[] buffer =new byte[20];int len;FileOutputStream fos =new FileOutputStream("leafdown.jpg");while((len=inputStream.read(buffer))!=-1){fos.write(buffer,0,len);}inputStream.close();fos.close();urlConnection.disconnect();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/234420.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构-函数题

6-2.求二叉树的高度 本题要求给定二叉树的高度。 函数接口定义: int GetHeight( BinTree BT ); typedef struct TNode *Position; typedef Position BinTree; struct TNode{ElementType Data;BinTree Left;BinTree Right; }; 要求函数返回给定二叉树BT的高度值…

C++学习笔记——string类和new函数

目录 string类 1.功能增强 1.1 子字符串提取 1.2 字符串拼接 1.3 大小写转换 1.4 字符串比较 2.性能优化 3.使用示例 下面是一个简单的使用示例,展示了如何使用改进后的String类: NEW函数 2.1NEW函数的基本用法 2.2NEW函数的注意事项 2.3避…

linux系统基础知识-基础IO

IO 概念引入位图的概念IO的系统调用函数openwriteread()close简单使用样例: 文件描述符fd默认文件流stdin/stdout/stderr文件描述符的分配规则 重定向的概念输出重定向输入重定向追加重定向dup2()系统调用总结 文件缓冲区深入理解缓冲区的概念输出缓冲区部分代码解释…

Linux网络配置与抓包工具介绍

目录 一、配置命令 1. ifconfig 1.1 概述信息解析 1.2 常用格式 2. ip 2.1 ip link 数据链路层 2.2 ip addr 网络层 2.3 路由 3. hostname 3.1 临时修改主机名 3.2 永久修改主机名 4. route 5. netstat 6. ss 7. ping 8. traceroute 9. nslookup 10. 永久修…

UI5与后端的文件交互(一)

文章目录 前言一、RAP的开发1. 创建表格2. 创建CDS Entity3. 创建BDEF4. 创建implementation class5. 创建Service Definition和Binding6. 测试API 二、创建UI5 Project1. 使用Basic模板创建2. 创建View3. 测试页面及绑定的oData数据是否正确4. 创建Controller5. 导入外部包&am…

计算机体系结构期末复习流程大纲

1.存储器和cache 存储器的容量、速度与价格之间的要求是相互矛盾的,速度越快,没bit位价格越高,容量越大,速度越慢,目前主存一般有DRAM构成。 处理器CPU访问存储器的指标: 延迟时间(Latency&am…

【算法】算法设计与分析 期末复习总结

第一章 算法概述 时间复杂度比大小,用代入法,代入2即可。求渐进表达式,就是求极限,以极限为O的括号;O是指上界,Ω是指下界,θ是指上下界相等,在这里,可以这样理解&#…

Influxdb2修改管理员密码

通过恢复管理员令牌来重置InfluxDB2管理员的密码 1.找到数据库的配置文件 一般为config.json 2.配置文件的的blod文件配置 3.在这个混合文本和二进制json文件中搜索已知的用户名或token之类的字符串。 例如: "id":"0bd73badf2941000","…

WEB 3D技术 three.js 线框几何体

本文 我们说一下 线框几何体 想将一个几何体 以线框形式展现 threeJS中 有两种类可以实现 第一种 WireframeGeometry 这种几何体 其实就类似于 将材质中的 wireframe 开启 这种方法 之前我们也用过 还有一种 就是 EdgesGeometry 边缘几何体 我们先将代码写成这样 import .…

关于kthread_stop的疑问(linux3.16)

线程一旦启动起来后,会一直运行,除非该线程主动调用do_exit函数,或者其他的进程调用kthread_stop函数,结束线程的运行。 之前找销毁内核线程的接口时,发现了kthread_stop这个接口。网上说这个函数能够销毁一个内核线程…

Java中的IO流

在Java中,I/O(输入/输出)流用于处理与输入和输出相关的操作。Java的I/O流按照数据处理的不同方式分为两大类:字节流和字符流。每个类别又分为输入流和输出流。以下是Java中常用的I/O流及其继承关系: 字节流&#xff0…

批量剪辑方法:掌握视频剪辑技巧,按指定时长轻松分割视频

在视频制作和编辑过程中,经常要批量处理和剪辑大量的视频片段。学会批量剪辑方法可以提高工作效率,还可以使视频编辑更加准确和高效。下面来看下云炫AI智剪如何按指定时长轻松分割视频的批量剪辑方法。 分割后的视频文件效果,已分割分段的视…

业界首款PCIe 4.0/5.0多通道融合接口SSD技术解读

之前小编写过一篇文章劝大家不要碰PCIe 5.0 SSD,详细内容,可以再回顾下: 扩展阅读:当下最好不要入坑PCIe 5.0 SSD 如果想要进一步了解PCIe 6.0,欢迎点击阅读: 浅析PCIe 6.0功能更新与实现的挑战 PCIe 6.…

云卷云舒:【实战篇】云主机/虚拟机迁移

1. 简介 用户原有业务通过不同版本型号、不同操作系统的主机承载,形式上包括物理服务器、虚拟机、公有云主机等。随着业务不断扩张,需要将其业务云化转型,必须保证上云过程数据完整,业务平滑过度。 如果将所有业务系统都重新部署…

教你如何将本地虚拟机变成服务器,供其它电脑访问

场景:最近在做数据仓库的作业,需要团队协作,买不起阿里云服务器,所以想到能不能将我本地机上的虚拟机变成服务器,供其它同学的电脑访问。在虚拟机上安装hadoop和hive,然后同学机子上安装kettle进行连接。最…

Java 反射(一)

反射 1.反射的介绍 1.反射机制允话程序在执行期间借助于Refelction API取得任何类的信息(比如成员变量,构造器,成员方法等)并能操作对象的属性及方法,反射在设计模式和框架底层都会用到 2.加载完类之后,在…

可狱可囚的爬虫系列课程 08:新闻数据爬取实战

前言 本篇文章中我带大家针对前面所学 Requests 和 BeautifulSoup4 进行一个实操检验。 相信大家平时或多或少都有看新闻的习惯,那么我们今天所要爬取的网站便是新闻类型的:中国新闻网,我们先来使用爬虫爬取一些具有明显规则或规律的信息&am…

【Redis-04】Redis命令在客户端与服务器之间的执行流程

Redis本质上是一个数据结构服务器,支持键值对类型存储的内存管理系统,可以用作数据库、缓存和消息中间件,在我日常的开发中,基本上使用redis作为缓存中间件。 在Redis中有两个重要的角色,一个是服务器server&#xff0…

Adding Conditional Control to Text-to-Image Diffusion Models——【论文笔记】

本文发表于ICCV2023 论文地址:ICCV 2023 Open Access Repository (thecvf.com) 官方实现代码:lllyasviel/ControlNet: Let us control diffusion models! (github.com) Abstract 论文提出了一种神经网络架构ControlNet,可以将空间条件控制添加到大型…

性能分析与调优: Linux 监测工具的数据来源

目录 一、实验 1.环境 2. proc目录 3. sys目录 4.netlink 5.tracepoint 6.kprobes 7. uprobes 二、问题 1.systemd如何查看启动时间 2.CentOS与Ubuntu如何安装bpftrace 3.snap有哪些常用的命令 4.snap如何安装store 5.如何列出使用bpftrace的OpenJDK USDT探针 一…