📄 stdafx.cpp
字号:
// stdafx.cpp : source file that includes just the standard includes
// SpeedPostEmail.pch will be the pre-compiled header
// stdafx.obj will contain the pre-compiled type information
#include "stdafx.h"
//
// 将字符串 lpszOrg 转换为多字节的字符串,如果还要使用多字符串的长度,可以用以下方式来使用这个类:
// CMultiByteString MultiByteString(_T("UNICODE字符串"));
// printf ( "ANSI 字符串为: %s, 字符个数为: %d , 长度为: %d字节\n", MultiByteString.GetBuffer(), MultiByteString.GetLength(), MultiByteString.GetSize() );
//
CMultiByteString::CMultiByteString( LPCTSTR lpszOrg, int nOrgStringEncodeType/*=STRING_IS_SOFTCODE*/, OUT char *pOutBuf/*=NULL*/, int nOutBufSize/*=0*/ )
{
m_bNewBuffer = FALSE;
m_pszData = NULL;
m_nDataSize = 0;
m_nCharactersNumber = 0;
if ( !lpszOrg ) return;
// 判断原始字符串的编码方式
BOOL bOrgIsUnicode = FALSE;
if ( nOrgStringEncodeType == STRING_IS_MULTICHARS ) bOrgIsUnicode = FALSE;
else if ( nOrgStringEncodeType == STRING_IS_UNICODE ) bOrgIsUnicode = TRUE;
else
{
#ifdef UNICODE
bOrgIsUnicode = TRUE;
#else
bOrgIsUnicode = FALSE;
#endif
}
// 计算字符串个数和需要的目标缓冲大小
if ( bOrgIsUnicode )
{
m_nCharactersNumber = (int)wcslen((WCHAR*)lpszOrg);
m_nDataSize = (m_nCharactersNumber + 1) * sizeof(WCHAR);
}
else
{
m_nCharactersNumber = (int)strlen((char*)lpszOrg);
m_nDataSize = (m_nCharactersNumber + 1) * sizeof(char);
}
// 使用调用者传入的缓冲
if ( pOutBuf && nOutBufSize > 0 )
{
m_pszData = pOutBuf;
m_nDataSize = nOutBufSize;
}
// 自己申请内存缓冲
else
{
m_pszData = (char*)new BYTE[m_nDataSize];
if ( !m_pszData )
{
::AfxThrowMemoryException ();
return;
}
m_bNewBuffer = TRUE;
}
memset ( m_pszData, 0, m_nDataSize );
if ( bOrgIsUnicode )
{
m_nCharactersNumber = WideCharToMultiByte ( CP_ACP, 0, (LPCWSTR)lpszOrg, m_nCharactersNumber, (LPSTR)m_pszData, m_nDataSize/sizeof(char)-1, NULL, NULL );
if ( m_nCharactersNumber < 1 ) m_nCharactersNumber = (int)strlen ( m_pszData );
}
else
{
m_nCharactersNumber = __min ( m_nCharactersNumber, (int)(m_nDataSize/sizeof(char)-1) );
strncpy ( m_pszData, (const char*)lpszOrg, m_nCharactersNumber );
m_nCharactersNumber = (int)strlen ( m_pszData );
}
m_nDataSize = ( m_nCharactersNumber + 1 ) * sizeof(char);
}
CMultiByteString::~CMultiByteString ()
{
if ( m_bNewBuffer && m_pszData )
{
delete[] m_pszData;
}
}
//
// 将 lpszOrg 转换为该程序使用的编码字符串,如果该程序是 UNICODE 就转为 UNICODE,如果是 ANSI 就转为 ANSI 的
//
CString GetCompatibleString ( LPVOID lpszOrg, BOOL bOrgIsUnicode, int nOrgLength/*=-1*/ )
{
if ( !lpszOrg ) return _T("");
TRY
{
#ifdef UNICODE
if ( bOrgIsUnicode )
{
if ( nOrgLength > 0 )
{
WCHAR *szRet = new WCHAR[nOrgLength+1];
if ( !szRet ) return _T("");
memset ( szRet, 0, (nOrgLength+1)*sizeof(WCHAR) );
memcpy ( szRet, lpszOrg, nOrgLength*sizeof(WCHAR) );
CString csRet = szRet;
delete[] szRet;
return csRet;
}
else if ( nOrgLength == 0 )
return _T("");
else
return (LPCTSTR)lpszOrg;
}
if ( nOrgLength < 0 )
nOrgLength = (int)strlen((const char*)lpszOrg);
int nWideCount = nOrgLength + 1;
WCHAR *wchar = new WCHAR[nWideCount];
if ( !wchar ) return _T("");
memset ( wchar, 0, nWideCount*sizeof(WCHAR) );
::MultiByteToWideChar(CP_ACP, 0, (LPCSTR)lpszOrg, nOrgLength, wchar, nWideCount);
CString csRet = wchar;
delete[] wchar;
return csRet;
#else
if ( !bOrgIsUnicode )
{
if ( nOrgLength > 0 )
{
char *szRet = new char[nOrgLength+1];
if ( !szRet ) return _T("");
memset ( szRet, 0, (nOrgLength+1)*sizeof(char) );
memcpy ( szRet, lpszOrg, nOrgLength*sizeof(char) );
CString csRet = szRet;
delete[] szRet;
return csRet;
}
else if ( nOrgLength == 0 )
return _T("");
else
return (LPCTSTR)lpszOrg;
}
if ( nOrgLength < 0 )
nOrgLength = (int)wcslen((WCHAR*)lpszOrg);
int nMultiByteCount = nOrgLength + 1;
char *szMultiByte = new char[nMultiByteCount];
if ( !szMultiByte ) return _T("");
memset ( szMultiByte, 0, nMultiByteCount*sizeof(char) );
::WideCharToMultiByte ( CP_ACP, 0, (LPCWSTR)lpszOrg, nOrgLength, (LPSTR)szMultiByte, nMultiByteCount, NULL, NULL );
CString csRet = szMultiByte;
delete[] szMultiByte;
return csRet;
#endif
}
CATCH_ALL(e)
{
THROW_LAST ();
}
END_CATCH_ALL
return _T("");
}
CString FormatDateTime ( COleDateTime &DateTime, LPCSTR pFormat )
{
// If null, return empty string
if ( DateTime.GetStatus() == COleDateTime::null || DateTime.GetStatus() == COleDateTime::invalid )
return "";
UDATE ud;
if (S_OK != VarUdateFromDate(DateTime.m_dt, 0, &ud))
{
return "";
}
struct tm tmTemp;
tmTemp.tm_sec = ud.st.wSecond;
tmTemp.tm_min = ud.st.wMinute;
tmTemp.tm_hour = ud.st.wHour;
tmTemp.tm_mday = ud.st.wDay;
tmTemp.tm_mon = ud.st.wMonth - 1;
tmTemp.tm_year = ud.st.wYear - 1900;
tmTemp.tm_wday = ud.st.wDayOfWeek;
tmTemp.tm_yday = ud.wDayOfYear - 1;
tmTemp.tm_isdst = 0;
CString strDate;
LPSTR lpszTemp = strDate.GetBufferSetLength(256);
strftime(lpszTemp, strDate.GetLength(), pFormat, &tmTemp);
strDate.ReleaseBuffer();
return strDate;
}
CString FormatString ( LPCTSTR lpszStr, ... )
{
TCHAR *buf = NULL;
// 循环格式化字符串,如果缓冲不够则将缓冲加大然后重试以保证缓冲够用同时又不浪费
for ( int nBufCount = 1024; nBufCount<5*1024*1024; nBufCount += 1024 )
{
buf = new TCHAR[nBufCount];
if ( !buf )
{
::AfxThrowMemoryException ();
return _T("");
}
memset ( buf, 0, nBufCount*sizeof(TCHAR) );
va_list va;
va_start (va, lpszStr);
int nLen = _vsnprintf_hw ((TCHAR*)buf, nBufCount-sizeof(TCHAR), lpszStr, va);
va_end(va);
if ( nLen <= (int)(nBufCount-sizeof(TCHAR)) )
break;
delete[] buf; buf = NULL;
}
if ( !buf )
{
return _T("");
}
CString csMsg = buf;
delete[] buf; buf = NULL;
return csMsg;
}
/********************************************************************************
* Function Type : Global
* Parameter : lpFileName - 文件路径
* Return Value : -1 - 失败
* >=0 - 文件大小
* Description : 获取文件属性 ( 文件大小、创建时间 )
*********************************************************************************/
int hwGetFileAttr ( LPCTSTR lpFileName, OUT CFileStatus *pFileStatus/*=NULL*/ )
{
if ( !lpFileName || lstrlen(lpFileName) < 1 ) return -1;
CFileStatus fileStatus;
fileStatus.m_attribute = 0;
fileStatus.m_size = 0;
memset ( fileStatus.m_szFullName, 0, sizeof(fileStatus.m_szFullName) );
BOOL bRet = FALSE;
TRY
{
if ( CFile::GetStatus(lpFileName,fileStatus) )
{
bRet = TRUE;
}
}
CATCH (CFileException, e)
{
ASSERT ( FALSE );
bRet = FALSE;
}
CATCH_ALL(e)
{
ASSERT ( FALSE );
bRet = FALSE;
}
END_CATCH_ALL;
if ( pFileStatus )
{
pFileStatus->m_ctime = fileStatus.m_ctime;
pFileStatus->m_mtime = fileStatus.m_mtime;
pFileStatus->m_atime = fileStatus.m_atime;
pFileStatus->m_size = fileStatus.m_size;
pFileStatus->m_attribute = fileStatus.m_attribute;
pFileStatus->_m_padding = fileStatus._m_padding;
lstrcpy ( pFileStatus->m_szFullName, fileStatus.m_szFullName );
}
return (int)fileStatus.m_size;
}
//
// 将一个表示字节的数用可读性好的字符串来表示,例如将 12345678 字节转换为:
// 11.77M
// nFlag - 0 : 自动匹配单位
// 1 : 以 Kb 为单位
// 2 : 以 Mb 为单位
// 3 : 以 Gb 为单位
//
CString FormatBytes ( double fBytesNum, BOOL bShowUnit/*=TRUE*/, int nFlag/*=0*/ )
{
CString csRes;
if ( nFlag == 0 )
{
if ( fBytesNum >= 1024.0 && fBytesNum < 1024.0*1024.0 )
csRes.Format ( _T("%.2f%s"), fBytesNum / 1024.0, bShowUnit?_T(" K"):_T("") );
else if ( fBytesNum >= 1024.0*1024.0 && fBytesNum < 1024.0*1024.0*1024.0 )
csRes.Format ( _T("%.2f%s"), fBytesNum / (1024.0*1024.0), bShowUnit?_T(" M"):_T("") );
else if ( fBytesNum >= 1024.0*1024.0*1024.0 )
csRes.Format ( _T("%.2f%s"), fBytesNum / (1024.0*1024.0*1024.0), bShowUnit?_T(" G"):_T("") );
else
csRes.Format ( _T("%.2f%s"), fBytesNum, bShowUnit?_T(" B"):_T("") );
}
else if ( nFlag == 1 )
{
csRes.Format ( _T("%.2f%s"), fBytesNum / 1024.0, bShowUnit?_T(" K"):_T("") );
}
else if ( nFlag == 2 )
{
csRes.Format ( _T("%.2f%s"), fBytesNum / (1024.0*1024.0), bShowUnit?_T(" M"):_T("") );
}
else if ( nFlag == 3 )
{
csRes.Format ( _T("%.2f%s"), fBytesNum / (1024.0*1024.0*1024.0), bShowUnit?_T(" G"):_T("") );
}
return csRes;
}
//
// 等待线程退出
//
BOOL WaitForThreadEnd ( HANDLE *phThread, DWORD dwWaitTime /*=10*1000*/ )
{
BOOL bRet = TRUE;
ASSERT ( phThread );
if ( !(*phThread) ) return TRUE;
if ( ::WaitForSingleObject ( *phThread, dwWaitTime ) == WAIT_TIMEOUT )
{
bRet = FALSE;
::TerminateThread ( *phThread, 0 );
}
::CloseHandle ( *phThread );
(*phThread) = NULL;
return bRet;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -