MFC自绘内存优化代码

2024-06-14 23:18
文章标签 代码 内存 优化 mfc 自绘

本文主要是介绍MFC自绘内存优化代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

// MemoryDlg.cpp : 实现文件
//


#include "stdafx.h"
#include "MFCApplication1.h"
#include "MemoryDlg.h"
#include "afxdialogex.h"


#include <windows.h>
#include <TLHELP32.H>
#include <psapi.h>
#pragma comment(lib,"psapi.lib")


#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
// MemoryDlg 对话框
IMPLEMENT_DYNAMIC(MemoryDlg, CDialog)


MemoryDlg::MemoryDlg(CWnd* pParent /*=NULL*/)
: CDialog(MemoryDlg::IDD, pParent)
{


}


MemoryDlg::~MemoryDlg()
{
}






void MemoryDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}




BEGIN_MESSAGE_MAP(MemoryDlg, CDialog)
ON_COMMAND(ID_FREEMEM,&MemoryDlg::OnFreemem)
ON_COMMAND(ID_32783,&MemoryDlg::On32783)
//ON_BN_CLICKED(IDC_BUTTON1,&MemoryDlg::OnBnClickedButton1)
END_MESSAGE_MAP( )




// MemoryDlg 消息处理程序




BOOL MemoryDlg::OnInitDialog( )
{
CDialog::OnInitDialog( );


// TODO:  在此添加额外的初始化


//m_Menu.LoadMenu(IDR_MENU2);  //  IDR_MENU1为你加入的菜单的ID,在Resource视图的Menu文件夹下可以找到


//SetMenu(&m_Menu);
 
  CMenu menu;
  menu.LoadMenu(IDR_MENU2);
  SetMenu(&menu);
  menu.Detach( );
 
 
  HANDLE hThread = CreateThread(NULL,0,OnThread,(LPVOID)this,0,NULL);
  if(hThread) CloseHandle(hThread);
 
  SetProcessWorkingSetSize(GetCurrentProcess( ),-1,-1);






return TRUE;  // return TRUE unless you set the focus to a control
// 异常:  OCX 属性页应返回 FALSE
}




DWORD WINAPI MemoryDlg::OnThread(LPVOID lpParameter)
{
//监视内存使用状态线程
MemoryDlg* pDlg = (MemoryDlg*)lpParameter;
while(TRUE)
{
CRect rc;
pDlg->GetClientRect(rc); //奔溃报错


CClientDC cDC(pDlg);
CDC dc;
CBitmap bmp;
dc.CreateCompatibleDC((CDC*)&cDC);
bmp.CreateCompatibleBitmap((CDC*)&cDC,rc.Width( ),rc.Height( ));
dc.SelectObject(&bmp);

CBrush* pBrush = CBrush::FromHandle((HBRUSH)GetStockObject(WHITE_BRUSH));
dc.FillRect(&rc,pBrush);
dc.SetBkMode(TRANSPARENT);

CString strOut;
MEMORYSTATUS mem;
mem.dwLength = sizeof(MEMORYSTATUS);
GlobalMemoryStatus(&mem);

LOGFONT lf;
dc.GetCurrentFont( )->GetLogFont(&lf);
lf.lfHeight = -14;
lf.lfWidth = 0;
StrCpyW(lf.lfFaceName,_T("微软雅黑"));

CFont font;
font.CreateFontIndirect(&lf);
CFont* pOldFont = dc.SelectObject(&font);
dc.SetBkMode(TRANSPARENT);

TEXTMETRIC tm;
dc.GetTextMetrics(&tm);

//画柱形图
CBrush brush;
CRect bkRc(10,10 + tm.tmHeight,110,210);
CRect frRc(11,11 + tm.tmHeight,109,209);

dc.Rectangle(&bkRc);
if(mem.dwMemoryLoad<30)
{
//绿色 RGB(130,193,14)
strOut = L"空闲";
dc.SetTextColor(RGB(130,193,14));
brush.CreateSolidBrush(RGB(130,193,14));
}
else if(mem.dwMemoryLoad<50)
{
//蓝色 RGB(59,169,243)
strOut = L"一般";
dc.SetTextColor(RGB(59,169,243));
brush.CreateSolidBrush(RGB(59,169,243));
}
else if(mem.dwMemoryLoad<70)
{
//黄色 RGB(237,171,0)
strOut = L"繁忙";
dc.SetTextColor(RGB(237,171,0));
brush.CreateSolidBrush(RGB(237,171,0));
}
else if(mem.dwMemoryLoad<80)
{
//橙色 RGB(234,109,12)
strOut = L"非常繁忙";
dc.SetTextColor(RGB(234,109,12));
brush.CreateSolidBrush(RGB(234,109,12));
}
else
{
//红色 RGB(213,10,4)
strOut = L"非常吃力";
dc.SetTextColor(RGB(213,10,4));
brush.CreateSolidBrush(RGB(213,10,4));
}
dc.TextOut(11,10,strOut);

dc.SetTextColor(RGB(0,0,0));
frRc.top = (long)(frRc.top + 209 - 209 * ((float)mem.dwMemoryLoad / 100));
dc.FillRect(&frRc,&brush);
strOut.Format(L"%d%%",mem.dwMemoryLoad);
dc.DrawText(strOut,&bkRc,DT_CENTER | DT_VCENTER | DT_SINGLELINE);

brush.DeleteObject( );

//内存使用率
strOut.Format(L"内存使用率: %d%%",mem.dwMemoryLoad);
dc.TextOut(140,10,strOut);
//物理内存
if(mem.dwTotalPhys >= 1073741824)
strOut.Format(L"物理内存大小: %.2fG",(float)mem.dwTotalPhys / 1073741824);
else if(mem.dwTotalPhys >= 1048576)
strOut.Format(L"物理内存大小: %.2fM",(float)mem.dwTotalPhys / 1048576);
else
strOut.Format(L"物理内存大小: %dKB",mem.dwTotalPhys / 1024);
dc.TextOut(140,10 + tm.tmHeight * 2,strOut);

strOut.Format(L"可用物理内存: %dKB",mem.dwAvailPhys / 1024);
dc.TextOut(140,10 + tm.tmHeight * 3,strOut);
//End 物理内存
//虚拟内存
if(mem.dwTotalVirtual >= 1073741824)
strOut.Format(L"虚拟内存大小: %.2fG",(float)mem.dwTotalVirtual / 1073741824);
else if(mem.dwTotalVirtual >= 1048576)
strOut.Format(L"虚拟内存大小: %.2fM",(float)mem.dwTotalVirtual / 1048576);
else
strOut.Format(L"虚拟内存大小: %dKB",mem.dwTotalVirtual / 1024);
dc.TextOut(140,10 + tm.tmHeight * 5,strOut);

strOut.Format(L"可用虚拟内存: %dKB",mem.dwAvailVirtual / 1024);
dc.TextOut(140,10 + tm.tmHeight * 6,strOut);
//End 虚拟内存
//页面文件
if(mem.dwTotalPageFile >= 1073741824)
strOut.Format(L"页面文件大小: %.2fG",(float)mem.dwTotalPageFile / 1073741824);
else if(mem.dwTotalPageFile >= 1048576)
strOut.Format(L"页面文件大小: %.2fM",(float)mem.dwTotalPageFile / 1048576);
else
strOut.Format(L"页面文件大小: %dKB",mem.dwTotalPageFile / 1024);
dc.TextOut(140,10 + tm.tmHeight * 8,strOut);

strOut.Format(L"可用页面大小: %dKB",mem.dwAvailPageFile / 1024);
dc.TextOut(140,10 + tm.tmHeight * 9,strOut);
//End 页面文件

dc.SelectObject(pOldFont);
font.DeleteObject( );

cDC.BitBlt(0,0,rc.Width( ),rc.Height( ),&dc,0,0,SRCCOPY);
dc.DeleteDC( );
bmp.DeleteObject( );
Sleep(1);
}
return 0;


}


DWORD WINAPI MemoryDlg::OnFreeMemThread(LPVOID lpParameter)
{
//整理内存线程
DWORD dwOld = 0;
DWORD dwNew = 0;
CString strInfo;


MEMORYSTATUS mem;
mem.dwLength = sizeof(MEMORYSTATUS);
GlobalMemoryStatus(&mem);
dwOld = mem.dwAvailPhys;


MemoryDlg* pDlg = (MemoryDlg*)lpParameter;
{
//提权
HANDLE hCurrentProcess;
HANDLE hProcessToken;
TOKEN_PRIVILEGES tp;
LUID luid;


hCurrentProcess = GetCurrentProcess( );
OpenProcessToken(hCurrentProcess,TOKEN_ALL_ACCESS,&hProcessToken);
LookupPrivilegeValue(NULL,TEXT("SeDebugPrivilege"),&luid);


tp.PrivilegeCount = 1;
tp.Privileges[0].Luid = luid;
tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
AdjustTokenPrivileges(hProcessToken,FALSE,&tp,sizeof(TOKEN_PRIVILEGES),
 (PTOKEN_PRIVILEGES)NULL,(PDWORD)NULL);
}
{
//整理内存
HANDLE SnapShot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
if(NULL == SnapShot) goto EndProc;
PROCESSENTRY32 ProcessInfo; //声明进程信息变量
ProcessInfo.dwSize = sizeof(PROCESSENTRY32);
//返回系统中第一个进程的信息
BOOL Status = Process32First(SnapShot,&ProcessInfo);
while(Status)
{
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS,TRUE,
 ProcessInfo.th32ProcessID);
if(hProcess)
{
//内存整理
SetProcessWorkingSetSize(hProcess,-1,-1);
EmptyWorkingSet(hProcess);
CloseHandle(hProcess);
}
//获取下一个进程信息
Status = Process32Next(SnapShot,&ProcessInfo);
}
}
EndProc:
//让内存整理菜单恢复可用
CMenu* pMenu = pDlg->GetMenu( )->GetSubMenu(0);
pMenu->EnableMenuItem(ID_FREEMEM,MF_ENABLED | MF_BYCOMMAND);


//计算释放内存的总数
GlobalMemoryStatus(&mem);
dwNew = mem.dwAvailPhys - dwOld;
if(dwNew >= 1073741824)
strInfo.Format(L"释放了%.2fG内存。",(float)dwNew / 1073741824);
else if(dwNew >= 1048576)
strInfo.Format(L"释放了%.2fM内存。",(float)dwNew / 1048576);
else
strInfo.Format(L"释放了%dKB内存。",dwNew / 1024);
pDlg->SetWindowText(L"Memory - " + strInfo);


return 1;
}






void MemoryDlg::OnFreemem( )
{
// TODO:  在此添加命令处理程序代码


CMenu* pMenu = GetMenu( )->GetSubMenu(0);
pMenu->EnableMenuItem(ID_FREEMEM,MF_DISABLED | MF_GRAYED | MF_BYCOMMAND);


HANDLE hThread = CreateThread(NULL,0,OnFreeMemThread,(LPVOID)this,0,NULL);
if(hThread) CloseHandle(hThread);
}


//退出
void MemoryDlg::On32783( )
{
// TODO:  在此添加命令处理程序代码


//CDialog::OnOK( );
CDialog::OnCancel( );
}

这篇关于MFC自绘内存优化代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1061776

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

记录AS混淆代码模板

开启混淆得先在build.gradle文件中把 minifyEnabled false改成true,以及shrinkResources true//去除无用的resource文件 这些是写在proguard-rules.pro文件内的 指定代码的压缩级别 -optimizationpasses 5 包明不混合大小写 -dontusemixedcaseclassnames 不去忽略非公共

麻了!一觉醒来,代码全挂了。。

作为⼀名程序员,相信大家平时都有代码托管的需求。 相信有不少同学或者团队都习惯把自己的代码托管到GitHub平台上。 但是GitHub大家知道,经常在访问速度这方面并不是很快,有时候因为网络问题甚至根本连网站都打不开了,所以导致使用体验并不友好。 经常一觉醒来,居然发现我竟然看不到我自己上传的代码了。。 那在国内,除了GitHub,另外还有一个比较常用的Gitee平台也可以用于

服务器雪崩的应对策略之----SQL优化

SQL语句的优化是数据库性能优化的重要方面,特别是在处理大规模数据或高频访问时。作为一个C++程序员,理解SQL优化不仅有助于编写高效的数据库操作代码,还能增强对系统性能瓶颈的整体把握。以下是详细的SQL语句优化技巧和策略: SQL优化 1. 选择合适的数据类型2. 使用索引3. 优化查询4. 范式化和反范式化5. 查询重写6. 使用缓存7. 优化数据库设计8. 分析和监控9. 调整配置1、

Android SurfaceFlinger——图形内存分配器(十一)

前面的文章中的图层合成器(HWC),这里我们接着看一下 SurfaceFlinger 中的另一个重要服务——图形内存分配器。 一、简介         android.hardware.graphics.allocator@2.0 是 Android 系统中硬件抽象层(HAL)的一个组件,专门用于图形内存的分配和管理。它是 SurfaceFlinger 在处理图形数据时所依赖的