.NET String [] 运算符返回与 ToString() 不同的内容

标签 .net

我有一个从 InstallShield 执行的 .NET 自定义操作 (DTF)。

在 .NET CA 中,我正在提取一个值为 “[CommonAppDataFolder]abc\def.txt” 的 MSI 属性。

该属性的访问方式如下:

string val = session["MY_PROPERTY"]; // Microsoft.Deployment.WindowsInstaller.Session

当我将此变量打印到日志文件时,我得到:C:\ProgramData\abc\def.txt。这正是我所期望的。

但是,当我使用 [] 运算符逐个字符查看时,我从未替换的值中获取字符: [CommonAppDataFolder]... 例如,val[0]'[' 而不是 'C' .

这怎么可能?

此外,==string.compare()!=等都没有给出预期的结果(我'想象一下它们在底层使用了 [] 运算符)。

编辑:

这就是我的记录方式: session.Log("文件名:{0}", val);

这就是我逐个字符打印的方式:

for (int i = 0; i < val.Length; i++) 
{ 
    session.Log(val[i].ToString());
}

最佳答案

字符串 val 仍然包含未替换的版本,因此 for 循环工作正常。
session 中的 Log() 方法使用“val”作为格式字符串(而不是文字),它在写入结果之前用实际值替换任何占位符。

如果您下载调试符号(输出可能不合法发布在此处),您可以看到这种情况发生。

简而言之,Log() 调用 Message(),而 Message() 又调用 MsiProcessMessage()在该 msdn 页面中,它引用 MsiFormatRecord() 。在该文件的末尾,它解释了自动发生的替换。对于本例来说,最值得注意的是:

  • If a substring of the form [propertyname] is encountered, it is replaced by the value of the property.
  • If a substring of the form [%environmentvariable] is found, the value of the environment variable is substituted.

尝试以下代码以获得预期结果

string formattedVal = session.Format(val)
for (int i = 0; i < formattedVal.Length; i++)  
{  
    session.Log(formattedVal[i].ToString()); 
} 

关于.NET String [] 运算符返回与 ToString() 不同的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12983129/

相关文章:

.net - 用于测试的静态日期时间

c# - 为什么我在这里得到 "Cannot access a closed Stream"?

c# - 数据绑定(bind) WPF 列表框?

c# - 如何读取 COM+ 服务器中的配置文件

c# - 禁用浏览器缓存 Azure 中运行的页面和 JavaScript

.net - 类内存堆/引用变量概念

.net - 在哪里可以找到 Visual Studio 2015 的 wsdl.exe?

.net - 查找GUI控件的所有者线程

.net - 如何使用 .NET 创建 JSON 数据?

.net - 在 .Net 中使用 PhantomJS selenium webdriver 时不执行 Element.Click