當前位置: 首頁>>代碼示例>>Python>>正文


Python Connection.recv_bytes方法代碼示例

本文整理匯總了Python中multiprocessing.connection.Connection.recv_bytes方法的典型用法代碼示例。如果您正苦於以下問題:Python Connection.recv_bytes方法的具體用法?Python Connection.recv_bytes怎麽用?Python Connection.recv_bytes使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在multiprocessing.connection.Connection的用法示例。


在下文中一共展示了Connection.recv_bytes方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: RawSocketHandler

# 需要導入模塊: from multiprocessing.connection import Connection [as 別名]
# 或者: from multiprocessing.connection.Connection import recv_bytes [as 別名]
    class RawSocketHandler(socketserver.BaseRequestHandler):
        def setup(self):
            registry.append(self)

        def handle(self):
            self.conn = Connection(self.request.detach())
            while self.conn._handle:
                try:
                    obj = json.loads(self.conn.recv_bytes().decode('utf-8'))
                except EOFError:
                    break
                if obj['type'] == 'message':
                    bus.post(nt_from_dict(Message, obj['message'], None))
                    self.conn.send_bytes(json.dumps({'ret': True}).encode('utf-8'))
                elif obj['type'] == 'request':
                    m = bus.post_sync(nt_from_dict(Message, obj['message'], None))
                    if m:
                        ret = {"ret": True, "response": m._asdict()}
                    else:
                        ret = {"ret": False, "response": None}
                    self.conn.send_bytes(json.dumps(ret).encode('utf-8'))

        def send(self, msg):
            if isinstance(msg, Message):
                ret = {"type": "message", "message": msg._asdict()}
            else:
                ret = {"type": "response", "response": msg._asdict()}
            self.conn.send_bytes(json.dumps(ret).encode('utf-8'))

        def finish(self):
            registry.remove(self)

        def close(self):
            self.conn.close()
開發者ID:gumblex,項目名稱:orizonhub,代碼行數:36,代碼來源:rawsocket.py

示例2: _handle

# 需要導入模塊: from multiprocessing.connection import Connection [as 別名]
# 或者: from multiprocessing.connection.Connection import recv_bytes [as 別名]
 def _handle(self, conn_lru_dict: LRUCacheType[multiprocessing_connection.Connection, bool],
             conn: multiprocessing_connection.Connection, c_send: multiprocessing_connection.Connection):
     try:
         data = conn.recv_bytes()
         if not data:
             raise EOFError
         self.logger.debug("parse conn %s" % conn)
         # self.logger.debug(data)
         try:
             result = self.handle(data)
             if result is not None:
                 conn.send_bytes(result)
         except Exception:
             self.logger.exception("handle error")
         conn_lru_dict[conn] = True
         c_send.send_bytes(b'ok')
     except OSError:
         self.logger.debug("conn %s was closed" % conn)
         conn.close()
     except EOFError:
         self.logger.debug("conn %s was eof" % conn)
         conn.close()
     except BrokenPipeError:
         self.logger.debug("conn %s was broken" % conn)
         conn.close()
開發者ID:wwqgtxx,項目名稱:wwqLyParse,代碼行數:27,代碼來源:connection_server.py

示例3: _process

# 需要導入模塊: from multiprocessing.connection import Connection [as 別名]
# 或者: from multiprocessing.connection.Connection import recv_bytes [as 別名]
 def _process(self, conn_lru_dict: LRUCacheType[multiprocessing_connection.Connection, bool],
              handle_pool: ThreadPool,
              c_recv: multiprocessing_connection.Connection,
              c_send: multiprocessing_connection.Connection,
              wait=multiprocessing_connection.wait):
     while True:
         try:
             for conn in wait(list(conn_lru_dict.keys()) + [c_recv]):
                 if conn == c_recv:
                     c_recv.recv_bytes()
                     continue
                 del conn_lru_dict[conn]
                 if not conn.closed:
                     handle_pool.spawn(self._handle, conn_lru_dict, conn, c_send)
                 else:
                     self.logger.debug("conn %s was closed" % conn)
         except OSError as e:
             if getattr(e, "winerror", 0) == 6:
                 continue
             logging.exception("OSError")
         except:
             logging.exception("error")
開發者ID:wwqgtxx,項目名稱:wwqLyParse,代碼行數:24,代碼來源:connection_server.py

示例4: recv

# 需要導入模塊: from multiprocessing.connection import Connection [as 別名]
# 或者: from multiprocessing.connection.Connection import recv_bytes [as 別名]
def recv(conn: Connection):
    while True:
        t = time.time()
        result = SDRPlay.unpack_complex(conn.recv_bytes())
        print("UNPACK", time.time()-t)
開發者ID:jopohl,項目名稱:urh,代碼行數:7,代碼來源:TestSDRPlay.py


注:本文中的multiprocessing.connection.Connection.recv_bytes方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。