zoukankan      html  css  js  c++  java
  • Python Network Programming

    @1: 同步网络编程(也就是阻塞方式)

    同步网络编程一次只能连接一个客户端。

    Server端:

    import socket
    
    def debugPrint(name, value):
        print("{0}: {1}".format(name, value))
    
    def server():
        #1:
        server = socket.socket()
        #NOTE: NOT "host = server.gethostname()"
        host = socket.gethostname()
        port = 8080
        #2:
        #NOTE: NOT "server.bind(host, port)" TypeError: bind() takes exactly one argument (2 given)
        server.bind((host, port))
        #3:
        server.listen(3)    #listen()的参数为允许等待的连接数
        while 1:
            #4:
            client, address = server.accept() #accept()会阻塞,直到有客户端连接
            debugPrint("client", client)
            debugPrint("address", address)
            #5:
            client.send("Welcome!")
            client.close()
    
    def main():
        server()

    Client端:

    import socket
    import server
    
    def client():
        #1:
        client = socket.socket()
        host = socket.gethostname()
        port = 8080
        #2:
        client.connect((host, port))
        #3:
        content = client.recv(1024)
        server.debugPrint("From Server", content)
    
    def main():
        client()

    @2: 异步网络编程(也就是非阻塞方式)

    异步网络编程, 允许多个客户端链接。

    异步网络编程有3种实现方法: 分叉(多进程), 多线程,异步IO

    分叉方式占据资源,windows不支持分叉; 多线程方式存在同步问题;

  • 相关阅读:
    python基础语法
    头文件和库文件
    #pragma的用法
    C++ signal的使用
    Glog
    Linux添加环境变量与GCC编译器添加INCLUDE与LIB环境变量
    /etc/ld.so.conf详解
    拿与不拿的dfs
    空白字符读取和处理
    统计频率----初始条件的设置
  • 原文地址:https://www.cnblogs.com/lxw0109/p/Python_Network_Programming.html
Copyright © 2011-2022 走看看