VC6.0

发布时间:2024-01-11 00:20:34 来源:君肯网

一般的使用方法是调用两次,

第一次获取需要分配内存的大小

分配完成后第二次在调用进行实际的转换

wchar_t *src

char *dest

int cch

 

cch = WideCharToMultiByte(CP_ACP, 0, src, -1, NULL, 0, NULL, NULL)

dest = new char[cch]

WideCharToMultiByte(CP_ACP, 0, src, -1, dest, cch, NULL, NULL)

错误 92 error C2664: “WideCharToMultiByte”: 不能将参数 3 从“unsigned short *”转换为“LPCWSTR”

WideCharToMultiByte 函数定义于 WinApi.Windows 单元(早期delphi版本在可能在 windows 单元),其函数原型定义如下:

function WideCharToMultiByte external kernel32 name ‘WideCharToMultiByte’

WideCharToMultiByte导入头文件为什么还是不能用

试一试

use std::wstring

或者

按alt+f7 然后去configuration properties -&gtgeneral 把”character set” 从 unicode 改为multibyte.

监控磁盘大小c语言

WideCharToMultiByte

函数功能:该函数映射一个unicode字符串到一个多字节字符串。

函数原型:

int WideCharToMultiByte(

UINT CodePage, //指定执行转换的代码页

DWORD dwFlags, //允许你进行额外的控制,它会影响使用了读音符号(比如重音)的字符

LPCWSTR lpWideCharStr, //指定要转换为宽字节字符串的缓冲区

int cchWideChar, //指定由参数lpWideCharStr指向的缓冲区的字符个数

LPSTR lpMultiByteStr, //指向接收被转换字符串的缓冲区

int cchMultiByte, //指定由参数lpMultiByteStr指向的缓冲区最大值

LPCSTR lpDefaultChar, //遇到一个不能转换的宽字符,函数便会使用pDefaultChar参数指向的字符

LPBOOL pfUsedDefaultChar //至少有一个字符不能转换为其多字节形式,函数就会把这个变量设为TRUE

)

参数:

CodePage:指定执行转换的代码页,这个参数可以为系统已安装或有效的任何代码页所给定的值。你也可以指定其为下面的任意一值:

CP_ACP:ANSI代码页;CP_MACCP:Macintosh代码页;CP_OEMCP:OEM代码页;

CP_SYMBOL:符号代码页(42);CP_THREAD_ACP:当前线程ANSI代码页;

CP_UTF7:使用UTF-7转换;CP_UTF8:使用UTF-8转换。

这篇文章主要介绍了C/C++ 监控磁盘与目录操作的示例,帮助大家更好的理解和学习C/C++编程,感兴趣的朋友可以了解下

遍历磁盘容量:

#include &ltstdio.h&gt

#include &ltWindows.h&gt

void GetDrivesType(const char* lpRootPathName)

{

UINT uDriverType = GetDriveType(lpRootPathName)

switch (uDriverType)

{

case DRIVE_UNKNOWN:puts(“未知磁盘”)break

case DRIVE_NO_ROOT_DIR: puts(“路径无效”)break

case DRIVE_REMOVABLE: puts(“可移动磁盘”)break

case DRIVE_FIXED: puts(“固定磁盘”)break

case DRIVE_REMOTE: puts(“网络磁盘”)break

case DRIVE_CDROM: puts(“光驱”)break

case DRIVE_RAMDISK: puts(“内存映射盘”)break

default: break

}

}

void GetDrivesFreeSpace(const char* lpRootPathName)

{

unsigned long long available, total, free

if (GetDiskFreeSpaceEx(lpRootPathName, (ULARGE_INTEGER*)&ampavailable,

(ULARGE_INTEGER*)&amptotal, (ULARGE_INTEGER*)&ampfree))

{

printf(“磁盘: %s | 总计: %lld MB 已用: %lld MB 剩余: %lld MB \n”,

lpRootPathName, total &gt&gt20, available &gt&gt20, free &gt&gt20)

}

}

int main(int argc,char *argv[])

{

DWORD dwSize = MAX_PATH

char szLogicalDrives[MAX_PATH] = {0}

// 获取逻辑驱动器号字符串

DWORD dwResult = GetLogicalDriveStringsA(dwSize, szLogicalDrives)

if (dwResult &gt0 &amp&ampdwResult &lt= MAX_PATH) {

char* szSingleDrive = szLogicalDrives // 从缓冲区起始地址开始

while (*szSingleDrive) {

//printf(“Drive: %s\n”, szSingleDrive) // 输出单个驱动器的驱动器号

// GetDrivesType(szSingleDrive)

GetDrivesFreeSpace(szSingleDrive)

szSingleDrive += strlen(szSingleDrive) + 1// 获取下一个驱动器地址

}

}

system(“pause”)

return 0

}

遍历文件特定路径:

循环遍历文件路径,并将文件后缀为.exe的路径筛选出来.

#include &ltstdio.h&gt

#include &ltwindows.h&gt

#include &lttlhelp32.h&gt

void SearchFile(char *pszDirectory)

{

// 搜索指定类型文件

char *pszFileName = NULL

char *pTempSrc = NULL

WIN32_FIND_DATA FileData = { 0 }

// 申请动态内存

pszFileName = new char[2048]

pTempSrc = new char[2048]

// 构造搜索文件类型字符串 *.* 表示搜索所有文件类型

wsprintf(pszFileName, “%s\\*.*”, pszDirectory)

HANDLE hFile = ::FindFirstFile(pszFileName, &ampFileData)

if (INVALID_HANDLE_VALUE != hFile)

{

do

{

// 过滤掉当前目录”.” 和上一层目录”..”

if (‘.’ == FileData.cFileName[0])

continue

// 拼接文件路径

wsprintf(pTempSrc, “%s\\%s”, pszDirectory, FileData.cFileName)

// 判断是否是目录还是文件

if (FileData.dwFileAttributes &ampFILE_ATTRIBUTE_DIRECTORY)

SearchFile(pTempSrc)// 如果是目录则继续递归

else

{

char drive[_MAX_DRIVE], dir[_MAX_DIR], fname[_MAX_FNAME], ext[_MAX_EXT]

_splitpath(pTempSrc, drive, dir, fname, ext)

// 如果是文件并且后缀为.exe则输出具体路径

if (strcmp(ext, “.exe”) == 0)

printf(“%s \n”, pTempSrc)

}

} while (::FindNextFile(hFile, &ampFileData))

}

FindClose(hFile)

delete[]pTempSrc

delete[]pszFileName

}

int main(int argc, char * argv[])

{

SearchFile(“c:\\MinGW7”)

system(“pause”)

return 0

}

监控文件目录变化:

#include &ltstdio.h&gt

#include &ltwindows.h&gt

#include &lttlhelp32.h&gt

UINT MonitorFileThreadProc(LPVOID lpVoid)

{

char *pszDirectory = (char *)lpVoid

// 打开目录, 获取文件句柄

HANDLE hDirectory = CreateFile(pszDirectory, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_WRITE,

NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL)

if (INVALID_HANDLE_VALUE == hDirectory)

return 1

char szFileName[MAX_PATH] = { 0 }

BOOL bRet = FALSE

DWORD dwRet = 0

DWORD dwBufferSize = 2048

// 申请一个足够大的缓冲区

VC6.0

BYTE *pBuf = new BYTE[dwBufferSize]

if (NULL == pBuf)

return 2

FILE_NOTIFY_INFORMATION *pFileNotifyInfo = (FILE_NOTIFY_INFORMATION *)pBuf

// 开始循环设置监控

do

{

RtlZeroMemory(pFileNotifyInfo, dwBufferSize)

// 设置监控目录

bRet = ReadDirectoryChangesW(hDirectory, pFileNotifyInfo, dwBufferSize, TRUE,

FILE_NOTIFY_CHANGE_FILE_NAME | // 修改文件名

FILE_NOTIFY_CHANGE_ATTRIBUTES | // 修改文件属性

FILE_NOTIFY_CHANGE_LAST_WRITE, // 最后一次写入

&ampdwRet, NULL, NULL)

if (FALSE == bRet)

break

// 将宽字符转换成窄字符,宽字节字符串转多字节字符串

WideCharToMultiByte(CP_ACP, 0, (wchar_t *)(&amppFileNotifyInfo-&gtFileName),

(pFileNotifyInfo-&gtFileNameLength / 2),szFileName,MAX_PATH,NULL,NULL)

// 将路径与文件连接成完整文件路径

char FullFilePath[1024] = { 0 }

strncpy(FullFilePath, pszDirectory, strlen(pszDirectory))

strcat(FullFilePath, szFileName)

// 判断操作类型并显示

switch (pFileNotifyInfo-&gtAction)

{

case FILE_ACTION_ADDED:

printf(“文件被 [创建]: %s \n”, FullFilePath)break

case FILE_ACTION_REMOVED:

printf(“文件被 [删除]: %s \n”, FullFilePath)break

case FILE_ACTION_MODIFIED:

printf(“文件被 [修改]: %s \n”, FullFilePath)break

case FILE_ACTION_RENAMED_OLD_NAME:

printf(“文件被 [重命名]: %s \n”, FullFilePath)break

}

} while (bRet)

CloseHandle(hDirectory)

delete[] pBuf

pBuf = NULL

return 0

}

int main(int argc, char * argv[])

{

char *pszDirectory = “C:\\”

// 创建线程开始监控

CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)MonitorFileThreadProc, pszDirectory, 0, NULL)

while (1)

{

Sleep(10000)

}

system(“pause”)

return 0

}

监控目录文件变化:

可以将其改为一个简单的文件防篡改程序,也可以用来监控病毒的行为.

#include &ltstdio.h&gt

#include &ltWindows.h&gt

#include &lttlhelp32.h&gt

DWORD WINAPI MonitorFileThreadProc(LPVOID lParam)

{

char *pszDirectory = (char *)lParam

BOOL bRet = FALSE

BYTE Buffer[1024] = { 0 }

FILE_NOTIFY_INFORMATION *pBuffer = (FILE_NOTIFY_INFORMATION *)Buffer

DWORD dwByteReturn = 0

HANDLE hFile = CreateFile(pszDirectory, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE,

NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL)

if (INVALID_HANDLE_VALUE == hFile)

return 1

while (TRUE)

{

ZeroMemory(Buffer, sizeof(Buffer))

// 设置监控目录回调函数

bRet = ReadDirectoryChangesW(hFile,&ampBuffer,sizeof(Buffer),TRUE,

FILE_NOTIFY_CHANGE_FILE_NAME | // 修改文件名

FILE_NOTIFY_CHANGE_ATTRIBUTES | // 修改文件属性

FILE_NOTIFY_CHANGE_LAST_WRITE, // 最后一次写入

&ampdwByteReturn, NULL, NULL)

if (TRUE == bRet)

{

char szFileName[MAX_PATH] = { 0 }

// 将宽字符转换成窄字符,宽字节字符串转多字节字符串

WideCharToMultiByte(CP_ACP,0,pBuffer-&gtFileName,(pBuffer-&gtFileNameLength / 2),

szFileName,MAX_PATH,NULL,NULL)

// 将路径与文件连接成完整文件路径

char FullFilePath[1024] = { 0 }

strncpy(FullFilePath, pszDirectory, strlen(pszDirectory))

strcat(FullFilePath, szFileName)

switch (pBuffer-&gtAction)

{

case FILE_ACTION_ADDED:

{

printf(“添加: %s \n”, FullFilePath)break

}

case FILE_ACTION_REMOVED:

{

printf(“删除: %s \n”, FullFilePath)break

}

case FILE_ACTION_MODIFIED:

{

printf(“修改: %s \n”, FullFilePath)break

}

case FILE_ACTION_RENAMED_OLD_NAME:

{

printf(“重命名: %s”, szFileName)

if (0 != pBuffer-&gtNextEntryOffset)

{

FILE_NOTIFY_INFORMATION *tmpBuffer = (FILE_NOTIFY_INFORMATION *)

((DWORD)pBuffer + pBuffer-&gtNextEntryOffset)

switch (tmpBuffer-&gtAction)

{

case FILE_ACTION_RENAMED_NEW_NAME:

{

ZeroMemory(szFileName, MAX_PATH)

WideCharToMultiByte(CP_ACP,0,tmpBuffer-&gtFileName,

(tmpBuffer-&gtFileNameLength / 2),

szFileName,MAX_PATH,NULL,NULL)

printf(” -&gt%s \n”, szFileName)

break

}

}

}

break

}

case FILE_ACTION_RENAMED_NEW_NAME:

{

printf(“重命名(new): %s \n”, FullFilePath)break

}

}

}

}

CloseHandle(hFile)

return 0

}

int main(int argc, char * argv[])

{

char *pszDirectory = “C:\\”

HANDLE hThread = CreateThread(NULL, 0, MonitorFileThreadProc, pszDirectory, 0, NULL)

WaitForSingleObject(hThread, INFINITE)

CloseHandle(hThread)

return 0

}

以上就是C/C++ 监控磁盘与目录操作的示例的详细内容

以上就是关于VC6.0 怎么使用 WideCharToMultiByte 函数全部的内容,如果了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

更多相关资讯

一般的使用方法是调用两次, 第一次获取需要分配内存的大小 分配完成后第二次在调用进行实际的转换 wchar_t *src char *des…
查看详情
一般的使用方法是调用两次, 第一次获取需要分配内存的大小 分配完成后第二次在调用进行实际的转换 wchar_t *src char *des…
查看详情
一般的使用方法是调用两次, 第一次获取需要分配内存的大小 分配完成后第二次在调用进行实际的转换 wchar_t *src char *des…
查看详情
相关文章
推荐游戏
风之谷
风之谷
游戏资讯 10.5M
下载
斗罗大陆3
斗罗大陆3
游戏资讯 566.9M
下载
冠军网球
冠军网球
游戏资讯 148.1M
下载
最佳炮手
最佳炮手
游戏资讯 68.1M
下载
如梦下弦月
如梦下弦月
游戏资讯 840.1M
下载
富甲封神传
富甲封神传
游戏资讯 263.0M
下载