show_mem在什么时候调用
时间: 2023-03-25 21:02:03 浏览: 81
show_mem函数是在Linux内核中用于打印内存信息的函数,它通常在系统启动时被调用,以便检查系统的内存使用情况。具体来说,show_mem函数会遍历系统中所有的物理内存页,并统计它们的使用情况,最终将结果打印到系统控制台上。这个函数在内核中的定义在文件mm/page_alloc.c中。
相关问题
创建Shape类,在此类中拥有2个double类型私有成员x和y,设有virtual void show_area()=0纯虚函数和设置私有成员set_mem函数。Shape类拥有3个子类分别是Triangle,Square,Circle,在子类中实现面积。最后在主函数实现。
好的,我来帮你解答这个问题。
首先,我们需要创建Shape类,如下所示:
```cpp
class Shape {
private:
double x;
double y;
public:
virtual void show_area() = 0;
void set_mem(double x, double y) {
this->x = x;
this->y = y;
}
};
```
在这个类中,我们定义了两个私有成员变量x和y,以及一个纯虚函数show_area()和一个设置私有成员的函数set_mem()。
然后,我们需要创建三个子类Triangle、Square和Circle,分别实现面积的计算,如下所示:
```cpp
class Triangle : public Shape {
public:
void show_area() override {
cout << "Triangle area: " << x * y / 2 << endl;
}
};
class Square : public Shape {
public:
void show_area() override {
cout << "Square area: " << x * y << endl;
}
};
class Circle : public Shape {
public:
void show_area() override {
cout << "Circle area: " << 3.14 * x * x << endl;
}
};
```
其中,我们使用了继承来实现对Shape类的扩展,并在子类中实现了计算面积的函数show_area()。
最后,在主函数中我们可以这样使用:
```cpp
int main() {
Shape *p;
Triangle t;
Square s;
Circle c;
p = &t;
p->set_mem(10, 5);
p->show_area();
p = &s;
p->set_mem(8, 8);
p->show_area();
p = &c;
p->set_mem(5, 0);
p->show_area();
return 0;
}
```
在这段代码中,我们创建了一个Shape类型的指针p,然后分别将它指向Triangle、Square和Circle类型的对象,然后调用set_mem()函数设置成员变量的值,并最终调用show_area()函数计算并输出面积。
希望这个例子能够帮助你理解如何实现这个问题。
一句句解释分析细致讲解一下这段代码void netconf_entry(void) { int state = 0; int event = 0; UINT8 * pPacket = NULL; UINT32 dataLen = 0; char *pData = NULL; UINT8 ret = 0; struct np_module netopeer_module; struct np_module server_module; memset(&netopeer_module,0,sizeof(struct np_module)); memset(&server_module,0,sizeof(struct np_module)); state = Ros_GetCurState(); event = Ros_GetMsgId(); switch( state ) { case NETCONF_PROCESS_INIT: switch( event ) { case MSG_MasterPowerOn: case MSG_SlavePowerOn: //printf("netconf_entry MSG_SlavePowerOn\n"); Ros_SetNextState(NETCONF_PROCESS_RUNNING); break; case MSG_INIT_PROTOCOL_OK: Ros_SetNextState(NETCONF_PROCESS_RUNNING); break; default: break; } break; case NETCONF_PROCESS_RUNNING: switch( event ) { case MSG_DriverOK: netconf_init(); break; case MSG_NETCONF_TO_DCN: nc_verb_verbose("netconf_entry recv netconf to dcn msg\n"); break; case MSG_ALARM_TO_NETCONF: NcProcessAlarmMsg(); break; case MSG_LIBNETCONF_TO_NETOPEER: ncRcvLibnetconfMsgProc(); break; case MSG_NETCONF_LLDP_TIMER: Ros_SetTimer(netconfLLDPTimerID, NETCONF_MSG_TIME_LLDP, 0); ncLldpchange(); break; case MSG_NETCONF_15MIN_PERF_TIMER: Ros_SetTimer(netconf15MINPerfTimerID, NETCONF_MSG_15MIN_TIME_PERF, 0); packageOptInfo15Min(); packageIfStatisInfo15Min(); break; case MSG_NETCONF_24H_PERF_TIMER: Ros_SetTimer(netconf24hPerfTimerID, NETCONF_MSG_24H_TIME_PERF, 0); packageOptInfo24H(); packageIfStatisInfo24H(); break; case MSG_NETCONF_MEM_CHECK_TIMER: printS("MSG_NETCONF_MEM_CHECK_TIMER TIMEROUT\n"); memory_line_check(0); break; case MSG_NETCONF_TIMER: oam_perf_netconf_show_value_entry(); break; default: break; } break; default: break; } return EXIT_SUCCESS; }
下面是对这段代码的逐句解释和分析:
```c++
void netconf_entry(void)
{
int state = 0;
int event = 0;
UINT8 * pPacket = NULL;
UINT32 dataLen = 0;
char *pData = NULL;
UINT8 ret = 0;
struct np_module netopeer_module;
struct np_module server_module;
memset(&netopeer_module,0,sizeof(struct np_module));
memset(&server_module,0,sizeof(struct np_module));
```
这段代码定义了一个名为netconf_entry的函数,没有参数,返回类型为void。
接下来,定义了一系列变量,包括state和event(int类型)、pPacket(UINT8指针类型)、dataLen(UINT32类型)、pData(char指针类型)和ret(UINT8类型)。
然后,定义了两个结构体变量netopeer_module和server_module,并使用memset函数将其内容初始化为0。
```c++
state = Ros_GetCurState();
event = Ros_GetMsgId();
switch( state )
{
case NETCONF_PROCESS_INIT:
switch( event )
{
case MSG_MasterPowerOn:
case MSG_SlavePowerOn:
//printf("netconf_entry MSG_SlavePowerOn\n");
Ros_SetNextState(NETCONF_PROCESS_RUNNING);
break;
case MSG_INIT_PROTOCOL_OK:
Ros_SetNextState(NETCONF_PROCESS_RUNNING);
break;
default:
break;
}
break;
case NETCONF_PROCESS_RUNNING:
switch( event )
{
case MSG_DriverOK:
netconf_init();
break;
case MSG_NETCONF_TO_DCN:
nc_verb_verbose("netconf_entry recv netconf to dcn msg\n");
break;
case MSG_ALARM_TO_NETCONF:
NcProcessAlarmMsg();
break;
case MSG_LIBNETCONF_TO_NETOPEER:
ncRcvLibnetconfMsgProc();
break;
case MSG_NETCONF_LLDP_TIMER:
Ros_SetTimer(netconfLLDPTimerID, NETCONF_MSG_TIME_LLDP, 0);
ncLldpchange();
break;
case MSG_NETCONF_15MIN_PERF_TIMER:
Ros_SetTimer(netconf15MINPerfTimerID, NETCONF_MSG_15MIN_TIME_PERF, 0);
packageOptInfo15Min();
packageIfStatisInfo15Min();
break;
case MSG_NETCONF_24H_PERF_TIMER:
Ros_SetTimer(netconf24hPerfTimerID, NETCONF_MSG_24H_TIME_PERF, 0);
packageOptInfo24H();
packageIfStatisInfo24H();
break;
case MSG_NETCONF_MEM_CHECK_TIMER:
printS("MSG_NETCONF_MEM_CHECK_TIMER TIMEROUT\n");
memory_line_check(0);
break;
case MSG_NETCONF_TIMER:
oam_perf_netconf_show_value_entry();
break;
default:
break;
}
break;
default:
break;
}
return EXIT_SUCCESS;
}
```
接下来,代码根据当前状态(state)和事件(event)进行switch语句的判断。
如果state为NETCONF_PROCESS_INIT,根据event的不同进行不同的操作。如果event是MSG_MasterPowerOn或MSG_SlavePowerOn,则将下一个状态设置为NETCONF_PROCESS_RUNNING。如果event是MSG_INIT_PROTOCOL_OK,则同样将下一个状态设置为NETCONF_PROCESS_RUNNING。
如果state为NETCONF_PROCESS_RUNNING,根据event的不同进行不同的操作。如果event是MSG_DriverOK,则调用netconf_init函数。如果event是MSG_NETCONF_TO_DCN,则打印一条调试信息。如果event是MSG_ALARM_TO_NETCONF,则调用NcProcessAlarmMsg函数。如果event是MSG_LIBNETCONF_TO_NETOPEER,则调用ncRcvLibnetconfMsgProc函数。如果event是MSG_NETCONF_LLDP_TIMER,则设置一个定时器,并调用ncLldpchange函数。如果event是MSG_NETCONF_15MIN_PERF_TIMER,则设置一个定时器,并依次调用packageOptInfo15Min和packageIfStatisInfo15Min函数。如果event是MSG_NETCONF_24H_PERF_TIMER,则设置一个定时器,并依次调用packageOptInfo24H和packageIfStatisInfo24H函数。如果event是MSG_NETCONF_MEM_CHECK_TIMER,则打印一条信息,并调用memory_line_check函数。如果event是MSG_NETCONF_TIMER,则调用oam_perf_netconf_show_value_entry函数。
最后,函数返回EXIT_SUCCESS(整数值,表示成功)。