error C2597: 对非静态成员“CManager::m_moveSpeed”的非法引用

静态成员函数相当于全局函数,只是有一个类名字空间的限制。而类成员函数是成员内部的函数,同一个类的对象实例可以有很多,每一个实例都有自已不同的成员变量值,成员函数一般都是对成员自已的成员变量值在操作,所以调用成员函数,必须明确是对哪一个对象实例的操作。

静态成员函数调用的成员变量值都必须是静态的,等同全局的变量。注:静态成员函数只能访问静态成员变量和静态成员函数。

一个类不同的对象实例的静态变量是同一个变量,所以静态成员函数的调用可以全局调用,而无须指明是对哪一个对象操作。

静态成员(类中用static声明)用“类名::成员名”的方式访问,非静态成员必须通过类对象来访问。也就是说,类的静态成员,通过类名就可以被访问,不一定要定义个对象才行,所以跟对象没有关系的。


二、网上类似问题

Q:
if(z==1)

           Admin::Menu(); 

    else 

          Student::Menu();

          出现C++“非静态成员的非法调用”是什么意思? 

A:  
Menu不是Admin的静态成员函数,所以只能绑定到具体的对象实例上使用,例如

Admin adm;

adm.Menu();


class Test  
{  
public:  
    int f()   
    {  
        cout << "member function" << endl;  
    }  
    static int g()  
    {  
        cout << "static member function" << endl;  
    }  
public:  
    enum   
    {  
        size_f = sizeof(f()), // error, 非静态成员函数的非法调用  
        size_g = sizeof(g())  // ok  
    };  
      
};  
int main()  
{  
    Test::g(); // ok  
    Test::f(); // error,非静态成员函数的非法调用(非静态成员必须由对象调用)  
    Test t;  
    t.g();     // ok  
    t.f();     // ok  
}  


  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我理解了你的要求。实现这个功能需要用到 WinSNMP API 来进行 SNMP 操作,以下是一个简单的 CManager 类实现代码: ```c #include <windows.h> #include <snmp.h> #pragma comment(lib, "snmpapi.lib") class CManager { public: CManager(); ~CManager(); bool Initialize(); bool Uninitialize(); bool GetAValue(const char* szOID, char* szValue, DWORD dwValueSize); bool GetTable(const char* szOID, char* szTable, DWORD dwTableSize, DWORD& dwTableRows); private: HSNMP_SESSION m_hSession; }; CManager::CManager() : m_hSession(NULL) { } CManager::~CManager() { Uninitialize(); } bool CManager::Initialize() { m_hSession = SnmpOpen(NULL, NULL, NULL, 0, SNMP_VERSION_2, SNMP_DEFAULT_RETRIES, SNMP_DEFAULT_TIMEOUT); if (m_hSession == NULL) { return false; } return true; } bool CManager::Uninitialize() { if (m_hSession != NULL) { SnmpClose(m_hSession); m_hSession = NULL; } return true; } bool CManager::GetAValue(const char* szOID, char* szValue, DWORD dwValueSize) { if (m_hSession == NULL) { return false; } SNMPAPI_STATUS nStatus; AsnObjectIdentifier snmpOID; snmpOID.idLength = MAX_OID_LEN; nStatus = SnmpMgrStrToOid(szOID, &snmpOID); if (nStatus != SNMPAPI_SUCCESS) { return false; } SNMP_VAR_BIND varBind; varBind.name = snmpOID; varBind.value.asnType = ASN_NULL; nStatus = SnmpMgrGet(m_hSession, &varBind); if (nStatus != SNMPAPI_SUCCESS) { return false; } if (varBind.value.asnType == ASN_NULL) { szValue[0] = '\0'; } else { DWORD dwLength = dwValueSize; SnmpUtilOidToA(&varBind.value.asnValue.object, szValue, &dwLength); } return true; } bool CManager::GetTable(const char* szOID, char* szTable, DWORD dwTableSize, DWORD& dwTableRows) { if (m_hSession == NULL) { return false; } SNMPAPI_STATUS nStatus; AsnObjectIdentifier snmpOID; snmpOID.idLength = MAX_OID_LEN; nStatus = SnmpMgrStrToOid(szOID, &snmpOID); if (nStatus != SNMPAPI_SUCCESS) { return false; } DWORD dwIndex = 0; while (1) { SNMP_VAR_BIND varBind; varBind.name = snmpOID; varBind.value.asnType = ASN_NULL; nStatus = SnmpMgrGetNext(m_hSession, &varBind); if (nStatus != SNMPAPI_SUCCESS) { break; } if (SnmpUtilOidNCmp(&varBind.name, &snmpOID, snmpOID.idLength) != 0) { break; } char szIndex[MAX_OID_LEN]; DWORD dwLength = MAX_OID_LEN; SnmpUtilOidToA(&varBind.name, szIndex, &dwLength); if (szTable != NULL) { if (dwIndex == 0) { strcpy(szTable, szIndex); } else { strcat(szTable, ";"); strcat(szTable, szIndex); } strcat(szTable, "="); switch (varBind.value.asnType) { case ASN_INTEGER: char szValue[32]; sprintf(szValue, "%d", varBind.value.asnValue.number); strcat(szTable, szValue); break; case ASN_OCTETSTRING: strncat(szTable, (char*)varBind.value.asnValue.string.stream, varBind.value.asnValue.string.length); break; default: strcat(szTable, "unknown type"); break; } } dwIndex++; } dwTableRows = dwIndex; return true; } ``` 这个类中包含了 Initialize() 和 Uninitialize() 方法来初始化和释放 WinSNMP 会话,GetAValue() 方法用于获取一个 OID 的值,GetTable() 方法用于获取一组 OID 的值。在 GetTable() 方法中,我们使用 SnmpMgrGetNext() 方法来获取下一个 OID 的值,这样可以遍历整个 OID 表并获取所有 OID 的值。 以下是一个简单的测试程序: ```c int main() { CManager manager; if (!manager.Initialize()) { printf("Failed to initialize WinSNMP.\n"); return 0; } // Test GetAValue char szValue[MAX_PATH]; if (manager.GetAValue("1.3.6.1.2.1.1.5.0", szValue, MAX_PATH)) { printf("System name: %s\n", szValue); } else { printf("Failed to get system name.\n"); } // Test GetTable char szTable[MAX_PATH]; DWORD dwTableRows; if (manager.GetTable("1.3.6.1.2.1.25.4.2.1.2", szTable, MAX_PATH, dwTableRows)) { printf("Processes:\n"); printf("%s\n", szTable); printf("Total rows: %d\n", dwTableRows); } else { printf("Failed to get processes.\n"); } manager.Uninitialize(); return 0; } ``` 这个测试程序分别测试了 GetAValue 和 GetTable 方法,使用的 OID 分别是系统名称和进程列表。注意,OID 的格式是以“.”分隔的数字,例如 1.3.6.1.2.1.1.5.0 表示系统名称。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值