Windows中程序可变数据的放置
acmilan2017/06/14软件综合 IP:四川

对于一般的程序,按照下面的方法存储可变数据就行了:

  • Unicode程序(类似Chrome):
    • 对于新系统,放到%[LOCAL]APPDATA%\OrgName\AppName
    • 对于老系统,放到%APPDATA%\OrgName\AppName
  • 非Unicode程序(类似Python 2.7):
    • 如果要求整个树Authenticated Users允许修改(最简单实用):
      • 放到%SYSTEMDRIVE%\AppName
      • 最新的系统,系统根目录只能新建子文件夹,子文件夹才可以允许修改
    • 如果要求整个树CREATOR OWNER完全控制,所有子文件夹Users可创建项目和修改属性(不推荐):
      • 对于新系统,放到%PROGRAMDATA%\OrgName\AppName\user#hash#
      • 对于老系统,放到%ALLUSERSPROFILE%\Application Data\OrgName\AppName\user#hash#

简单一句话就是:Unicode程序最好放到AppData子文件夹,非Unicode程序最好放到系统根目录子文件夹。

如果需要让用户能够备份自己的数据,可以把数据放到用户资料文件夹,SHGetSpecialFolderPath等API可以获取Windows中特殊文件夹的位置,用户资料文件夹如下:

  • 老系统:CSIDL_PERSONAL、CSIDL_MYPICTURES、CSIDL_MYMUSIC、CSIDL_MYVIDEO、CSIDL_DESKTOPDIRECTORY
  • 新系统:
    • 传统:FOLDERID_Documents、FOLDERID_Pictures、FOLDERID_Music、FOLDERID_Videos、FOLDERID_Desktop
    • 新增:FOLDERID_SavedGames、FOLDERID_Contacts、FOLDERID_Links、FOLDERID_Favorites、FOLDERID_SavedSearches、FOLDERID_Downloads

[修改于 6年10个月前 - 2017/06/14 04:10:19]

来自:计算机科学 / 软件综合
4
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
amo
6年10个月前 IP:广东
834867
为什么不在启动的时候获取程序所在目录,然后所有东西都放到自己目录底下,无需依赖系统,不更改系统,绿色环保
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
acmilan作者
6年10个月前 修改于 6年10个月前 IP:四川
834886
引用 amo:
为什么不在启动的时候获取程序所在目录,然后所有东西都放到自己目录底下,无需依赖系统,不更改系统,绿色环保
是否可以将数据保存在程序所在目录,要看情况
程序被装到Program Files,一般是没有修改权限的
程序被装到%APPDATA%或%LOCALAPPDATA%,可能用户名有特殊字符,Python2.7这种程序容易报错
程序被装到%PROGRAMDATA%或%ALLUSERSPROFILE%,则只有创建的用户才有修改权限,其它人只能创建新项目
程序被装到%SYSTEMDRIVE%根目录,所有非Guest用户对子目录都有修改权限,这种情况是兼容性最好的
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
amo
6年10个月前 IP:广东
834890
引用 acmilan:
是否可以将数据保存在程序所在目录,要看情况
程序被装到Program Files,一般是没有修改权限的
程序被装到%APPDATA%或%LOCALAPPDATA%,可能用户名有特殊字符,Python2……
软件解压即可运行,就没那么多烦恼了……

商业软件把安装过程、卸载过程搞得那么炫目,并且在系统盘几十个文件夹里都放置它的各种文件夹、文件,是不是一种过度包装行为,目的是为了让用户感受其专业性而买单?
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
acmilan作者
6年10个月前 修改于 6年10个月前 IP:四川
834903
引用 amo:
软件解压即可运行,就没那么多烦恼了……

商业软件把安装过程、卸载过程搞得那么炫目,并且在系统盘几十个文件夹里都放置它的各种文件夹、文件,是不是一种过度包装行为,目的是为了让用户感受其专业性而买单?
要考虑到很多系统只有C盘一个盘,你解压到哪里呢?这就是我说的这个问题了。

第二个问题,
Windows爱好者确实最喜欢绿色软件,这主要是因为Windows是个丰富的标准环境,什么都不装就可以具有强大的功能。Windows发展过程中,会将一些常用的redist dll集成为known dll,也会增加一些non-redist的known dll,使得系统功能越来越强大,而这些dll出于兼容性的考虑一般都不会被主动移除,这就是Windows现在绿色软件多的原因。Linux绿色软件反而比较少,主要是Linux已安装环境可以差别很大,标准环境并不强大,经常需要解决依赖问题。
使用安装程序而不是绿色软件,主要有以下好处:
1、安装程序可以自动安装新版系统组件(如.NET4.0、Access2010、SQLCompact或SQLLocalDB)和第三方组件(如Java),而不用麻烦用户去搜索这些组件,也不用固守系统自带的组件(如.NET3.5或Jet4.0)。
2、普通用户往往会去桌面、任务栏、开始菜单找软件,或者直接双击文档来打开关联的软件,这时候就要创建快捷方式或注册关联。要求用户必须去找exe的话,确实不怎么友好。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
所属分类
上级专业
同级专业
acmilan
进士 学者 笔友
文章
461
回复
2934
学术分
4
2009/05/30注册,5年2个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}