社区
硬件/系统
帖子详情
请问如何在windows和linux下看当前的cpu和内存使用率?
mybesthhujian
2005-06-16 10:53:55
有什么相关的系统调用吗?
谢谢
...全文
186
5
打赏
收藏
请问如何在windows和linux下看当前的cpu和内存使用率?
有什么相关的系统调用吗? 谢谢
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
5 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
Alan S1
2005-08-02
打赏
举报
回复
帮你查书了:
// TestDlg.cpp : 实现文件
//
#include "stdafx.h"
#include "Test.h"
#include "TestDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
class CAboutDlg : public CDialog
{
public:
CAboutDlg();
// 对话框数据
enum { IDD = IDD_ABOUTBOX };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()
// CTestDlg 对话框
CTestDlg::CTestDlg(CWnd* pParent /*=NULL*/)
: CDialog(CTestDlg::IDD, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CTestDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CTestDlg, CDialog)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
//}}AFX_MSG_MAP
ON_BN_CLICKED(IDC_BTNNAME, OnBnClickedBtnname)
ON_BN_CLICKED(IDC_BTNIDENTIFY, OnBnClickedBtnidentify)
ON_BN_CLICKED(IDC_BTNVENDOR, OnBnClickedBtnvendor)
ON_BN_CLICKED(IDC_BTNMHZ, OnBnClickedBtnmhz)
ON_BN_CLICKED(IDC_BTNNUMBER, OnBnClickedBtnnumber)
ON_BN_CLICKED(IDC_BTN3DNOW, OnBnClickedBtn3dnow)
ON_BN_CLICKED(IDC_BTNMMX, OnBnClickedBtnmmx)
ON_BN_CLICKED(IDC_BTNSECURE, OnBnClickedBtnsecure)
ON_BN_CLICKED(IDC_BTNNAME9, OnBnClickedBtnname9)
END_MESSAGE_MAP()
// CTestDlg 消息处理程序
BOOL CTestDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// 将\“关于...\”菜单项添加到系统菜单中。
// IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenu.LoadString(IDS_ABOUTBOX);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标
// TODO:在此添加额外的初始化代码
return TRUE; // 除非设置了控件的焦点,否则返回 TRUE
}
void CTestDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}
}
// 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。
void CTestDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
}
}
//当用户拖动最小化窗口时系统调用此函数取得光标显示。
HCURSOR CTestDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CTestDlg::OnBnClickedBtnname()
{
HKEY hKey;
LPCTSTR StrKey="HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0";
if (ERROR_SUCCESS==::RegOpenKeyEx(HKEY_LOCAL_MACHINE,StrKey,NULL,KEY_ALL_ACCESS,&hKey))
{
DWORD dwSize=255,dwType=REG_SZ;
char String[256];
LPCSTR KeyValue="ProcessorNameString";
if (ERROR_SUCCESS==::RegQueryValueEx(hKey,KeyValue,0,&dwType,(BYTE *)String,&dwSize))
{
CString StrData=String;
MessageBox("CPU的名称为:"+StrData,"信息提示",MB_OK);
}
::RegCloseKey(hKey);
}
}
void CTestDlg::OnBnClickedBtnidentify()
{
HKEY hKey;
LPCTSTR StrKey="HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0";
if (ERROR_SUCCESS==::RegOpenKeyEx(HKEY_LOCAL_MACHINE,StrKey,NULL,KEY_ALL_ACCESS,&hKey))
{
DWORD dwSize=255,dwType=REG_SZ;
char String[256];
LPCSTR KeyValue="Identifier";
if (ERROR_SUCCESS==::RegQueryValueEx(hKey,KeyValue,0,&dwType,(BYTE *)String,&dwSize))
{
CString StrData=String;
MessageBox("CPU的标识为:"+StrData,"信息提示",MB_OK);
}
::RegCloseKey(hKey);
}
}
void CTestDlg::OnBnClickedBtnvendor()
{
HKEY hKey;
LPCTSTR StrKey="HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0";
if (ERROR_SUCCESS==::RegOpenKeyEx(HKEY_LOCAL_MACHINE,StrKey,NULL,KEY_ALL_ACCESS,&hKey))
{
DWORD dwSize=255,dwType=REG_SZ;
char String[256];
LPCSTR KeyValue="VendorIdentifier";
if (ERROR_SUCCESS==::RegQueryValueEx(hKey,KeyValue,0,&dwType,(BYTE *)String,&dwSize))
{
CString StrData=String;
MessageBox("CPU的制造商为:"+StrData,"信息提示",MB_OK);
}
::RegCloseKey(hKey);
}
}
inline unsigned _int64 theCycleCount(void)
{
_asm _emit 0x0F
_asm _emit 0x31
}
void CTestDlg::OnBnClickedBtnmhz()
{
unsigned _int64 start=theCycleCount();
Sleep(1000);
unsigned _int64 end=theCycleCount();
unsigned _int64 tick=(end-start)/1000000;
CString StrMHZ;
StrMHZ.Format("CPU的主频为:%ld MHz",tick);
MessageBox(StrMHZ,"信息提示",MB_OK);
}
void CTestDlg::OnBnClickedBtnnumber()
{
//声明硬件信息结构变量
SYSTEM_INFO siSysInfo;
//复制硬件信息到SYSTEM_INFO结构变量
GetSystemInfo(&siSysInfo);
//显示硬件信息
CString StrCPUNumber;
StrCPUNumber.Format("系统一共有 %u 个CPU", siSysInfo.dwNumberOfProcessors);
MessageBox(StrCPUNumber,"信息提示",MB_OK);
}
void CTestDlg::OnBnClickedBtn3dnow()
{
if(IsProcessorFeaturePresent(PF_3DNOW_INSTRUCTIONS_AVAILABLE))
MessageBox("当前CPU支持3DNow技术","信息提示",MB_OK);
else
MessageBox("当前CPU不支持3DNow技术","信息提示",MB_OK);
}
void CTestDlg::OnBnClickedBtnmmx()
{
if(IsProcessorFeaturePresent(PF_MMX_INSTRUCTIONS_AVAILABLE))
MessageBox("当前CPU支持MMX技术","信息提示",MB_OK);
else
MessageBox("当前CPU不支持MMX技术","信息提示",MB_OK);
}
void CTestDlg::OnBnClickedBtnsecure()
{
if(::GetSystemMetrics(SM_SECURE))
MessageBox("提供安全特性","信息提示",MB_OK);
else
MessageBox("没有提供安全特性","信息提示",MB_OK);
}
void CTestDlg::OnBnClickedBtnname9()
{
if(::GetSystemMetrics(SM_SLOWMACHINE))
MessageBox("具有低档处理器","信息提示",MB_OK);
else
MessageBox("不具有低档处理器","信息提示",MB_OK);
}
// TestDlg.h : 头文件
//
#pragma once
// CTestDlg 对话框
class CTestDlg : public CDialog
{
// 构造
public:
CTestDlg(CWnd* pParent = NULL); // 标准构造函数
// 对话框数据
enum { IDD = IDD_TEST_DIALOG };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
HICON m_hIcon;
// 生成的消息映射函数
virtual BOOL OnInitDialog();
afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()
public:
afx_msg void OnBnClickedBtnname();
afx_msg void OnBnClickedBtnidentify();
afx_msg void OnBnClickedBtnvendor();
afx_msg void OnBnClickedBtnmhz();
afx_msg void OnBnClickedBtnnumber();
afx_msg void OnBnClickedBtn3dnow();
afx_msg void OnBnClickedBtnmmx();
afx_msg void OnBnClickedBtnsecure();
afx_msg void OnBnClickedBtnname9();
};
oyljerry
2005-07-28
打赏
举报
回复
不同的操作系统,系统API还有内核等都是不同的,方法也肯定不同了
微星1234
2005-07-28
打赏
举报
回复
window和linux本来就是不同得系统,还指望有相同得API啊:)
linux下获得系统信息(cpu,memory,磁盘I/O,网络等等),
可以用开源库“libstatgrab”,使用方便,功能全
wudong001
2005-06-29
打赏
举报
回复
借此地问stevecrisewu(月亮骑士) ,为什么在两种操作系统下的做法不同?谢谢!!
stevecrisewu
2005-06-17
打赏
举报
回复
int GetCpuUsgesNt()
{
SYSTEM_PERFORMANCE_INFORMATION SysPerfInfo;
SYSTEM_TIME_INFORMATION SysTimeInfo;
SYSTEM_BASIC_INFORMATION SysBaseInfo;
double dbIdleTime;
double dbSystemTime;
LONG status;
typedef LONG (WINAPI *PROCNTQSI)(UINT,PVOID,ULONG,PULONG);
PROCNTQSI NtQuerySystemInformation;
NtQuerySystemInformation = (PROCNTQSI)GetProcAddress(
GetModuleHandle("ntdll"),
"NtQuerySystemInformation"
);
if (!NtQuerySystemInformation)
{
return 0;
}
// get number of processors in the system
status = NtQuerySystemInformation(SystemBasicInformation,
&SysBaseInfo,sizeof(SysBaseInfo),NULL);
if (status != NO_ERROR)
{
return 0;
}
status = NtQuerySystemInformation(SystemTimeInformation,
&SysTimeInfo,sizeof(SysTimeInfo),0);
if (status!=NO_ERROR)
{
return 0;
}
// get new CPU's idle time
status = NtQuerySystemInformation(SystemPerformanceInformation,
&SysPerfInfo,sizeof(SysPerfInfo),NULL);
if (status != NO_ERROR)
{
return 0;
}
// if it's a first call - skip it
if (m_liOldIdleTime.QuadPart != 0)
{
// CurrentValue = NewValue - OldValue
dbIdleTime = Li2Double(SysPerfInfo.liIdleTime) - Li2Double(m_liOldIdleTime);
dbSystemTime = Li2Double(SysTimeInfo.liKeSystemTime) - Li2Double(m_liOldSystemTime);
// CurrentCpuIdle = IdleTime / SystemTime
dbIdleTime = dbIdleTime / dbSystemTime;
// CurrentCpuUsage% = 100 - (CurrentCpuIdle * 100) / NumberOfProcessors
dbIdleTime = 100.0 - dbIdleTime * 100.0 / (double)SysBaseInfo.bKeNumberProcessors + 0.5;
//m_fNewUsges = (UINT)dbIdleTime;
}
// store new CPU's idle and system time
m_liOldIdleTime = SysPerfInfo.liIdleTime;
m_liOldSystemTime = SysTimeInfo.liKeSystemTime;
return (int)dbIdleTime;
}
int GetCpuUsges9X()
{
HKEY hkey;
DWORD dwDataSize;
DWORD dwType;
DWORD dwCpuUsage;
// starting the counter
if ( RegOpenKeyEx( HKEY_DYN_DATA,
"PerfStats\\StartStat",
0,KEY_ALL_ACCESS,
&hkey ) != ERROR_SUCCESS
)
{
return 0;
}
dwDataSize=sizeof(DWORD);
RegQueryValueEx( hkey,
"KERNEL\\CPUUsage",
NULL,&dwType,
(LPBYTE)&dwCpuUsage,
&dwDataSize );
RegCloseKey(hkey);
// geting current counter's value
if ( RegOpenKeyEx( HKEY_DYN_DATA,
"PerfStats\\StatData",
0,KEY_READ,
&hkey ) != ERROR_SUCCESS)
{
return 0;
}
dwDataSize=sizeof(DWORD);
RegQueryValueEx( hkey,
"KERNEL\\CPUUsage",
NULL,&dwType,
(LPBYTE)&dwCpuUsage,
&dwDataSize );
RegCloseKey(hkey);
// stoping the counter
if ( RegOpenKeyEx( HKEY_DYN_DATA,
"PerfStats\\StopStat",
0,KEY_ALL_ACCESS,
&hkey ) != ERROR_SUCCESS)
{
return (int)dwCpuUsage;
}
dwDataSize=sizeof(DWORD);
RegQueryValueEx( hkey,
"KERNEL\\CPUUsage",
NULL,&dwType,
(LPBYTE)&dwCpuUsage,
&dwDataSize );
RegCloseKey(hkey);
return (int)dwCpuUsage;
}
linux
——
CPU
使用率
、
内存
使用率
、磁盘
使用率
等详解
1:
CPU
使用率
可参考
linux
系统查看
CPU
使用率
的命令 常用命令:top top命令是
Linux
下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于
Windows
的任务管理器。 [root@izwz94b8tt3jlf3ne0ymp3z ~]# top top - 09:27:04 up 49 days, 23:46, 8 users, load average: 0.68, 0.72, 0.71 Tasks: 642 total, 1 running, 641 sleepi
linux
获取
cpu
使用率
,
linux
获取
cpu
使用率
Windows
查看
CPU
使用率
很简单,我们通过任务管理器就能看到。那么对于
linux
来说,怎么查看获取
CPU
使用率
呢?下面是学习啦小编跟大家分享的是
linux
获取
cpu
使用率
,欢迎大家来阅读学习。
linux
获取
cpu
使用率
的方法工具/原料Centos获取
CPU
使用率
1实时
CPU
使用率
类似任务管理器实时系统信息可以通过top命令查看。显示的信息四个参数分别是:用户的模式(user)、低优先级的用户模...
Linux
系统查看
CPU
使用率
、
内存
使用率
、磁盘
使用率
、磁盘大小
一、查看
CPU
使用率
1、top命令 在
linux
的系统维护中,可能需要经常查看
cpu
使用率
,分析系统整体的运行情况。常用的查看
CPU
使用率
命令为top命令。 top命令是
Linux
下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于
Windows
的任务管理器。 top:Time of Process查看系统
当前
运行的情况,
CPU
、
内存
、运行时间、交换分区、执行的线程等信息...
Java 获取
当前
系统(
windows
/
linux
)状态(
CPU
利用率,
CPU
温度,
内存
使用率
,磁盘
使用率
)
log.error("脚本文件{} 执行失败:{} {}", cmd, code, errorSb.toString());// 计算 (1 / logicalProcessorCount) * 100。log.debug("脚本文件执行信息:" + infoLine);log.debug("脚本文件执行成功:" + code);//-------------------- 硬盘信息。//--------------------
内存
信息。# 通过
当前
使用
内存
/总
内存
=
内存
利用率。
Linux
系统快速查看
CPU
和
内存
使用情况,附各参数详解
Linux
系统中查看
CPU
和
内存
使用情况,是一个运维工程师常见的事情,下面分享一下。 目 录 1.top命令 2.ps命令 3.free命令 1.top命令 top命令是
Linux
下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于
Windows
的任务管理器。 运行 top 命令后,
CPU
使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等。退出 top 的命令为 q (在 top 运行中敲 q 键一次)。 内容
硬件/系统
2,643
社区成员
17,229
社区内容
发帖
与我相关
我的任务
硬件/系统
VC/MFC 硬件/系统
复制链接
扫一扫
分享
社区描述
VC/MFC 硬件/系统
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章