libuv - 在没有多线程

时间:2018-04-27 23:09:32

标签: c++ libuv single-threaded libsourcey

我使用libsourcey,它使用libuv作为其底层I / O网络层。 一切都已设置好并且似乎已经完成(因为我只是原型设计和实验,所以还没有任何测试)。但是,我要求在应用程序循环旁边(libsourcey附带的依赖于libuv循环的循环),还要调用"空闲函数"。就像现在一样,它在每个周期调用空闲CB,这非常消耗CPU。我需要一种方法来限制uv_idle_cb的调用率,而不会阻塞调用线程,该调用线程与应用程序用来处理I / O数据的方式相同(不确定这最后一个语句,请纠正我,如果我'我错了。)

idle函数将管理应用程序的几个不同方面,它需要在1秒内运行x次。此外,一切都需要运行一个相同的线程(计划升级旧应用程序的网络基础设施,完全运行单线程)。

这是我到目前为止的代码,其中还包括我在回调中休眠线程所做的测试,但它会阻止所有内容,所以即使我设置的第二个空闲cb也具有与第一个相同的调用率。 / p>

struct TCPServers
{
    CTCPManager<scy::net::SSLSocket> ssl;
};

int counter = 0;
void idle_cb(uv_idle_t *handle)
{
    printf("Idle callback %d TID %d\n", counter, std::this_thread::get_id());

    counter++;

    std::this_thread::sleep_for(std::chrono::milliseconds(1000 / 25));
}

int counter2 = 0;
void idle_cb2(uv_idle_t *handle)
{
    printf("Idle callback2 %d TID %d\n", counter2, std::this_thread::get_id());

    counter2++;

    std::this_thread::sleep_for(std::chrono::milliseconds(1000 / 50));
}

class CApplication : public scy::Application
{
public:
    CApplication() : scy::Application(), m_uvIdleCallback(nullptr), m_bUseSSL(false)
    {}

    void start()
    {
        run();

        if (m_uvIdleCallback)
            uv_idle_start(&m_uvIdle, m_uvIdleCallback);

        if (m_uvIdleCallback2)
            uv_idle_start(&m_uvIdle2, m_uvIdleCallback2);
    }

    void stop()
    {
        scy::Application::stop();

        uv_idle_stop(&m_uvIdle);

        if (m_bUseSSL)
            scy::net::SSLManager::instance().shutdown();
    }

    void bindIdleEvent(uv_idle_cb cb)
    {
        m_uvIdleCallback = cb;
        uv_idle_init(loop, &m_uvIdle);
    }

    void bindIdleEvent2(uv_idle_cb cb)
    {
        m_uvIdleCallback2 = cb;
        uv_idle_init(loop, &m_uvIdle2);
    }

    void initSSL(const std::string& privateKeyFile = "", const std::string& certificateFile = "")
    {
        scy::net::SSLManager::instance().initNoVerifyServer(privateKeyFile, certificateFile);
        m_bUseSSL = true;
    }

private:
    uv_idle_t m_uvIdle;
    uv_idle_t m_uvIdle2;
    uv_idle_cb m_uvIdleCallback;
    uv_idle_cb m_uvIdleCallback2;
    bool m_bUseSSL;
};

int main()
{
    CApplication app;
    app.bindIdleEvent(idle_cb);
    app.bindIdleEvent2(idle_cb2);
    app.initSSL();
    app.start();

    TCPServers srvs;
    srvs.ssl.start("127.0.0.1", 9000);

    app.waitForShutdown([&](void*) {
        srvs.ssl.shutdown();
    });

    app.stop();

    system("PAUSE");
    return 0;
}

如果有人可以提供帮助,请提前致谢。

1 个答案:

答案 0 :(得分:1)

使用uv_timer_t和uv_timer_cb解决了这个问题(还没有深入研究libuv的doc)。 CPU使用率大幅下降,没有任何东西被阻止。