为什么我列表中的所有元素都有相同的创建时间?

时间:2016-06-15 17:55:59

标签: c++ time.h

我想在list变量中添加节点,其中包含从程序启动开始经过的时间。不幸的是,所有人都有同样的情况。我的代码出了什么问题?

    void MyList:: pushBack(val nval)
{
    if (size == 0)
    {
        first->elem = nval;
        first->time = ((clock() / (double)(CLOCKS_PER_SEC)) * 1000);
        size++;
        return;
    }
    Node *n = new Node(); 
    n->time= ((clock() / (double)(CLOCKS_PER_SEC)) *1000);
    n->elem = nval;
    last->next = n;
    last = n;
    size++;
//  delete n;

}
   struct Node {
    double time;
    val elem;
    Node *next=nullptr;
};

class MyList
{
    int size = 0;
    Node* first;
    Node* last = first;
MyList();
void pushBack(val nval);
~MyList();
};

1 个答案:

答案 0 :(得分:6)

  

为什么列表中的所有元素都有相同的创建时间?

您正在使用

((clock() / (double)(CLOCKS_PER_SEC)) * 1000);

获取time成员变量的值。那是以毫秒为单位的时间。今天的计算机可以在一毫秒内完成大量工作。创建所有对象所花费的时间似乎不到一毫秒。这就是为什么你为所有对象看到time的相同值。

如果clock的分辨率大于毫秒,则对于大量对象,您将看到time的相同值。