首页 > 编程语言 >网络编程UDP、TCP

网络编程UDP、TCP

时间:2024-08-22 14:05:06浏览次数:9  
标签:UDP socket 编程 System TCP println new public String

1 UDP通信

客户端UDPClient

public class UDPClient {
    public static void main(String[] args) throws IOException {
        // 获取本地服务器地址
        InetAddress server_address = InetAddress.getLocalHost();
        // 创建数据报套接字以连接到服务器
        DatagramSocket client = new DatagramSocket();

        Scanner sc = new Scanner(System.in);
        while (true) {
            System.out.println("please enter:");
            String s = sc.nextLine();
            if (s.equals("exit")) {
                break;
            }
            byte[] bytes = s.getBytes();

            // 创建数据报包以发送消息到服务器
            DatagramPacket sendPacket = new DatagramPacket(bytes, bytes.length, server_address, 8080);
            client.send(sendPacket);
        }
    }
}

服务端UDPSerever

public class UDPServer {
    public static void main(String[] args) throws IOException {
        // 创建一个数据报套接字,并将其绑定到端口8080,用于监听来自客户端的请求
        DatagramSocket server = new DatagramSocket(8080);

        byte[] buffer = new byte[1024];
        // 创建一个数据报包,用于接收客户端发送的数据,指定接收缓冲区和缓冲区长度
        DatagramPacket receivePacket = new DatagramPacket(buffer, buffer.length);

        while (true) {
            // 接收数据报包中的数据
            server.receive(receivePacket);
            int len = receivePacket.getLength();
            String data = new String(receivePacket.getData(), 0, len);
            String ip = receivePacket.getAddress().getHostAddress();
            int port = receivePacket.getPort();
            System.out.println("Received: " + "[ip " + ip + " port " + port + "] " + data);
        }

    }
}

2 TCP通信

客户端TCPClient

public class TCPClient {
    public static void main(String[] args) throws IOException {
        Socket socket = new Socket("127.0.0.1", 9999);

        OutputStream os = socket.getOutputStream();
        DataOutputStream dos = new DataOutputStream(os);

        Scanner scanner = new Scanner(System.in);
        while (true) {
            System.out.println("please enter:");
            String s = scanner.nextLine();
            if (s.equals("exit")) {
                socket.close();
                break;
            }
            dos.writeUTF(s);
            dos.flush();
        }
    }
}

服务端TCPServer

public class TCPServer {
    public static void main(String[] args) throws IOException {
        ServerSocket serverSocket = new ServerSocket(9999);

        Socket socket = serverSocket.accept();

        InputStream is = socket.getInputStream();
        DataInputStream dis = new DataInputStream(is);

        while (true) {
            String s = dis.readUTF();
            System.out.println("ip " + socket.getInetAddress().getHostAddress() + " port "+ socket.getPort() + " " + s);
            System.out.println("--------------");
        }

    }
}

服务端TCPServerMultiThread(多线程)

public class TCPServerMultiThread {
    public static void main(String[] args) throws IOException {
        // 主线程负责接收客户端连接
        ServerSocket serverSocket = new ServerSocket(9999);
        while(true){
            Socket accept = serverSocket.accept();
            System.out.println("online-UP: ip " + accept.getInetAddress().getHostAddress() + " port "+ accept.getPort());
            // 创建子线程并启动
            new ServerThread(accept).start();
        }
    }
}

class ServerThread extends Thread{
    private Socket socket;

    public ServerThread(Socket socket) {
        this.socket = socket;
    }

    @Override
    public void run() {
        try {
            InputStream is = socket.getInputStream();
            DataInputStream dis = new DataInputStream(is);

            while (true) {
                String s = dis.readUTF();
                System.out.println("ip " + socket.getInetAddress().getHostAddress() + " port "+ socket.getPort() + " " + s);
                System.out.println("--------------");
            }
        } catch (IOException e) {
            System.out.println("offline-DOWN: ip " + socket.getInetAddress().getHostAddress() + " port "+ socket.getPort());
            e.printStackTrace();
        }
    }
}

标签:UDP,socket,编程,System,TCP,println,new,public,String
From: https://www.cnblogs.com/sherioc/p/18373721

相关文章

  • AI编程工具简介
    AI编程工具是指利用人工智能技术来辅助编程工作的软件,它们可以帮助开发者提高编码效率、生成代码、自动添加注释、代码翻译以及智能问答等功能:1.**GitHubCopilot**:由GitHub与OpenAI合作开发,提供整行或整个函数的代码建议,支持多种编程语言和IDE。2.**CodeGeeX**:智谱AI推出......
  • 【Android】Android AOP 编程框架
    什么是AOP编程AOP编程全称AspectOrientedProgramming,面向切面编程主要功能是在不改变原代码的前提下,对特点代码节点进行修改,预处理,后期处理AOP的历史Android的AOP编程框架比较多,它们大多具备以下特点以AspectJ为基础,提供AOP编程能力AspectJ最早为Java项目中的编程框......
  • 【花雕学编程】Arduino FOC 之FTC机械臂关节控制
    Arduino是一个开放源码的电子原型平台,它可以让你用简单的硬件和软件来创建各种互动的项目。Arduino的核心是一个微控制器板,它可以通过一系列的引脚来连接各种传感器、执行器、显示器等外部设备。Arduino的编程是基于C/C++语言的,你可以使用ArduinoIDE(集成开发环境)来编写、......
  • 一网打尽,国内外ChatGPT镜像网站集合【2024-08最新】AI编程、AI写作、AI对话、AI翻译、
    一网打尽,我经过一年多搜集的各种AI工具,使用的都是最强最新的大语言模型,都是在各自领域独领风骚的产品。1:【AI站点】AIPlus 推荐指数:⭐️⭐️⭐️⭐️⭐️推荐理由:一个AI综合网站,有多个GPT和绘画站,每个站点都很流畅且可用2:【AI编程】https://zed.dev/推荐指数:⭐️⭐️⭐️⭐️⭐️推荐理......
  • 深入理解 TCP 协议与网络通信
    1.什么是TCP网络分层?TCP网络分层是指将计算机网络的通信过程分为不同的层次,每一层都承担特定的功能。通常,网络分为四个主要层次:应用层、传输层、网络层和链路层。这种分层结构使得网络协议的设计和实现更加清晰,便于维护和扩展。生活案例帮助记忆想象一下,网络就像一个快......
  • 从开发者视角解析提示词工程:大模型时代的新型编程范式
    1.引言在人工智能飞速发展的今天,大语言模型(LLM)、智能代理(Agent)、检索增强生成(RAG)、以及提示词工程(PromptEngineering)这些词语频繁出现在我们的技术讨论中。今天,我们来聊聊提示词工程,看看它怎么成为开发者手中一种新型的“编程语言”。2.传统软件开发流程回顾说到软件开发,大......
  • Python是一种广泛使用的编程语言,其主要用途有什么?
    Python是一种广泛使用的编程语言,其主要用途包括但不限于以下几个方面:1.Web开发Python拥有众多Web开发框架,如Django和Flask,这些框架使得开发者能够高效地构建和维护Web应用程序。许多著名的网站,如YouTube、Instagram以及国内的豆瓣等,都是使用Python进行开发的。2.数据科学......
  • DDD的函数式编程实现
    DDD是一种成熟的软件设计方法,旨在确保领域专家和开发人员能够有效合作,创造出高质量的软件。本文介绍咋将FP(函数式编程)应用于DDD的实现,使其既优雅又简洁。C4模型中,软件架构图分为四个层次:“系统上下文”、“容器”、“组件”和“代码”。“组件”是构成容器的基本单位,也是本文描......
  • 【TCP】核心机制:滑动窗口、流量控制和拥塞控制
    文章目录滑动窗口窗口滑动滑动窗口丢包流量控制拥塞控制窗口大小变化过程滑动窗口有一类算法题,就是通过滑动窗口的思想来解决的,算法中的“滑动窗口”借鉴自TCP的滑动窗口TCP是要保证可靠传输的==>代价,降低了传输的效率(重传,确认重传等操作)TCP希望能在可靠传输......
  • IPC对象通信方式---共享内存 | 网络通信 -编程
    共享内存共享内存机制其允许两个或多个进程共享一个给定的存储区,这一段存储区可以被两个或两个以上的进程映射至自身的地址空间中,一个进程写入共享内存的信息,可以被其他使用这个共享内存的进程,通过一个简单的内存读取错做读出,从而实现了进程间的通信。是内核预留的内存空间,最......