java--网络编程

网络的相关概念

网络通信

  • 1.概念:两台设备之间通过网络实现数据传输
  • 2.网络通信:将数据通过网络从一台设备传输到另一台设备
  • 3.java.net包下提供了一系列的类或接口,供程序员使用,完成网络通信

网络

  1. 概念:两台或多台设备通过一定物理设备连接起来构成了网络
  2. 根据网络的覆盖范围不同,对网络进行分类:
    局域网:覆盖范围最小,仅仅覆盖一个教室或一个机房
    城域网:覆盖范围较大,可以覆盖一个城市
    广域网:覆盖范围最大,可以覆盖全国,甚至全球,万维网是广域网的代表

IP 地址

  • (1)概念:用于唯一标识网络中的每台计算机/主机
  • (2)查看 ip 地址: ipconfig
  • (3)ip 地址的表示形式:点分十进制 XX.XX.XX.XX(4 个字节,32 位)
  • (4)每一个十进制数的范围:0~255
  • (5)ip 地址的组成 = 网络地址(192.168.16) + 主机地址(69),比如:192.168.16.69
  • (6)IPV6 是互联网工程任务组设计的用于替代 IPV4 的下一代 IP 协议,其地址数量号称可为全世界的每一粒沙子编上一个地址
  • (7)由于 IPV4 最大的问题在于网络地址资源有限,严重制约了互联网的应用和发展。IPv6 的使用,不仅能解决网络地址资源数量的问题,而且也解决了多种接入设备连入互联的障碍

ipv4 地址分类

本机地址: 127.0.0.1

域名

1.www.baidu.com
2.好处:为了方便记忆,解决记ip的困难
3.概念:将ip地址映射成域名,这里怎么映射上,HTTP协议

端口号
1、概念:用于标识计算机上某个特定的网络程序
2、 表示形式:以整数形式,端口范围0~65535 [2个字节表示端口 0~2^16-1]
3、0~1024已经被占用,比如 ssh 22,ftp 21,smtp 25 http 80
4、常见的网络程序端口号:
tomcat :8080
mysql:3306
oracle:1521
sqlserver:1433

网络通信协议

  • TCP/IP:Transmission Control Protocol / Internet Protocol,传输控制协议/因特网互联协议,又叫网络通讯协议。
  • 这个协议是 Internet 最基本的协议、Internet 国际互联网络的基础,简单地说,就是由网络层的IP协议和传输层的TCP协议组成的。

网络通信协议

TCP 和 UDP

TCP协议:传输控制协议
(1)使用TCP协议前,须先建立 TCP 连接,形成传输数据通道
(2)传输前,采用”三次握手“方式,是可靠的
(3)TCP协议进行通信的两个应用进程:客户端、服务端
(4)在连接中可进行大数据量的传输
(5)传输完毕,需释放已建立的连接效率低
(6)类似打电话

UDP协议:用户数据协议
(1)将数据、源、目的封装成数据包,不需要建立连接
(2)每个数据报的大小限制在64K内,不适合传输大量数据
(3)因无需连接,故是不可靠的
(4)发送数据结束时无需释放资源(因为不是面向连接的),速度快
(5)类似发短信

InetAddress类

相关方法

1.获取本机InetAddress对象 getLocalHost
2.根据指定主机名/域名获取ip地址对象 getByName
3.获取InetAddress对象的主机名 getHostName
4.获取InetAddress对象的地址 getHostAddress

应用案例

编写代码,获取计算机的主机名和IP地址相关API

import java.net.InetAddress;
import java.net.UnknownHostException;
public class API_ {public static void main(String[] args) throws UnknownHostException {//1. 获取本机的InetAddress 对象InetAddress localHost = InetAddress.getLocalHost();System.out.println(localHost);//LAPTOP-I7QFKRFR/192.168.31.181//2. 根据指定主机名 获取 InetAddress对象InetAddress host1 = InetAddress.getByName("LAPTOP-I7QFKRFR");System.out.println("host1=" + host1);//LAPTOP-I7QFKRFR/192.168.31.181//3. 根据域名返回 InetAddress对象, 比如 www.baidu.com 对应InetAddress host2 = InetAddress.getByName("www.baidu.com");System.out.println("host2=" + host2);//host2=www.baidu.com/182.61.200.7//4. 通过 InetAddress 对象,获取对应的地址String hostAddress = host2.getHostAddress();//IP 182.61.200.7System.out.println("host2 对应的ip = " + hostAddress);//182.61.200.7//5. 通过 InetAddress 对象,获取对应的主机名/或者的域名String hostName = host2.getHostName();System.out.println("host2对应的主机名/域名=" + hostName); // www.baidu.com}
}

Socket

基本介绍

(1)套接字(Socket)开发网络应用程序被广泛采用,以至于成为事实上的标准
(2)通信的两端都要有 Socket,是两台机器间通信的端点
(3)网络通信其实就是 Socket 的通信。
(4)Socket 允许程序把网络连接当成一个流,数据在两个 Socket 间通过 IO 传输。
(5)一般主动发起通信的应用程序属客户端,等待通信请求的为服务端

Socket工作过程包含以下四个步骤:
(1) 创建Socket;
(2) 打开连接到Socket的输入/输出流;
(3) 按照一定的协议对Socket进行读/写操作;
(4) 关闭Socket

java中的Socket类主要包括两个:Socket(客户端)和 ServerSocket(服务器端)

Socket客户端
(1)Socket socket = new Socket(ip,port);                    打开一个套接字,发送请求  
(2)InputStream in = socket.getInputStream();            从socket建立输入流
(3)OutputStream out  = socket.getOutputStream();   从socket建立输出流
Socket服务器注意多个客户端同时访问服务器的问题:多线程
(1)ServerSocket server = new ServerSocket(port);    创建一个端口
(2)Socket socket = server.accept();         只有当有客户端请求并建立了连接,函数才会返                                                                       回,返回Socket对象
(3)InputStream istream = socket.getInputStream();           从socket建立输入流 (4)OutputStream ostream  = socket.getOutputStream();    从socket建立输出流

TCP 网络通信编程

基本介绍

1.基于客户端一服务端的网络通信
2.底层使用的是TCP/IP协议
3应用场景举例:客户端发送数据,服务端接受并显示控制台
4.基于Socket的TCP编程

应用案例1(使用字节流)

1、编写一个服务器端,和一个客户端
2、服务器端在9999端口监听
3、客户端连接到服务器端,发送“hello,server”,然后退出
4、服务器端接收到客户端发送的信息,输出,并退出

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
/*** 服务端*/
public class SocketTCP01Server {public static void main(String[] args) throws IOException {//思路//1. 在本机 的9999端口监听, 等待连接//   细节: 要求在本机没有其它服务在监听9999//   细节:这个 ServerSocket 可以通过 accept() 返回多个Socket[多个客户端连接服务器的并发]ServerSocket serverSocket = new ServerSocket(9999);System.out.println("服务端,在9999端口监听,等待连接..");//2. 当没有客户端连接9999端口时,程序会 阻塞, 等待连接//   如果有客户端连接,则会返回Socket对象,程序继续Socket socket = serverSocket.accept();System.out.println("服务端 socket =" + socket.getClass());//3. 通过socket.getInputStream() 读取客户端写入到数据通道的数据, 显示InputStream inputStream = socket.getInputStream();//4. IO读取byte[] buf = new byte[1024];int readLen = 0;while ((readLen = inputStream.read(buf)) != -1) {System.out.println(new String(buf, 0, readLen));//根据读取到的实际长度,显示内容.}//5.关闭流和socketinputStream.close();socket.close();serverSocket.close();//关闭}
}
import java.io.IOException;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;
/*** 客户端,发送 "hello, server" 给服务端*/
public class SocketTCP01Client {public static void main(String[] args) throws IOException {//思路//1. 连接服务端 (ip , 端口)//解读: 连接本机的 9999端口, 如果连接成功,返回Socket对象Socket socket = new Socket(InetAddress.getLocalHost(), 9999);System.out.println("客户端 socket返回=" + socket.getClass());//2. 连接上后,生成Socket, 通过socket.getOutputStream()//   得到 和 socket对象关联的输出流对象OutputStream outputStream = socket.getOutputStream();//3. 通过输出流,写入数据到 数据通道outputStream.write("hello, server".getBytes());//4. 关闭流对象和socket, 必须关闭outputStream.close();socket.close();System.out.println("客户端退出.....");}
}

public Socket accept()方法的作用就是侦听并接受此套接字的连接。此方法在连接传入之前一直阻塞。

应用案例2(使用字节流)(互发)

  1. 编写一个服务端,和一个客户端
  2. 服务器端在9999端口监听
  3. 客户端连接到服务器端,发送“hello,server” 并接收服务器端回发的 “hello,client”,再退出
  4. 服务器端接收到客户端发送的信息,输出,并发送“hello,client” 再退出

!设置写入结束标记: socket.shutdownOutput();

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
/*** 服务端*/
@SuppressWarnings({"all"})
public class SocketTCP02Server {public static void main(String[] args) throws IOException {//思路//1. 在本机 的9999端口监听, 等待连接//   细节: 要求在本机没有其它服务在监听9999//   细节:这个 ServerSocket 可以通过 accept() 返回多个Socket[多个客户端连接服务器的并发]ServerSocket serverSocket = new ServerSocket(9999);System.out.println("服务端,在9999端口监听,等待连接..");//2. 当没有客户端连接9999端口时,程序会 阻塞, 等待连接//   如果有客户端连接,则会返回Socket对象,程序继续Socket socket = serverSocket.accept();System.out.println("服务端 socket =" + socket.getClass());////3. 通过socket.getInputStream() 读取客户端写入到数据通道的数据, 显示InputStream inputStream = socket.getInputStream();//4. IO读取byte[] buf = new byte[1024];int readLen = 0;while ((readLen = inputStream.read(buf)) != -1) {System.out.println(new String(buf, 0, readLen));//根据读取到的实际长度,显示内容.}//5. 获取socket相关联的输出流OutputStream outputStream = socket.getOutputStream();outputStream.write("hello, client".getBytes());//   设置结束标记socket.shutdownOutput();//6.关闭流和socketoutputStream.close();inputStream.close();socket.close();serverSocket.close();//关闭}
}
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
/*** 客户端,发送 "hello, server" 给服务端*/
@SuppressWarnings({"all"})
public class SocketTCP02Client {public static void main(String[] args) throws IOException {//思路//1. 连接服务端 (ip , 端口)//解读: 连接本机的 9999端口, 如果连接成功,返回Socket对象Socket socket = new Socket(InetAddress.getLocalHost(), 9999);System.out.println("客户端 socket返回=" + socket.getClass());//2. 连接上后,生成Socket, 通过socket.getOutputStream()//   得到 和 socket对象关联的输出流对象OutputStream outputStream = socket.getOutputStream();//3. 通过输出流,写入数据到 数据通道outputStream.write("hello, server".getBytes());//   设置结束标记socket.shutdownOutput();//4. 获取和socket关联的输入流. 读取数据(字节),并显示InputStream inputStream = socket.getInputStream();byte[] buf = new byte[1024];int readLen = 0;while ((readLen = inputStream.read(buf)) != -1) {System.out.println(new String(buf, 0, readLen));}//5. 关闭流对象和socket, 必须关闭inputStream.close();outputStream.close();socket.close();System.out.println("客户端退出.....");}
}

应用案例3(使用字符流)

  1. 编写一个服务端,和一个客户端
  2. 服务端在 9999端口监听
  3. 客户端连接到服务端,发送"hello,server”,并接收服务端回发的"hello,client”,再退出
  4. 服务端接收到 客户端发送的 信息,输出,并发送"hello, client",再退出

设置写入结束标记: Writer.newLine();    readLine() 配合使用

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
/*** 服务端, 使用字符流方式读写*/
@SuppressWarnings({"all"})
public class SocketTCP03Server {public static void main(String[] args) throws IOException {//思路//1. 在本机 的9999端口监听, 等待连接//   细节: 要求在本机没有其它服务在监听9999//   细节:这个 ServerSocket 可以通过 accept() 返回多个Socket[多个客户端连接服务器的并发]ServerSocket serverSocket = new ServerSocket(9999);System.out.println("服务端,在9999端口监听,等待连接..");//2. 当没有客户端连接9999端口时,程序会 阻塞, 等待连接//   如果有客户端连接,则会返回Socket对象,程序继续Socket socket = serverSocket.accept();System.out.println("服务端 socket =" + socket.getClass());////3. 通过socket.getInputStream() 读取客户端写入到数据通道的数据, 显示InputStream inputStream = socket.getInputStream();//4. IO读取, 使用字符流, 老师使用 InputStreamReader 将 inputStream 转成字符流BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));String s = bufferedReader.readLine();System.out.println(s);//输出//5. 获取socket相关联的输出流OutputStream outputStream = socket.getOutputStream();//    使用字符输出流的方式回复信息BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream));bufferedWriter.write("hello client 字符流");bufferedWriter.newLine();// 插入一个换行符,表示回复内容的结束bufferedWriter.flush();//注意需要手动的flush//6.关闭流和socketbufferedWriter.close();bufferedReader.close();socket.close();serverSocket.close();//关闭}
}
import java.io.*;
import java.net.InetAddress;
import java.net.Socket;
/*** 客户端,发送 "hello, server" 给服务端, 使用字符流*/
@SuppressWarnings({"all"})
public class SocketTCP03Client {public static void main(String[] args) throws IOException {//思路//1. 连接服务端 (ip , 端口)//解读: 连接本机的 9999端口, 如果连接成功,返回Socket对象Socket socket = new Socket(InetAddress.getLocalHost(), 9999);System.out.println("客户端 socket返回=" + socket.getClass());//2. 连接上后,生成Socket, 通过socket.getOutputStream()//   得到 和 socket对象关联的输出流对象OutputStream outputStream = socket.getOutputStream();//3. 通过输出流,写入数据到 数据通道, 使用字符流BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream));bufferedWriter.write("hello, server 字符流");bufferedWriter.newLine();//插入一个换行符,表示写入的内容结束, 注意,要求对方使用readLine()!!!!bufferedWriter.flush();// 如果使用的字符流,需要手动刷新,否则数据不会写入数据通道//4. 获取和socket关联的输入流. 读取数据(字符),并显示InputStream inputStream = socket.getInputStream();BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));String s = bufferedReader.readLine();System.out.println(s);//5. 关闭流对象和socket, 必须关闭bufferedReader.close();//关闭外层流bufferedWriter.close();socket.close();System.out.println("客户端退出.....");}
}

应用案例4

  1. 编写一个服务端, 和一个客户端
  2. 服务器端在 8888端口监听
  3. 客户端连接到服务端,发送 一张图片 e:\gie.png
  4. 服务器端接收到 客户端发送的 图片,保存到 src下,发送"收到图片"再退出
  5. 客户端接收到服务端发送的"收到图片",再退出
  6. 该程序要求使用 StreamUtils.java,我们直接使用

工具类

import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;/*** 此类用于演示关于流的读写方法**/
public class StreamUtils {/*** 功能:将输入流转换成byte[]* @param is* @return* @throws Exception*/public static byte[] streamToByteArray(InputStream is) throws Exception{ByteArrayOutputStream bos = new ByteArrayOutputStream();//创建输出流对象byte[] b = new byte[1024];int len;while((len=is.read(b))!=-1){bos.write(b, 0, len);	}byte[] array = bos.toByteArray();bos.close();return array;}/*** 功能:将InputStream转换成String* @param is* @return* @throws Exception*/public static String streamToString(InputStream is) throws Exception{BufferedReader reader = new BufferedReader(new InputStreamReader(is));StringBuilder builder= new StringBuilder();String line;while((line=reader.readLine())!=null){ //当读取到 null时,就表示结束builder.append(line+"\r\n");}return builder.toString();}
}

服务端

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
/*** 文件上传的服务端*/
public class TCPFileUploadServer {public static void main(String[] args) throws Exception {//1. 服务端在本机监听8888端口ServerSocket serverSocket = new ServerSocket(8888);System.out.println("服务端在8888端口监听....");//2. 等待连接Socket socket = serverSocket.accept();//3. 读取客户端发送的数据//   通过Socket得到输入流BufferedInputStream bis = new BufferedInputStream(socket.getInputStream());byte[] bytes = StreamUtils.streamToByteArray(bis);//4. 将得到 bytes 数组,写入到指定的路径,就得到一个文件了String destFilePath = "src\\abc.mp4";BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(destFilePath));bos.write(bytes);bos.close();// 向客户端回复 "收到图片"// 通过socket 获取到输出流(字符)BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));writer.write("收到图片");writer.flush();//把内容刷新到数据通道socket.shutdownOutput();//设置写入结束标记//关闭其他资源writer.close();bis.close();socket.close();serverSocket.close();}
}

客户端

import java.io.*;
import java.net.InetAddress;
import java.net.Socket;
/*** 文件上传的客户端*/
public class TCPFileUploadClient {public static void main(String[] args) throws Exception {//客户端连接服务端 8888,得到Socket对象Socket socket = new Socket(InetAddress.getLocalHost(), 8888);//创建读取磁盘文件的输入流//String filePath = "e:\\qie.png";String filePath = "e:\\abc.mp4";BufferedInputStream bis  = new BufferedInputStream(new FileInputStream(filePath));//bytes 就是filePath对应的字节数组byte[] bytes = StreamUtils.streamToByteArray(bis);//通过socket获取到输出流, 将bytes数据发送给服务端BufferedOutputStream bos = new BufferedOutputStream(socket.getOutputStream());bos.write(bytes);//将文件对应的字节数组的内容,写入到数据通道bis.close();socket.shutdownOutput();//设置写入数据的结束标记//=====接收从服务端回复的消息=====InputStream inputStream = socket.getInputStream();//使用StreamUtils 的方法,直接将 inputStream 读取到的内容 转成字符串String s = StreamUtils.streamToString(inputStream);System.out.println(s);//关闭相关的流inputStream.close();bos.close();socket.close();}
}

netstat 指令

netstat 指令----TCP网络通信编程

  • (1)netstat -an 可以查看当前主机网络情况,包括 端口监听 情况和 网络连接 情况
  • (2)netstat -an | more可以分页显示,按下空格翻页
  • (3)要求在 dos控制台 下执行 win+r
  • ① Listening 表示某个端口在监听
    ② 如果有一个外部程序(客户端)连接到该端口,就会显示一条连接信息
  • netstat -anb more 权限更高

TCP 网络通讯不为人知的秘密:当客户端连接到服务端后,实际上客户端也是通过一个端口和服务端进行通讯的,这个端口是TCP/IP 来分配的, 是不确定的,是随机的.

UDP 网络通信编程[了解]

 基本介绍

  1. DatagramSocket 和 DatagramPacket [数据包/数据报] 实观了基于 UDP 协议网络程序。
  2. UDP 数据报通过数据报套接字 DatagramSocket 发送和接收,系统不保证 UDP 数据报一定能够安全送到目的地,也不能确定什么时候可以抵达。
  3. DatagramPacket 对象封装了 UDP 数据报,在数据报中包含了发送端的 IP 地址和端口号以及接收端的 IP 地址和端口号。
  4. UDP 协议中每个数据报都给出了完整的地址信息,因此无须建立发送方和接收方的连接

基本流程

  1. 核心的两个类/对象 DatagramSocket DatagramPacket
  2. 建立发送端,接收端(没有服务端和客户端概念)
  3. 发送数据前,建立数据包/报 DatagramPacket 对象
  4. 调用 DatagramSocket 的发送、接收方法
  5. 关闭 DatagramSocket

UDP说明

  • 没有明确的服务端和客户端,演变成数据的发送端和接收端
  • 接收数据和发送数据是通过 DatagramSocket 对象完成
  • 将数据封装到 DatagramPacket 对象/装包
  • 当接收到 DatagramPacket 对象,需要进行拆包,取出数据
  • DatagramSocket 可以指定在哪个端口接收数据

应用案例

  1. 编写一个接收端A,和一个发送端B
  2. 接收端 A 在9999端口等待接收数据(receive
  3. 发送端 B 向接收端 A 发送数据 “hello,明天吃火锅~”
  4. 接收端 A 接收到发送端 B 发送的数据,回复 “好的,明天见” 再退出
  5. 发送端接收 回复的数据,再退出
UDP 协议一个数据包最大 64k

UDP接收端 -----  接收端   A

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;/*** UDP接收端*/
public class UDPReceiverA {public static void main(String[] args) throws IOException {//1. 创建一个 DatagramSocket 对象,准备在9999接收数据DatagramSocket socket = new DatagramSocket(9999);//2. 构建一个 DatagramPacket 对象,准备接收数据//   在前面讲解UDP 协议时,老师说过一个数据包最大 64kbyte[] buf = new byte[1024];DatagramPacket packet = new DatagramPacket(buf, buf.length);//3. 调用 接收方法, 将通过网络传输的 DatagramPacket 对象//   填充到 packet对象//提示: 当有数据包发送到 本机的9999端口时,就会接收到数据//   如果没有数据包发送到 本机的9999端口, 就会阻塞等待.System.out.println("接收端A 等待接收数据..");socket.receive(packet);//4. 可以把packet 进行拆包,取出数据,并显示.int length = packet.getLength();//实际接收到的数据字节长度byte[] data = packet.getData();//接收到数据String s = new String(data, 0, length);System.out.println(s);//===回复信息给B端//将需要发送的数据,封装到 DatagramPacket对象data = "好的, 明天见".getBytes();//说明: 封装的 DatagramPacket对象 data 内容字节数组 , data.length , 主机(IP) , 端口packet =new DatagramPacket(data, data.length, InetAddress.getByName("192.168.12.1"), 9998);socket.send(packet);//发送//5. 关闭资源socket.close();System.out.println("A端退出...");}
}

发送端B ====> 也可以接收数据 

import java.io.IOException;
import java.net.*;/*** 发送端B ====> 也可以接收数据*/
@SuppressWarnings({"all"})
public class UDPSenderB {public static void main(String[] args) throws IOException {//1.创建 DatagramSocket 对象,准备在9998端口 接收数据DatagramSocket socket = new DatagramSocket(9998);//2. 将需要发送的数据,封装到 DatagramPacket对象byte[] data = "hello 明天吃火锅~".getBytes(); ////说明: 封装的 DatagramPacket对象 data 内容字节数组 , data.length , 主机(IP) , 端口DatagramPacket packet =new DatagramPacket(data, data.length, InetAddress.getByName("192.168.12.1"), 9999);socket.send(packet);//3.=== 接收从A端回复的信息//(1)   构建一个 DatagramPacket 对象,准备接收数据//   在前面讲解UDP 协议时,老师说过一个数据包最大 64kbyte[] buf = new byte[1024];packet = new DatagramPacket(buf, buf.length);//(2)    调用 接收方法, 将通过网络传输的 DatagramPacket 对象//   填充到 packet对象//老师提示: 当有数据包发送到 本机的9998端口时,就会接收到数据//   如果没有数据包发送到 本机的9998端口, 就会阻塞等待.socket.receive(packet);//(3)  可以把packet 进行拆包,取出数据,并显示.int length = packet.getLength();//实际接收到的数据字节长度data = packet.getData();//接收到数据String s = new String(data, 0, length);System.out.println(s);//关闭资源socket.close();System.out.println("B端退出");}
}

上一章

java--IO流-CSDN博客

下一章

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

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

相关文章

P2-3与P2-4.【C语言基本数据类型、运算符和表达式】第三节与第四节

讲解视频: P2-3.【基本数据类型、运算符和表达式】第三节 P2-4.【基本数据类型、运算符和表达式】第四节 目录 必备知识与理论 任务实施 必备知识与理论 C语言中把除了控制语句和输入输出以外的几乎所有的基本操作都作为运算符处理。 其运算符和表达式数量之多&a…

PythonExcel批量pingIP地址

问题: 作为一个电气工程师(PLC),当设备掉线的时候,需要用ping工具来检查网线物理层是否可靠连接,当项目体量过大时,就不能一个手动输入命令了。 解决方案一: 使用CMD命令 for /L %…

ARM 中断控制器 GIC-V2

GIC-V2 中断控制器架构 参考文档:《ARMGeneric Interrupt Controller Architecture version 2.0》 GIC:Generic Interrupt Controller(GIC) 本文省略中断虚拟化相关章节。 1、Introduction(简介) 中断状态: The following states apply at each interface between the GI…

论文阅读_大型语言模型增强强化学习调查

中文标题:Survey on Large Language Model-Enhanced Reinforcement Learning: Concept, Taxonomy, and Methods 中文名称: 大型语言模型增强强化学习调查:概念、分类和方法 链接: https://arxiv.org/pdf/2404.00282 作者: Yuji Cao, Huan Zhao, Yuheng C…

ABAQUS应用11——支座弹簧

文章目录 0、背景1、ABAQUS中几类弹簧的简介2、SPRING1的性质初探 0、背景 1、ABAQUS中几类弹簧的简介 先说参考来源,ABAQUS2016的帮助文档里第4卷,32.1.1节,有三种弹簧(SPRING1 、SPRING2 以及SPRINGA)。 三种弹簧里…

基于LORA的一主多从监测系统_数据发送

数据上传我这里使用了问询的方式,这样的好处一是可以用来统计节点的存活状态,二是可以避免冲突,主节点通过向从节点发送问询帧,从节点收到问询帧后开始向主节点发送数据,同时我们也可以加入不同的帧类型,比…

DSVPN简介与应用

目录 简介 DSVPN 封装模式 Nomal(动态)方式建立DSVPN 一、配置缺省包过滤 二、划分区域(以总部为例) 三、配置IP地址(以R1为例) 四、配置DSVPN 简介 DSVPN DSVPN(Dynamic Secure Vir…

初识git · 基本操作

目录 前言: 基本操作 检查是否存在git 初始化仓库 认识三个区域 添加文件 查看.git文件 修改文件 版本回退 撤销操作 删除文件 我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/suppor…

手撕布隆过滤器:原理解析与面试心得

前言 说来话长,话来说长。前些天我投了一些日常实习的简历,结果足足等了两个礼拜才收到面试通知,看来如今的行情确实是挺紧张的。当时我是满怀信心去的,心想这次一定要好好拷打面试官一番,结果没想到,自我…

美摄科技云服务解决方案,方案成熟,接入简单

美摄科技作为视频处理领域的先锋,凭借其强大的技术实力和深厚的行业经验,推出了成熟的云服务解决方案,为轻量化视频制作开辟了全新的道路。 一、成熟方案,接入无忧 美摄科技云服务解决方案的最大亮点在于其成熟度和易用性。我们…

java事务讲解(详解篇)

本篇博客将各位介绍事务的相关内容,也算是对事物的大部分知识点进行的一个总结,接下来就跟着我一起来学习学习吧~ 实现事务 实现事务的方式大类共有两大类,一种是编程式事务,另一种是声明式事务。 编程式事务的好处在于他的最小…

Postman 接口测试工具学习使用

目录 Postman 下载 postman界面详解 postman接口测试 操作步骤 postman发送post请求总结 postman断言 状态码断言 响应body正文断言(3种场景) 响应头断言 响应时间断言 postman集合测试 变量的应用 参数变量 1、环境变量 2、全局变量 3、局…

李德仁院士携实验室及大势文旅团队参加“湖北旅游、武当突破”名家谈,分享数智文旅发展新经验

10月12日上午,2024世界武当太极大会在湖北省十堰市武当山盛大开幕。 2023年国家科学技术最高奖获得者、中国科学院、中国工程院院士、武汉大学李德仁教授携测绘遥感信息工程国家重点实验室(后简称“实验室”)团队以及大势智慧文旅团队&#…

QUIC 协议的优势

QUIC 协议的优势包括: 快速建立连接:将传输层和加密层的握手合并,减少了连接建立的延迟。QUIC 建连时间大约为 0~1RTT,相比 HTTPS 的 3RTT 建连,具有极大的优势。客户端第一次建连的握手协商需 1RTT,而已建…

其他css的用途

1.animation-fill-mode: backwards; //避免了在动画开始前元素的突然显现,动画必要。 2.用rem响应式字体大小,可以在html样式定义font-size?(例10px,62.5%(100%是16px))。然后样式就可以用rem代替px。 3.color: transparent;: 这行代码将文…

【动手学深度学习】7.3 网络中的网络(NiN)(个人向笔记)

LeNet,AlexNet和VGG都有一个共同的设计模型:通过一系列卷积层和汇聚层来提取空间结构特征,然后通过全连接层对特征的表征进行处理AlexNet和VGG对LeNet的改进主要是在于如何扩大和加深这两个模块网络中的网络(NIN)提出了:在每个像素…

炒股VS炒游戏装备,哪个更好做

这个项目,赚个10%都是要被嫌弃的 虽然天天都在抒发自己对股市的看法,但自己自始至终也没有买进任何一支股票。之所以对这个话题感兴趣,着实是因为手上的游戏搬砖项目也是国际性买卖,跟国际形势,国际汇率挂钩&#xff0…

【D3.js in Action 3 精译_034】4.1 D3 中的坐标轴的创建(中篇):定义横纵坐标轴的比例尺

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一部分 D3.js 基础知识 第一章 D3.js 简介(已完结) 1.1 何为 D3.js?1.2 D3 生态系统——入门须知1.3 数据可视化最佳实践(上)1.3 数据可…

H-TCP 的效率和公平性

昨晚带安孩楼下玩耍,用手机 desmos 作了一组 response curve 置于双对数坐标系: 长肥管道的优化思路都很类似,cwnd 增长快一点: BIC TCP:二分查找逼近 capacity;CUBIC TCP:上凸曲线逼近 capa…

探索光耦:光耦——不间断电源(UPS)系统中的安全高效卫士

在现代社会,不间断电源(UPS)系统已成为保障关键设备和数据安全的关键设施,广泛应用于企业数据中心、家庭电子设备等场景。UPS能在电力中断或波动时提供稳定电力,确保设备持续运行。而在这套系统中,光耦&…