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


Python threading.current_thread方法代碼示例

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


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

示例1: cron_task_host

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def cron_task_host():
    """定時任務宿主, 每分鍾檢查一次列表, 運行時間到了的定時任務"""
    while True:
        # 當全局開關關閉時, 自動退出線程
        if not enable_cron_tasks:
            if threading.current_thread() != threading.main_thread():
                exit()
            else:
                return

        sleep(60)
        try:
            task_scheduler.run()
        except:  # coverage: exclude
            errprint('ErrorDuringExecutingCronTasks')
            traceback.print_exc() 
開發者ID:aploium,項目名稱:zmirror,代碼行數:18,代碼來源:zmirror.py

示例2: acceptThread

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def acceptThread(parameters):
    acceptor = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    acceptor.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    acceptor.bind(('', int(parameters['listenPort'])))
    acceptor.listen(5)
    cur_thread = threading.current_thread()
    logger.info("Listening to connections on port " + str(parameters['listenPort']) + '\n')

    while True:
        (clientSock, clientAddr) = acceptor.accept()
        print "==== Output Request ====="
        msg = "Connected to " + str(clientAddr[0]) + ":" + str(clientAddr[1])
        logger.info(msg)
        thread3 = threading.Thread(target=sendFile, args=(clientSock, parameters))
        thread3.daemon = True
        thread3.start()
    acceptor.close()
    return 
開發者ID:insightfinder,項目名稱:InsightAgent,代碼行數:20,代碼來源:script_runner.py

示例3: acceptThread

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def acceptThread():       
    acceptor = socket.socket(socket.AF_INET, socket.SOCK_STREAM)        
    acceptor.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    acceptor.bind(('', int(uploadPort)))
    acceptor.listen(5)
        
    cur_thread=threading.current_thread()
    while True:            
        (clientSock,clientAddr)=acceptor.accept()
        print "====Output Request:"
        msg = "Connected to " + str(clientAddr[0]) + ":" + str(clientAddr[1])
        print msg
        thread3=threading.Thread(target=sendFile(clientSock))
        thread3.daemon=True
        thread3.start()
        #thread3.join()            
    acceptor.close()
    return 
開發者ID:insightfinder,項目名稱:InsightAgent,代碼行數:20,代碼來源:reporting_send.py

示例4: _app

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def _app() -> Quart:
    app = Quart(__name__)

    @app.route("/", methods=["GET", "POST"])
    def index() -> ResponseReturnValue:
        return request.method

    @app.route("/gen")
    def gen() -> ResponseReturnValue:
        def _gen() -> Generator[bytes, None, None]:
            yield b"%d" % threading.current_thread().ident
            for _ in range(2):
                yield b"b"

        return _gen(), 200

    return app 
開發者ID:pgjones,項目名稱:quart,代碼行數:19,代碼來源:test_sync.py

示例5: process_request

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def process_request(self, environ) -> bool:
        """Process the incoming Flask request."""
        # Bot Service doesn't handle anything over 256k
        length = int(environ.get("CONTENT_LENGTH", "0"))
        if length > 256 * 1024:
            print(f"request too long - rejected")
        else:
            body_bytes = environ["wsgi.input"].read(length)
            environ["wsgi.input"] = BytesIO(body_bytes)
            body_unicode = body_bytes.decode("utf-8")

        # Sanity check JSON
        if body_unicode is not None:
            # Integration layer expecting just the json text.
            _REQUEST_BODIES[current_thread().ident] = body_unicode
        return True 
開發者ID:microsoft,項目名稱:botbuilder-python,代碼行數:18,代碼來源:flask_telemetry_middleware.py

示例6: create_dict

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def create_dict(self):
        """Create a new dict for the current thread, and return it."""
        localdict = {}
        key = self.key
        thread = current_thread()
        idt = id(thread)
        def local_deleted(_, key=key):
            # When the localimpl is deleted, remove the thread attribute.
            thread = wrthread()
            if thread is not None:
                del thread.__dict__[key]
        def thread_deleted(_, idt=idt):
            # When the thread is deleted, remove the local dict.
            # Note that this is suboptimal if the thread object gets
            # caught in a reference loop. We would like to be called
            # as soon as the OS-level thread ends instead.
            local = wrlocal()
            if local is not None:
                dct = local.dicts.pop(idt)
        wrlocal = ref(self, local_deleted)
        wrthread = ref(thread, thread_deleted)
        thread.__dict__[key] = wrlocal
        self.dicts[idt] = wrthread, localdict
        return localdict 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:26,代碼來源:_threading_local.py

示例7: run

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def run(self):
        """Connect to the server and start the loop in its thread.  Retry if requested"""
        self.mumble_thread = threading.current_thread()
        
        # loop if auto-reconnect is requested
        while True:
            self.init_connection()  # reset the connection-specific object members
            
            self.connect()
            
            self.loop()
        
            if not self.reconnect or not self.parent_thread.is_alive():
                break
            
            time.sleep(PYMUMBLE_CONNECTION_RETRY_INTERVAL) 
開發者ID:Robert904,項目名稱:pymumble,代碼行數:18,代碼來源:mumble.py

示例8: get_sizes

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def get_sizes(jsn):
   thrd = threading.current_thread()
   logging.info('starting thread '+str(thrd.ident)+' ...')
   try:
      while True:
         if queue.empty() == True: 
            break
         itm = queue.get()
         logging.info(str(thrd.ident)+' :' +str(itm))
         val = get_remote_size(itm)
         if val != None: jsn[itm]['objsize'] = val
         queue.task_done()
   except Queue.Empty: 
      pass
   logging.info('thread '+str(thrd.ident)+' done...') 
#get_sizes

#--------------------------------------------------------------------------------- 
開發者ID:HDFGroup,項目名稱:hsds,代碼行數:20,代碼來源:get_s3_stats.py

示例9: terminate

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def terminate(self, block=True, timeout=30):
        """Terminate this job, the current thread will blocked util
        the job is terminate finished if block is True """
        if self.is_stopped():
            _logger.info('Job already been stopped.')
            return

        if self._running_thread == threading.current_thread():
            _logger.warning('Job cannot terminate itself.')
            return

        _logger.info('Stopping job')
        self._should_stop = True

        if not block:
            return
        if not self._terminated.wait(timeout):
            _logger.warning('Terminating job timeout.') 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:20,代碼來源:engine.py

示例10: run

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def run(self):
        """Start job and exit util meet stop condition. """
        _logger.info('Start to process job')

        self._stopped = False
        try:
            self._running_thread = threading.current_thread()
            self._run()
        except Exception:
            _logger.exception('Error encountered while running job.')
            raise
        finally:
            self._terminated.set()
            self._stopped = True

        _logger.info('Job processing finished') 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:18,代碼來源:engine.py

示例11: _do_admin

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def _do_admin(self):
        admin_q = self._admin_queue
        resize_win = self._resize_window
        while 1:
            try:
                wakup = admin_q.get(timeout=resize_win + 1)
            except queue.Empty:
                self._do_resize_according_to_loads()
                continue

            if wakup is None:
                break
            else:
                self._do_resize_according_to_loads()
        log.logger.info("ThreadPool admin thread=%s stopped.",
                        threading.current_thread().getName()) 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:18,代碼來源:thread_pool.py

示例12: then

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def then(self, fn, deferred=False):
        result = Future(self._loop)
        result._register()

        def callback(_):
            try:
                if deferred:
                    temp = self._loop.run_later(fn, self.result())
                    temp.chain(result)
                elif not threading.current_thread() is self._loop:
                    temp = self._loop.run_async(fn, self.result())
                    temp.chain(result)
                else:
                    result.set_result(fn(self.result()))
            except Exception as e:
                self.logger.exception(
                    "Unhandled exception while chaining futures"
                )
                result.set_exception(e)
            except:
                result.cancel()

        self.add_done_callback(callback)
        return result 
開發者ID:Parrot-Developers,項目名稱:olympe,代碼行數:26,代碼來源:pomp_loop_thread.py

示例13: run_async

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def run_async(self, func, *args, **kwds):
        """
        Fills in a list with the function to be executed in the pomp thread
        and wakes up the pomp thread.
        """
        future = Future(self)
        future._register()

        if threading.current_thread() is not self:
            self.async_pomp_task.append((future, func, args, kwds))
            self._wake_up()
        else:
            try:
                ret = func(*args, **kwds)
            except Exception as e:
                self.logger.exception(
                    "Unhandled exception in async task function"
                )
                future.set_exception(e)
            else:
                if not isinstance(ret, concurrent.futures.Future):
                    future.set_result(ret)
                else:
                    ret.chain(future)
        return future 
開發者ID:Parrot-Developers,項目名稱:olympe,代碼行數:27,代碼來源:pomp_loop_thread.py

示例14: get_feed_dict

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def get_feed_dict(self, dest=None):
        tid = threading.current_thread().ident
        self.prefetch.setdefault(tid, {'thread': None, 'data': None})
        current = self.prefetch[tid]

        def assign_thread():
            def assign():
                current['data'] = self.get_feed_dict_sync()
            current['thread'] = threading.Thread(target=assign)
            current['thread'].start()
        if current['thread'] is None:
            assign_thread()
        current['thread'].join()
        res = current['data']
        assign_thread()
        return res 
開發者ID:yuantailing,項目名稱:ctw-baseline,代碼行數:18,代碼來源:chineselib.py

示例15: _set_SIGCHLD_handler

# 需要導入模塊: import threading [as 別名]
# 或者: from threading import current_thread [as 別名]
def _set_SIGCHLD_handler():
    # Windows doesn't support SIGCHLD handler
    if sys.platform == 'win32':
        return
    # can't set signal in child threads
    if not isinstance(threading.current_thread(), threading._MainThread):
        return
    global _SIGCHLD_handler_set
    if _SIGCHLD_handler_set:
        return
    previous_handler = signal.getsignal(signal.SIGCHLD)
    if not callable(previous_handler):
        previous_handler = None

    def handler(signum, frame):
        # This following call uses `waitid` with WNOHANG from C side. Therefore,
        # Python can still get and update the process status successfully.
        _error_if_any_worker_fails()
        if previous_handler is not None:
            previous_handler(signum, frame)

    signal.signal(signal.SIGCHLD, handler)
    _SIGCHLD_handler_set = True 
開發者ID:XiaLiPKU,項目名稱:EMANet,代碼行數:25,代碼來源:dataloader.py


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