如何在C++中查找桌面路径
更新:在科迪·格雷回复后,
我想找到一种将文件保存到桌面的方法。由于每个用户都有不同的用户名,我发现以下代码将帮助我找到其他人桌面的路径。但是如何将以下内容保存到桌面呢?
#include <iostream>
#include <windows.h>
#include <fstream>
#include <direct.h>
#include <shlobj.h>
using namespace std;
int main ()
{
ofstream file;
TCHAR appData[MAX_PATH];
if (SUCCEEDED(SHGetFolderPath(NULL,
CSIDL_DESKTOPDIRECTORY | CSIDL_FLAG_CREATE,
NULL,
SHGFP_TYPE_CURRENT,
appData)))
wcout << appData << endl; //This will printout the desktop path correctly, but
file.open(appData +"/.txt"); //how can I open the desktop path here??
file<<"hello\n";
file.close();
return 0;
}
Microsoft Visual Studio 2010、Windows 7、C++ 控制台
UPDATED: after Cody Gray's reply
I want to find a way to save a file to a desktop. Since every user has different user name, I found following code will help me find the path to someone else’s desktop. But how can I save the following to desktop?
#include <iostream>
#include <windows.h>
#include <fstream>
#include <direct.h>
#include <shlobj.h>
using namespace std;
int main ()
{
ofstream file;
TCHAR appData[MAX_PATH];
if (SUCCEEDED(SHGetFolderPath(NULL,
CSIDL_DESKTOPDIRECTORY | CSIDL_FLAG_CREATE,
NULL,
SHGFP_TYPE_CURRENT,
appData)))
wcout << appData << endl; //This will printout the desktop path correctly, but
file.open(appData +"/.txt"); //how can I open the desktop path here??
file<<"hello\n";
file.close();
return 0;
}
Microsoft Visual Studio 2010, Windows 7, C++ console
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
问题是您正在使用定义的
UNICODE
来编译应用程序(您应该这样做),这意味着 C 样式字符串不会存储在char
数组中(因为它们适用于 ANSI 字符串),而是wchar_t
数组。这就是为什么您无法从
char*
转换为LPWSTR
(在 Windows 标头中typedef
为wchar_t*)。
解决方案是更改字符串缓冲区的类型。您可以显式使用
wchar_t
:或者利用
TCHAR
宏,它会自动#define
到适当的类型,具体取决于您是否编译定义了 UNICODE:但这并不是唯一的问题。其他需要注意的事项:
您应该强烈考虑使用
TRUE
和FALSE
符号,而不是文字0
和1
编写 Win32 代码时。当函数的文档表明它接受BOOL
类型的值时,请利用已为该类型定义的符号。它使您的代码更加清晰易读,即使您可以合理地假设这些符号永远不会更改标头中的定义。CSIDL_LOCAL_APPDATA
不是正确的常量。这将返回一个与当前用户关联的文件夹,该文件夹旨在由应用程序用于存储不应该与用户一起漫游的数据(它应该存储在本地计算机上并可用仅)。考虑到所有因素,这可能是比桌面更好的选择,因为应用程序在将垃圾溢出到用户桌面上之前确实应该有一个非常好的理由。如果您需要数据随应用程序漫游,则应使用
CSIDL_APPDATA
。我在我的回答<这里简要介绍了所有这些不同的文件夹是什么、它们的含义以及何时应该使用它们< /a>.但是请注意,
SHGetSpecialFolderPath
函数将您限制为特殊文件夹的特定子集。这让我想到...从 Windows 2000 开始(老实说,我认为没有人还在编写针对 2000 年之前的 Windows 版本的应用程序) ),
SHGetSpecialFolderPath
函数 已过时。针对 Windows 2000 和 XP 的首选替代品是
SHGetFolderPath
,您将以类似的方式使用它:该家族的最新成员是
SHGetKnownFolderPath
适用于仅针对 Windows Vista 及更高版本的新应用程序。The problem is that you're compiling the application with
UNICODE
defined (as you well should be), meaning that C-style strings are not stored inchar
arrays (as they would be for ANSI strings), but ratherwchar_t
arrays.That's why you can't convert from
char*
toLPWSTR
(which istypedef
ed in the Windows headers aswchar_t*
).The solution is to change the type of your string buffer. You can either use
wchar_t
explicitly:or take advantage of the
TCHAR
macro that will automatically#define
to the appropriate type, depending on whether you compile withUNICODE
defined:That's not the only problem though. A couple of other things to note:
You should strongly consider using the
TRUE
andFALSE
symbols instead of the literals0
and1
when writing Win32 code. When the function's documentation indicates that it accepts values of typeBOOL
, take advantage of the symbols that are already defined for that type. It makes your code much clearer and easier to read, even if you can reasonably assume that these symbols will never change their definitions in the headers.CSIDL_LOCAL_APPDATA
is not the correct constant to use if you want the desktop folder. That will return a folder that is associated with the current user and intended to be used by applications for storing data that should not roam with the user (it should be stored and available on the local machine only). All things considered, this is probably a better choice than the desktop anyway, as apps should really have a darn good reason before spilling junk out on a user's desktop.If you need the data to roam with the application, you should use
CSIDL_APPDATA
instead. I provide a brief run-down of what all these different folders are, what they mean, and when you should use them in my answer here.Do note, however, that the
SHGetSpecialFolderPath
function limits you to a particular subset of the special folders. Which brings me to...As of Windows 2000 (and I honestly don't think there's anyone out there still writing apps targeting versions of Windows prior to 2000), the
SHGetSpecialFolderPath
function is obsolete.The preferred replacement for those targeting Windows 2000 and XP is
SHGetFolderPath
, which you would use in a similar fashion:And the newest member of the family is
SHGetKnownFolderPath
for new applications targeting only Windows Vista and later.