//字符串转hex数组: "12 34 ab "=>0x12,0x34,0xab
void StringGroupToHex(CString str,UCHAR* hexOut, int &len )
{
int outIndex = 0;
UCHAR ch;
CString nPtr="";
for (int i = 0; i < str.GetLength(); i++)
{
ch = str.GetAt(i);
if (ch != ' ')
{
nPtr += ch;
if ( nPtr.GetLength()<2 )
{
continue;
}
else
{
hexOut[outIndex]=strtol(nPtr, NULL, 16);
nPtr = "";
if (++outIndex > len)
{
break;
}
}
}
}
len = outIndex;
}
//数字转二进制字符串 16 ==>"0001000"
char* decToBin(uint8_t num)
{
int k=0;
static char str[9]= {0};
for(int i=0;i<8;i++)
{
sprintf(str+k,"%d",(num)&0x01 );
num>>=1;
k++;
}
return str;
}
//格式化打印日志
void PrintMsg(char* fmt, ...)
{
#define MAX_LOG_LENGTH 1024
char* buf = new char[MAX_LOG_LENGTH];//注意输出最大长度限制
va_list args;
va_start(args, fmt);
vsprintf_s(buf,MAX_LOG_LENGTH, fmt, args);
va_end(args);
//添加系统时间前缀
SYSTEMTIME sysTm;
CString tmStr;
GetSystemTime( &sysTm);
tmStr.Format("[%02d:%02d:%02d]",(sysTm.wHour+8)%24,sysTm.wMinute,sysTm.wSecond);
OutputDebugString(tmStr);
OutputDebugString(buf);//日志本体
OutputDebugString("\r\n")
free(buf);
return;
}
//输出数组16进制数据调试
void DumpHex(UCHAR* data, int len)
{
char buffer[500];
int pos = 0;
pos += sprintf_s(buffer, "Hex(%d) ", len);
for (int i = 0; i < len; i++)
{
pos += sprintf_s( (char*)(buffer + pos),sizeof(buffer), "%02x ", data[i]);
}
OutputDebugStringA(buffer);
OutputDebugStringA("\n");
}
//获取软件版本+编译时间
char* Get_soft_version()
{
#define SOFT_VER "1.00" //可放在外部定义版本号,编译时间_TIME_只跟随当前C文件变化
static char verStr[21] = { 0 }; //格式 eg: 1.00.220925.113056
#define YEAR ((((__DATE__[7]-'0')*10+(__DATE__[8]-'0'))*10 \
+(__DATE__[9]-'0'))*10+(__DATE__[10]-'0'))
#define MONTH (__DATE__[2]=='n'?1 \
:__DATE__[2]=='b'?2 \
:__DATE__[2]=='r'?(__DATE__[0]=='M'?3:4) \
:__DATE__[2]=='y'?5 \
:__DATE__[2]=='n'?6 \
:__DATE__[2]=='l'?7 \
:__DATE__[2]=='g'?8 \
:__DATE__[2]=='p'?9 \
:__DATE__[2]=='t'?10 \
:__DATE__[2]=='v'?11:12)
#define DAY ((__DATE__[4]==' '?0:__DATE__[4]-'0')*10 \
+(__DATE__[5]-'0'))
#define HOUR ((__TIME__[0]-'0')*10+(__TIME__[1]-'0'))
#define MINUTE ((__TIME__[3]-'0')*10+(__TIME__[4]-'0'))
#define SECOND ((__TIME__[6]-'0')*10+(__TIME__[7]-'0'))
//#define TIME_AS_INT ( (((((YEAR - 2000) * 12 + MONTH) * 31 + DAY)*12+HOUR)*60+MINUTE)* 60 + SECOND )
//#define DATE_AS_INT (((YEAR - 2000) * 12 + MONTH) * 31 + DAY)
//
//版本号+年月日+时分秒 (年份只取两位)
sprintf_s(verStr, sizeof(verStr),"%s.%02d%02d%02d.%02d%02d%02d",SOFT_VER, YEAR-2000, MONTH, DAY, HOUR, MINUTE, SECOND);
return verStr;
}
CString g_ini_fileName = "My_Soft_Config.ini";
void WriteInitParam(CString keyStr, CString wrStr)
{
::WritePrivateProfileStringA("Config", keyStr, wrStr, g_ini_fileName);
}
void ReadInitParam(CString keyStr, CString defStr, CString& outStr)
{
::GetPrivateProfileString("Config", keyStr, defStr, outStr.GetBuffer(MAX_PATH), MAX_PATH, g_ini_fileName);
}
----------待续--------------------