zoukankan      html  css  js  c++  java
  • 第16月第10天 poco target

     1.

    void TCPServer::start()

    {

        poco_assert (_stopped);

     

        _stopped = false;

        _thread.start(*this);

    }

     

    void Thread::start(Runnable& target)
    {
        startImpl(target);
    }
    
    ...
    
    void ThreadImpl::startImpl(Runnable& target)
    {
        if (_pData->pRunnableTarget)
            throw SystemException("thread already running");
    
        pthread_attr_t attributes;
        pthread_attr_init(&attributes);
    
        if (_pData->stackSize != 0)
        {
            if (0 != pthread_attr_setstacksize(&attributes, _pData->stackSize))
            {
                pthread_attr_destroy(&attributes);
                throw SystemException("cannot set thread stack size");
            }
        }
    
        _pData->pRunnableTarget = ⌖
        if (pthread_create(&_pData->thread, &attributes, runnableEntry, this))
        {
            _pData->pRunnableTarget = 0;
            pthread_attr_destroy(&attributes);
            throw SystemException("cannot start thread");
        }
        pthread_attr_destroy(&attributes);
    
        if (_pData->policy == SCHED_OTHER)
        {
            if (_pData->prio != PRIO_NORMAL_IMPL)
            {
                struct sched_param par;
                par.sched_priority = mapPrio(_pData->prio, SCHED_OTHER);
                if (pthread_setschedparam(_pData->thread, SCHED_OTHER, &par))
                    throw SystemException("cannot set thread priority");
            }
        }
        else
        {
            struct sched_param par;
            par.sched_priority = mapPrio(_pData->prio, _pData->policy);
            if (pthread_setschedparam(_pData->thread, _pData->policy, &par))
                throw SystemException("cannot set thread priority");
        }
    }
    ...
    
    void* ThreadImpl::runnableEntry(void* pThread)
    {
        _currentThreadHolder.set(reinterpret_cast<ThreadImpl*>(pThread));
    
    #if defined(POCO_OS_FAMILY_UNIX)
        sigset_t sset;
        sigemptyset(&sset);
        sigaddset(&sset, SIGQUIT);
        sigaddset(&sset, SIGTERM);
        sigaddset(&sset, SIGPIPE);
        pthread_sigmask(SIG_BLOCK, &sset, 0);
    #endif
    
        ThreadImpl* pThreadImpl = reinterpret_cast<ThreadImpl*>(pThread);
        AutoPtr<ThreadData> pData = pThreadImpl->_pData;
        try
        {
            pData->pRunnableTarget->run();
        }
        catch (Exception& exc)
        {
            ErrorHandler::handle(exc);
        }
        catch (std::exception& exc)
        {
            ErrorHandler::handle(exc);
        }
        catch (...)
        {
            ErrorHandler::handle();
        }
    
        pData->pRunnableTarget = 0;
        pData->done.set();
        return 0;
    }

    https://codeload.github.com/JetMeta/ZPoco/zip/master

  • 相关阅读:
    mysql中删除重复记录,并保留重复数据中的一条数据的SQL语句
    架构设计文档提纲简描
    各大互联网公司架构演进之路汇总
    大数据安全规范
    生活启示
    mysql数据库分库分表(Sharding)
    大数据风控指标----查准率与查全率
    YARN和MapReduce的内存设置参考
    不要在linux上启用net.ipv4.tcp_tw_recycle参数
    [Spark经验一]Spark RDD计算使用的函数里尽量不要使用全局变量
  • 原文地址:https://www.cnblogs.com/javastart/p/8257897.html
Copyright © 2011-2022 走看看