时间:2021-05-20
注:在程序退出的时候写上 自己的卸载代码。
复制代码 代码如下:
// FileName: Uninstall.h
#pragma once
class CUninstall
{
private:
// Exe文件名
CString m_strExeName;
// Bat文件名
CString m_strBatName;
public:
// exe的路径
CString m_strExePath;
// bat的路径
CString m_strBatPath;
CString m_unInstallPath;
public:
// 是否已经复制到临时文件夹
bool GetState (void);
// 初始化
void Init (void);
// 卸载程序
void Uninstall (void);
public:
CUninstall();
~CUninstall();
};
复制代码 代码如下:
// FileName: Uninstall.cpp
#include "stdafx.h"
#include "Uninstall.h"
#include <atlconv.h>
#include <locale.h>
CUninstall::CUninstall() : m_strExeName(_T("XABC01.exe")), m_strBatName(_T("XABC01.bat"))
{
TCHAR strPath[MAX_PATH] = {0};
GetTempPath(MAX_PATH, strPath);
m_strExePath = strPath;
m_strExePath += m_strExeName;
memset(strPath, 0, MAX_PATH);
GetTempPath(MAX_PATH, strPath);
m_strBatPath = strPath;
m_strBatPath += m_strBatName;
}
CUninstall::~CUninstall()
{
}
void CUninstall::Uninstall (void)
{
// 获取exe所在路径
CString strExePath; // 临时问价下exe文件所在路径
HMODULE hModule = NULL;
TCHAR strPath[MAX_PATH] = {0};
HKEY hKey;
::GetModuleFileName(hModule, strPath, MAX_PATH);
strExePath = strPath;
// 拷贝到临时文件夹
CopyFile(strExePath, m_strExePath, FALSE);
int nIndex = strExePath.ReverseFind(_T('\\'));
strExePath = strExePath.Left(nIndex);
m_unInstallPath = strExePath;
HANDLE hande = CreateFile (m_strBatPath, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_ARCHIVE, NULL);
CloseHandle(hande);
// 写卸载批处理文件文件到磁盘
CString strBuffer;
strBuffer = _T(":repeat\ndel ");
strBuffer += _T("\"") + m_strExeName + _T("\"\nif exist ");
strBuffer += _T("\"") + m_strExeName + _T("\" goto repeat\n");
strBuffer += _T("rd /s /q \"") + strExePath + _T("\"\n");
strBuffer += _T("del \"") + m_strBatName + _T("\"");
CStdioFile file;
if (file.Open(m_strBatPath, CFile::modeWrite))
{
char* old_locale=_strdup(setlocale(LC_CTYPE,NULL) );
setlocale( LC_CTYPE,"chs");
file.WriteString(strBuffer);
file.Close();
setlocale( LC_CTYPE, old_locale ); //还原语言区域的设置
free( old_locale );//还原区域设定
}
else
{
::MessageBox (NULL, TEXT("文件写入磁盘失败!"), TEXT(""), MB_OK|MB_ICONEXCLAMATION);
}
}
bool CUninstall::GetState (void)
{
if (PathFileExists(m_strBatPath))
{
return true;
}
else
{
return false;
}
}
void CUninstall::Init (void)
{
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C++多重继承引发的重复调用问题与解决方法。分享给大家供大家参考,具体如下:前面简单介绍了一个C++多重继承功能示例,这里再来分析一个多重继承引发
c++回调之利用函数指针示例复制代码代码如下:#includeusingnamespacestd;/******************************
在C++程序中很少有人去使用explicit关键字,不可否认,在平时的实践中确实很少能用的上。再说C++的功能强大,往往一个问题可以利用好几种C++特性去解决。
01C++程序到C程序的翻译要想理解C++的this指针,我们先把下面的C++代码转换成C的代码classCar{public:intm_price;//成员变
1、C和C++够笨,逼的程序员自己做很多事。2、C和C++够通用,逼的程序员广种薄收。这个通用,分两层意思。一个是从应用角度,C和C++是目前我见到唯一的可以适