zoukankan      html  css  js  c++  java
  • socket简单通信

    base:

    TCP/IP(Transmission Control Protocol/Internet Protocol) 即传输控制协议/网间协议,是一种面向连接(连接导向)的、可靠的、基于字节流的传输层(Transport layer)通信协议,因为是面向连接的协议,数据像水流一样传输,会存在黏包问题。

    TCP-server:

    一个TCP服务端可以同时连接很多个客户端,例如世界各地的用户使用自己电脑上的浏览器访问淘宝网。因为Go语言中创建多个goroutine实现并发非常方便和高效,所以我们可以每建立一次链接就创建一个goroutine去处理。

    TCP服务端程序的处理流程:

    1. 监听端口
    2. 接收客户端请求建立链接
    3. 创建goroutine处理链接。

    我们使用Go语言的net包实现的TCP服务端代码如下

    package main
    
    import (
        "bufio"
        "fmt"
        "net"
    )
    
    // server
    
    // 监听端口
    // 接收客户端请求建立链接
    // 创建goroutine处理链接
    
    func process(conn net.Conn) {
        defer conn.Close() // 关闭连接
        for {
            reader := bufio.NewReader(conn)
            var buf [128]byte
            n, err := reader.Read(buf[:]) // 读取数据
            if err != nil {
                fmt.Println("read from client failed, err:", err)
                break
            }
            recvStr := string(buf[:n])
            fmt.Println("收到client端发来的数据:", recvStr)
            recvStr += "	to"
            conn.Write([]byte(recvStr)) // 发送数据
        }
    }
    
    func main() {
        listen, err := net.Listen("tcp", "127.0.0.1:20000")
        if err != nil {
            fmt.Println("listen failed, err:", err)
            return
        }
        for {
            conn, err := listen.Accept() // 建立连接
            if err != nil {
                fmt.Println("accept failed, err:", err)
                continue
            }
            go process(conn) // 启动一个goroutine处理连接
        }
    }

    TCP-client

    一个TCP客户端进行TCP通信的流程如下:

    1. 建立与服务端的链接
    2. 进行数据收发
    3. 关闭链接

    使用Go语言的net包实现的TCP客户端代码如下:

    package main
    
    import (
        "bufio"
        "fmt"
        "net"
        "os"
        "strings"
    )
    
    // client
    // 建立与服务端的链接
    // 进行数据收发
    // 关闭链接
    
    func main() {
        conn, err := net.Dial("tcp", "127.0.0.1:20000")
        if err != nil {
            fmt.Println("err :", err)
            return
        }
        defer conn.Close() // 关闭链接
        inputReader := bufio.NewReader(os.Stdin)
        for {
            input, _ := inputReader.ReadString('
    ') // 读取用户输入
            inputInfo := strings.Trim(input, "
    ")
            if strings.ToUpper(inputInfo) == "Q" { // 如果输入q就退出
                return
            }
            _, err = conn.Write([]byte(inputInfo)) // 发送数据
            if err != nil {
                return
            }
            buf := [512]byte{}
            n, err := conn.Read(buf[:])
            if err != nil {
                fmt.Println("recv failed, err:", err)
                return
            }
            fmt.Println(string(buf[:n]))
        }
    }
  • 相关阅读:
    百度面试题:把数组排成最小的数
    面试题:在O(1)时间删除链表结点
    从第一字符串中删除第二个字符串中所有的字符
    在一个字符串中找到第一个只出现一次的字符
    大整数运算
    输出1到最大的N位数
    删除字符串中的数字并压缩字符串
    排列 或组合问题的解法(包含回溯法)
    卡特兰数(Catalan)简介
    编程之美-分层遍历二叉树
  • 原文地址:https://www.cnblogs.com/fmgao-technology/p/11211488.html
Copyright © 2011-2022 走看看