(_tcsrchr(szFilePath, _T('\\')))[1] = 0

char szFilePath[MAX_PATH];
 GetModuleFileName(NULL, szFilePath, MAX_PATH);  
 (_tcsrchr(szFilePath, _T('\\')))[1] = 0;

这是一段获得程序当前目录的一段代码

这段代码很简单,唯一有点难度的就是最后一句(_tcsrchr(szFilePath, _T('\\')))[1] = 0;

其实这句可分解为两句话

char *ch = _tcsrchr(szFilePath, _T('\\'));查找最后一个\出现的位置,并返回\后面的字符(包括\)

ch[1] = 0;//NULL  通过操作来操作szFilePath = 将szFilePath截断,截断最后一个\后面的字符(不包括\)

转自:http://www.cnblogs.com/flying-roc/articles/1781754.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用ZLIB库 包装的压缩解压缩文件的源码 VS2005 工程创建 /* */ class ZIPWRAP_EXP CZipper { public: CZipper(); virtual ~CZipper(); // simple interface static bool ZipFile(const char* szFilePath); // saves as same name with .zip static bool ZipFolder(const char* szFilePath, bool ignoreself = false); // saves as same name with .zip bool AddFolderToZipFile(const char*foldername, const char* rootfolder); bool AddFileToZipFile(const char*filename, const char*relfolder = NULL, const char* comment = NULL); bool AddFolderOnlyPathToFile(const char* foldername, const char* comment = NULL); bool OpenZipFile(const char* zipfilename, bool append = false); bool CloseZipFile(const char* global_comment = NULL); private: void* zipfile_;/* = NULL */ }; /* */ #define MAX_COMMENT (255) /* tm_unz contain date/time info */ typedef struct UZ_s { unsigned int tm_sec; /* seconds after the minute - [0,59] */ unsigned int tm_min; /* minutes after the hour - [0,59] */ unsigned int tm_hour; /* hours since midnight - [0,23] */ unsigned int tm_mday; /* day of the month - [1,31] */ unsigned int tm_mon; /* months since January - [0,11] */ unsigned int tm_year; /* years - [1980..2044] */ } UZ_s; // create our own fileinfo struct to hide the underlying implementation struct UZ_FileInfo { char szFileName[260 + 1]; char szComment[255 + 1]; unsigned long dwVersion; unsigned long dwVersionNeeded; unsigned long dwFlags; unsigned long dwCompressionMethod; unsigned long dwDosDate; unsigned long dwCRC; unsigned long dwCompressedSize; unsigned long dwUncompressedSize; unsigned long dwInternalAttrib; unsigned long dwExternalAttrib; bool bFolder; UZ_s tmu_date; }; class ZIPWRAP_EXP CUnZipper { public: CUnZipper(); virtual ~CUnZipper(); // simple interface static bool UnZip( const char* filename, const char* dstfolder, bool ingorepath = false, const char* password = NULL); bool OpenUnZipFile(const char* filename); bool CloseUnZipFile(); bool UnZipTo( const char* dstfolder, bool ingorepath = false, const char* password = NULL); int GetFileCount(); bool GotoFirstFile(); bool GotoNextFile(); bool GotoZipFile(int index); bool GotoZipFile(const char* zipfilename); bool GetCurrentFileInfo(UZ_FileInfo&fileinfo;); bool UnCurrentZipFile(const char* dstfolder, bool ingorepath = false, const char* password = NULL); bool UnOneZipFile(const char* filename, const char* dstfolder, bool ingorepath = false, const char* password = NULL); bool UnOneZipFile(int index, const char* dstfolder, bool ingorepath = false, const char* password = NULL); private: void* unzipfile_; };
;;;V2.0修改: 1.修改V1.0的通讯架构,由客户端连接服务端,服务端验证通 ;;; 过后,将行情发送给所有在线客户端. ;;; 2.客户端自动创建行情库 ;;; 3.服务端增加IP过滤功能. ;;; 4.客户端增加当服务端有问题时,自动连接备份服务端功能. [COMMON] ;0为客户端,1为服务端 type=1 ;如为客户端,则填服务端的IP,如为服务端,则填本机IP IP=127.0.0.10 ;通讯端口,双方需配置相同 PORT=9999 ftpport=5000 ;用于配置发送一轮后,等待多少毫秒开始新一轮 delay=1000 ;用于配置是否发送上海行情,1发送,0不发送 send_sh=1 ;用于配置是否发送深圳行情,1发送,0不发送 send_sz=1 ;用于配置是否发送文件 send_file=1 ;用于配置周末是否发送 holiday=0 [CLIENT] ;以下目录必须存在 shhq=d:\\sh\\ szhq=d:\\sz\\ ;文件存放路径 shfilepath=d:\\sh\\msg\\ szfilepath=d:\\sz\\msg\\ other=d:\\sz\\other\\ ;当服务端程序断开时,自动切换到备份服务端 backupip=127.0.0.2,127.0.0.3 [SERVER] shhq=d:\\hqsource\\shhq\\show2003.dbf szhq=d:\\hqsource\\szhq\\sjshq.dbf,d:\\hqsource\\szhq\\sjsxx.dbf,d:\\hqsource\\szhq\\stbhq.dbf starttime=09:55:00-15:31:00,15:32:30-23:15:50 stoptime=23:15:00 ;用于控制是否限制客户端连接,如=0,则不限制客户端,否则只允许IP_PERMIT段的IP地址 ip_filter=1 ip_permit=168.166.129.175,127.0.0.10,127.0.0.2 [sendfile] ;发送文件时间 sendfiletime=14:10:00 ;文件列表 shfiles=c:\\*.txt szfiles=c:\\*.dbf otherfiles= qzxx=d:\\vccode\\qzxx0525.txt
LONG CSCOMMDlg::OnCommunication(WPARAM ch, LPARAM port) { g_ucRecvBuf[g_ulRecvLen++]=UCHAR(ch); if(g_ulRecvLen>=51) { memcpy(&g_ADData,g_ucRecvBuf,51); //return 1; } // return 1; if(g_ulRecvLen<4) return 1; //1表示接收数据长度不够 ULONG ulCheckSum =0; CMDHEADER header; header = *((CMDHEADER *)g_ucRecvBuf); //如果不相等,将Buffer中的每个数据前移动一个位置 if(CMD_SYN_WORD!= header.ulSyncWord) { memmove(g_ucRecvBuf,g_ucRecvBuf+1,3); return 2;//2表示没有接收到同步字 } if(g_ulRecvLen<sizeof(CMDHEADER)) return 3; //3表示没有接收到帧头 CString strTemp; CString strFileName; char szFilePath[MAX_PATH]={0}; switch(header.cmdType) { case CMD_FILEINFO://文件信息(包括名称,大小)命令 if(g_ulRecvLen<header.ulPackLen) return 4; //没有收到完整的文件信息命令 if(g_ulRecvLen==(sizeof(CMDHEADER)+header.ulPackLen)) { FILEINFO fileInfo; fileInfo=*((FILEINFO *)g_ucRecvBuf); ulCheckSum = CheckSum(fileInfo.ucFileName,fileInfo.ulFileNameLen) +fileInfo.lFileLen; if(ulCheckSum!=fileInfo.ulCheckSum) { fileInfo.header.cmdState = CMD_STATE_ERROR; g_lErrorPackNum++; //strTemp.Format("%d",g_lErrorPackNum); } else { fileInfo.header.cmdState = CMD_STATE_OK; //增加接收文件的计时功能 memset(&g_tRecvBegin,0,sizeof(time_t)); time(&g_tRecvBegin); m_bRecvFileIsBegin = TRUE; } m_nCurFileRecvLen=0; m_nFileRecvLen = fileInfo.lFileLen; //文件长度 fileInfo.header.cmdType =CMD_FILEINFO_RESP; m_Port.WriteToPort((char*)&fileInfo.header,sizeof(CMDHEADER)); memcpy(szFilePath,fileInfo.ucFileName,fileInfo.ulFileNameLen); strFileName.Format("%s",szFilePath); m_strCurFilePath= m_strSaveFileDir+strFileName; if(NULL!=g_file.m_hFile) g_file.Close(); g_file.Open(m_strCurFilePath,CFile::modeCreate|CFile::modeReadWrite); TRACE("1,RECV FILEINFO CMD,File Name = %s,g_ulRecvLen = %d\n", fileInfo.ucFileName,g_ulRecvLen); // if(m_nFileRecvLen1024*1024) // { // strTemp.Format("%0.3fKB",m_nFileRecvLen/1024.0/1024.0); // } // //显示"传输总耗时" // const ULONG ulFrameBytes = g_nBaud/10 -(sizeof(CMDHEADER)+4); // long lComm_TimeSum = m_nFileRecvLen/ulFrameBytes; // //传输总耗时间,单位:秒 // // WORD wHour =0; // WORD wMinute =0; // WORD wSecond =0; // // wSecond = lComm_TimeSum%60; // wMinute = lComm_TimeSum/60%60; // wHour = lComm_TimeSum/60/60%60; // // if((0==wSecond)&&(0==wMinute)&&(0==wHour)) // wSecond =1; // strTemp.Format("%02d:%02d:%02d",wHour,wMinute,wSecond); g_ulRecvLen =0; } break; case CMD_FILEDATA: //发送文件中数据的命令 if(g_ulRecvLen<header.ulPackLen) return 5;//没有收到完整的文件数据帧命令 if(g_ulRecvLen == (sizeof(CMDHEADER)+header.ulPackLen)) { FILEDATA fileData; fileData = *((FILEDATA *)g_ucRecvBuf); fileData.pucBuf = new UCHAR[fileData.header.ulPackLen-4]; memset(fileData.pucBuf,0,fileData.header.ulPackLen-4); memcpy(fileData.pucBuf,g_ucRecvBuf+sizeof(CMDHEADER)+4,fileData.header.ulPackLen-4); ulCheckSum=CheckSum(fileData.pucBuf, fileData.header.ulPackLen-4); if(ulCheckSum!= fileData.ulCheckSum) { fileData.header.cmdState =CMD_STATE_ERROR; g_lErrorPackNum++; strTemp.Format("%d",g_lErrorPackNum); //m_editErrorFrames } else fileData.header.cmdState =CMD_STATE_OK; fileData.header.cmdType = CMD_FILEDATA_RESP; g_file.Write(fileData.pucBuf,fileData.header.ulPackLen-4); //fileData.header.ulPackLen-4, DELETE_ARRAYOBJS(fileData.pucBuf); g_ulRecvLen=0; m_Port.WriteToPort((char*)&fileData.header,sizeof(CMDHEADER)); m_nCurFileRecvLen+=fileData.header.ulPackLen-4; strTemp.Format("%0.2f",(float)m_nCurFileRecvLen/(float)m_nFileRecvLen*100); strTemp+=_T("%"); float step = (float)m_nCurFileRecvLen/(float)m_nFileRecvLen*100; // m_progress.SetPos((int)step); /*if(m_nFileRecvLen1024*1024) { strTemp.Format("%0.3fKB",m_nFileRecvLen/1024.0/1024.0); }*/ } break; case CMD_FILEEOF://文件发送结束命令 if(g_ulRecvLen<header.ulPackLen) return 6;//没有发到完整的文件发送结束命令 if(g_ulRecvLen == (sizeof(CMDHEADER)+header.ulPackLen)) { FILEEOF fileEOF; fileEOF= *((FILEEOF *)g_ucRecvBuf); fileEOF.pucBuf = new UCHAR[fileEOF.header.ulPackLen-4]; memset(fileEOF.pucBuf,0,fileEOF.header.ulPackLen-4); memcpy(fileEOF.pucBuf,g_ucRecvBuf+sizeof(CMDHEADER)+4,fileEOF.header.ulPackLen-4); ulCheckSum = CheckSum(fileEOF.pucBuf,fileEOF.header.ulPackLen-4); if(ulCheckSum!=fileEOF.ulCheckSum) { fileEOF.header.cmdState=CMD_STATE_ERROR; g_lErrorPackNum++; strTemp.Format("%d",g_lErrorPackNum); } else { fileEOF.header.cmdState =CMD_STATE_OK; m_bRecvFileIsBegin = FALSE;//接收文件完成,停止显示时间 } fileEOF.header.cmdType =CMD_FILEEOF_RESP; g_file.Write(fileEOF.pucBuf,fileEOF.header.ulPackLen-4); g_file.Close(); //解决大文件发送时,第二个文件打开错误原因是没“置0”原因 g_file.m_hFile=NULL; DELETE_ARRAYOBJS(fileEOF.pucBuf); g_ulRecvLen=0; m_Port.WriteToPort((char*)&fileEOF.header,sizeof(CMDHEADER)); m_nCurFileRecvLen += fileEOF.header.ulPackLen-4; if(m_nFileRecvLen<=0) { strTemp=_T("0%"); } else { strTemp.Format("%0.2f", (float)m_nCurFileRecvLen/(float)m_nFileRecvLen*100); strTemp+=_T("%"); } if(m_nFileRecvLen1024*1024) { strTemp.Format("%0.3fKB",m_nFileRecvLen/1024.0/1024.0); } } break; //=================处理接收端的响应信息 begin 信息头================= case CMD_FILEINFO_RESP://发送文件信息命令后,发到接收端的响应信息 if(CMD_STATE_OK==header.cmdState) { m_bFileInfoIsOK = TRUE; g_ulRecvLen = 0; g_bIsRecvData = TRUE; } else if(CMD_STATE_ERROR==header.cmdState) { m_bFileInfoIsOK = FALSE; g_ulRecvLen=0; SendFileInfo(); } break; //=================处理接收端的响应信息 文件数据================= case CMD_FILEDATA_RESP://发送文件体命令后,发到接收端的响应信息 if(CMD_STATE_OK==header.cmdState) m_bFileDataIsOK = TRUE; else if(CMD_STATE_ERROR==header.cmdState) m_bFileDataIsOK = FALSE; g_ulRecvLen =0; g_bIsRecvData = TRUE; break; //=================处理接收端的响应信息 文件结尾================= case CMD_FILEEOF_RESP://发送文件尾命令后,发到接收端的响应信息 if(CMD_STATE_OK==header.cmdState) { m_bFileEOFIsOK = TRUE; g_bFileSendEnd = TRUE; } else if (CMD_STATE_ERROR == header.cmdState) { m_bFileEOFIsOK = FALSE; m_bSendFileIsBegin = FALSE; } g_ulRecvLen = 0; g_bIsRecvData = TRUE; break; //====================默认处理================= default:break; } //设置信号量 SetEvent(m_hRecvMsgEvent); return 0; //返回0表示正确 }
void Program_dynamic1(char* ip,int port,LPCWSTR str) { unsigned long playlist = create_playlist(64, 32,8536); cout<<"create_playlist:"<<playlist<<endl; unsigned long program = create_program(L"program_1",_TEXT_T("0xff000000")); cout<<"create_program:"<<program<<endl; int dynamic_type = 1; int display_effects = 52; int display_speed = 10; int stay_time = 0; int gif_flag = 0; LPCWSTR bg_color = L"0xff000000"; LPCWSTR color = L"0xffff0000"; LPCWSTR font_attributes = L"normal"; LPCWSTR font = L"SimSun"; LPCWSTR align_h = L"0"; LPCWSTR align_v = L"0"; LPCWSTR ff=L"1.txt"; TCHAR szFilePath[MAX_PATH + 1]={0}; GetModuleFileName(NULL, szFilePath, MAX_PATH); (_tcsrchr(szFilePath, L'\\'))[1] = 0; LPCWSTR f = wcscat(szFilePath,ff); unsigned long dynamic_area = create_dynamic(); cout<<"create_dynamic:"<<dynamic_area<<endl; int err = add_dynamic_unit(dynamic_area, dynamic_type, display_effects, display_speed, stay_time, _TEXT_T("1.txt"), gif_flag, bg_color, 12, font, color, font_attributes, align_h, align_v, 0, 0, 0,_TEXT_T(""),_TEXT_T("")); err = add_dynamic_unit(dynamic_area, 0, display_effects, display_speed, stay_time, _TEXT_T("1.bmp"), gif_flag, bg_color, 12, font, color, font_attributes, _TEXT_T("0"), _TEXT_T("0"), 0, 0, 0,_TEXT_T(""),_TEXT_T("")); cout<<"add_dynamic_unit:"<<err<<endl; err = add_dynamic(program, dynamic_area,0, 0, 0, 64, 32, L"", 0, L"", 100); cout<<"add_dynamic:"<<err<<endl; delete_dynamic(dynamic_area); LPCWSTR m_aging_start_time = _T("2018-12-01"); LPCWSTR m_aging_stop_time = _T("2018-12-30"); LPCWSTR m_period_ontime = _T("15:14:00"); LPCWSTR m_period_offtime = _T("15:15:00"); err = add_program_in_playlist(playlist, program, 0, 10, m_aging_start_time, m_aging_stop_time, m_period_ontime, m_period_offtime, 127); cout<<"add_program_in_playlist:"<<err<<endl; err = update_dynamic(ip, port, _TEXT_T("guest"), _TEXT_T("guest"), playlist, _TEXT_T(""), 1, 0); cout<<"update_dynamic:"<<err<<endl; cancel_send_program(playlist); delete_playlist(playlist); }
最新发布
07-16
这段代码是一个C++函数,名为Program_dynamic1。它的作用是创建一个动态节目,并将其添加到播放列表中,然后通过网络更新动态节目。 函数中主要的步骤包括: 1. 调用create_playlist函数创建一个播放列表,返回一个unsigned long类型的值,表示播放列表的ID。 2. 调用create_program函数创建一个节目,其中包括节目名称和背景颜色。 3. 设置一些动态特效的参数,如动态类型、显示特效、显示速度、停留时间等。 4. 调用create_dynamic函数创建一个动态区域,返回一个unsigned long类型的值,表示动态区域的ID。 5. 调用add_dynamic_unit函数向动态区域中添加动态单元,包括一些参数如动态类型、显示特效、显示速度、文件路径等。 6. 调用add_dynamic函数将动态区域添加到节目中。 7. 调用delete_dynamic函数删除动态区域。 8. 设置一些节目的播放时间参数,如开始日期、结束日期、起止时间等。 9. 调用add_program_in_playlist函数将节目添加到播放列表中。 10. 调用update_dynamic函数通过网络更新动态节目。 11. 调用cancel_send_program函数取消发送节目。 12. 调用delete_playlist函数删除播放列表。 以上就是函数Program_dynamic1的主要流程和功能。请注意,该代码中使用了一些Windows特定的函数和数据类型,如LPCWSTR、TCHAR等,这些是为了支持Unicode字符集和跨平台兼容性而定义的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值