API函数为什么不用。
CreateFile不是很方便吗?
CreateFile不是很方便吗?
解决方案 »
- MFC单文档如何初始化内容
- D3DXVec3Unproject函数的一个参数问题
- HOW TO:创建一个由系统菜单,没有标题栏的窗口
- 庆祝第一次测试突破1000人在线中转视频!!
- C++与VC的困惑!
- DLL中的PROPERTYSHEET中使用CHTMLVIEW出现的问题
- 简单问题,静态连接库中,没有用到的代码会不会连接到可执行程序里?
- View的重绘问题,也太慢了吧??
- 谁知道怎么隐去ClassView窗口中的变量或者函数!(内空)
- 多线程数据共享的问题。
- 大家都是爱好VC者,不如一起探讨VC吧?我的QQ是:121823 欢迎和我聊VC共同进步,同是VC不眠人,相逢何必曾相识??朋友....
- ★从两万个数据中找到与给定值最接近的算法问题?
谢谢阿.
没有mfc的吗/
我只是问问,长一下见识:)
LPCTSTR lpPathName, // directory name
LPSECURITY_ATTRIBUTES lpSecurityAttributes // SD
);
一个例子
Platform SDK: Files and I/O
Searching for Files and Changing File Attributes
The following example copies all text files in the current directory to a new directory of read-only files named \TEXTRO. Files in the new directory are changed to read only, if necessary. The application uses the GetCurrentDirectory function to retrieve the current directory path. This function is also used to return to the current directory after changing to the \TEXTRO directory. The application then creates the \TEXTRO directory by using the CreateDirectory function. The application searches the current directory for all .TXT files by using the FindFirstFile and FindNextFile functions. Each .TXT file is copied to the \TEXTRO directory. After a file is copied, the GetFileAttributes function determines whether the file is read only. If the file is not read only, the application changes directories to \TEXTRO and converts the copied file to read only by using the SetFileAttributes function. After all .TXT files in the current directory have been copied, the application closes the search handle by using the FindClose function. WIN32_FIND_DATA FileData;
HANDLE hSearch;
DWORD dwAttrs;
char szDirPath[] = "c:\\TEXTRO\\";
char szNewPath[MAX_PATH];
char szHome[MAX_PATH];
BOOL fFinished = FALSE;
// Create a new directory.
if (!CreateDirectory(szDirPath, NULL))
{
ErrorHandler("Couldn't create new directory.");
}
// Start searching for .TXT files in the current directory.
hSearch = FindFirstFile("*.txt", &FileData);
if (hSearch == INVALID_HANDLE_VALUE)
{
ErrorHandler("No .TXT files found.");
}
// Copy each .TXT file to the new directory
// and change it to read only, if not already.
while (!fFinished)
{
lstrcpy(szNewPath, szDirPath);
lstrcat(szNewPath, FileData.cFileName);
if (CopyFile(FileData.cFileName, szNewPath, FALSE))
{
dwAttrs = GetFileAttributes(FileData.cFileName);
if (!(dwAttrs & FILE_ATTRIBUTE_READONLY))
{
SetFileAttributes(szNewPath,
dwAttrs | FILE_ATTRIBUTE_READONLY);
}
}
else
{
ErrorHandler("Couldn't copy file.");
}
if (!FindNextFile(hSearch, &FileData))
{
if (GetLastError() == ERROR_NO_MORE_FILES)
{
MessageBox(hwnd, "No more .TXT files.",
"Search completed.", MB_OK);
fFinished = TRUE;
}
else
{
ErrorHandler("Couldn't find next file.");
}
}
}
// Close the search handle.
if (!FindClose(hSearch))
{
ErrorHandler("Couldn't close search handle.");
}
Platform SDK Release: February 2001 Contact Platform SDK Order a Platform SDK CD Online