QTime QTimer timeout()驱动秒表具有很高的CPU使用率

时间:2011-01-05 01:23:03

标签: c++ qt timer cpu-usage

在我的游戏中,我需要一个秒表来测量并显示经过的时间。

为此,我制作了一个简单的小部件:

    ZuulStopwatchWidget::ZuulStopwatchWidget(QWidget *parent) :
    QWidget(parent)
{
        num = new QLCDNumber(this); // create the display
        num->setDigitCount(9);

        time = new QTime();
        time->setHMS(0,0,0,0); // set the time

        timer = new QTimer(this);

        connect(timer, SIGNAL(timeout()), this, SLOT(showTime()));
        i=0;
        QString text = time->toString("hh:mm:ss");
        num->display(text);
        //num->setStyleSheet("* { background-color:rgb(199,147,88);color:rgb(255,255,255); padding: 7px}}");
        num->setSegmentStyle(QLCDNumber::Flat); //filled flat outline
        //setStyleSheet("* { background-color:rgb(236,219,187)}}");

        layout = new QVBoxLayout(this);
        layout->addWidget(num);
        setMinimumHeight(70);
}

ZuulStopwatchWidget::~ZuulStopwatchWidget()
{
    // No need to delete any object that has a parent which is properly deleted.

}
void ZuulStopwatchWidget::resetTime()
{
    time->setHMS(0,0,0);
    QString text = time->toString("hh:mm:ss");
    num->display(text);
    i=0;
    stopTime();
}

void ZuulStopwatchWidget::startTime()
{
    //flag=0;
    timer->start(1);
}

void ZuulStopwatchWidget::stopTime()
{
    timer->stop();
}


void ZuulStopwatchWidget::showTime()
{
    QTime newtime;
        //if(flag==1)
                //i=i-1;
    i=i+1;
    newtime=time->addMSecs(i);
    QString text = newtime.toString("mm:ss:zzz");
    num->display(text);
}

但是当我运行游戏时,2,5Ghz i5的CPU使用率约为13%。我知道这不是问题,但对于一个愚蠢的时钟来说肯定是荒谬的。

我做错了还是这种常见做法?!

非常感谢提前。

1 个答案:

答案 0 :(得分:2)

开始(1)将定时器设置为每毫秒触发

然后你想格式化一个字符串并在屏幕上打印它比屏幕可能更新快16倍