共享 C++ 的数据成员指针

data member pointer being shared c++

本文关键字:指针 数据成员 C++ 共享      更新时间:2023-10-16

我创建了两个类SystemClock,用于显示当前时间(通过从ctime创建指向结构tm的指针(和另一个名为CustomClock的类,它根据用户给出的小时,分钟和秒创建时间对象。 CustomClass 继承自 SystemClock,SystemClock 具有以小时:分钟:秒格式显示时间的显示方法。

由于某种原因,系统时钟中的 tm* 字段由所有对象共享。因为当我创建一个 CustomClock 对象时,说 c1(1,2,3( 和 c2(4,5,6( 并调用 c1.display 和 c2.display,它们都打印 4:5:6。(为清楚起见,请参阅下面的代码(

法典:

#include <chrono>
#include <ctime>
#include <iostream>
class SystemClock {
public:
tm* time;
SystemClock() {
time_t now = std::time(0);
time = localtime(&now);
}
void display() {
std::cout << "Time: "<< this->time->tm_hour << ":";
std::cout << this->time->tm_min << ":";
std::cout << this->time->tm_sec << std::endl;
}
};
class CustomClock : public SystemClock {
public:
// CustomClock():SystemClock() {}
CustomClock(int hours, int minutes, int seconds) {
this->set_time(hours,minutes,seconds);
}
CustomClock(CustomClock &c) {
std::cout<<"inside copy constructor";
c.display();
this->set_time(c.time->tm_hour,c.time->tm_min,c.time->tm_sec);
}
void set_time(int hours, int minutes, int seconds) {
this->time->tm_hour = hours;
this->time->tm_min = minutes;
this->time->tm_sec = seconds;
}
};
int main() {
CustomClock c1(1,2,3);
CustomClock c2(4,5,6);
c2.display(); //prints Time: 4:5:6
c1.display(); //prints Time: 4:5:6 instead of 1:2:3
CustomClock c3(c1); //prints current time instead of 1:2:3
c3.display();
return 0;
}

当我通过创建值类型数据成员而不是指针类型数据成员来执行上述实现时,它可以正常工作。我无法理解指针如何以及为什么被所有对象共享。

指针被切变,因为localtime方法返回指向内部对象的指针。

返回值指向内部对象...

该函数还访问和修改共享的内部对象...

您可以在以下位置阅读有关它的更多信息: http://www.cplusplus.com/reference/ctime/localtime/

这就是你修复代码的方式(正如Raffallo所指出的(

class SystemClock {
public:
tm time;
SystemClock() {
time_t now = std::time(0);
time = *localtime(&now);
}
...

您应该使用localtime_r.这允许您将内部对象内容复制到用户内存中。