String、FormattableString、IFormattable 之间的区别

本文关键字:区别 之间 IFormattable FormattableString String | 更新日期: 2023-09-27 18:34:56

FormattableString已在

C# 6.0 中引入。由于我们可以使用相同的字符串格式string对象为什么需要使用FormattableStringIFormattable。三者之间有什么区别?

我的代码

        var name = "Pravin";
        var s = $"Hello, {name}";
        System.IFormattable s1 = $"Hello, {name}";
        System.FormattableString s2 = $"Hello, {name}";

最重要的是,产生相同的结果,即'Hello Pravin'.

如果有人对此有深入的了解,我可以得到更详细的答案吗?

String、FormattableString、IFormattable 之间的区别

FormattableString

.NET 4.6 中的一种新类型,编译器只有在您尝试使用它时才会使用它。换句话说,内插字符串文字的类型通常是string的 - 用string.Format构建 - 但如果你要求它,可以FormattableString(通过FormattableStringFactory(。

FormattableString由将传递给string.Format的格式字符串组成(例如 "Hello, {0}" ( 以及为了格式化它而传递的参数。至关重要的是,此信息是在格式化之前捕获的。

这允许您适当地调整格式 - 最常见的是在固定区域性中执行它,通常使用 Invariant 静态方法。

将内插字符串文本分配给IFormattable变量时,也会使用 FormattableString。在这种情况下,IFormattable.ToString(string, CultureInfo) 实现忽略第一个参数,这大概是它使用显式接口实现的原因。

示例代码:

using System;
using System.Globalization;
using System.Threading;
using static System.FormattableString;
class Test
{
    static void Main()
    {
        var uk = CultureInfo.CreateSpecificCulture("en-GB");
        Thread.CurrentThread.CurrentCulture = uk;
        var germany = CultureInfo.CreateSpecificCulture("de-DE");
        string now = $"Default: it is now {DateTime.UtcNow}";
        Console.WriteLine(now); // UK format
        IFormattable x = $"Specific: It is now {DateTime.UtcNow}";
        Console.WriteLine(x.ToString("ignored", germany));
        FormattableString y = $"FormattableString: It is now {DateTime.UtcNow}";
        Console.WriteLine(FormattableString.Invariant(y));
        // Via using static
        Console.WriteLine(Invariant($"It is now {DateTime.UtcNow}")); 
    }
}

示例结果:

Default: it is now 16/02/2016 07:16:21
Specific: It is now 16.02.2016 07:16:21
FormattableString: It is now 02/16/2016 07:16:21
It is now 02/16/2016 07:16:21
顺便说一句

,https://www.meziantou.net/interpolated-strings-advanced-usages.htm 涵盖了 FormattableString 允许您执行的操作的一些示例(例如自动参数化 SQL 语句(

例如

void ExecuteNonQuery(DbConnection connection, FormattableString formattableString)
{
    using (var command = connection.CreateCommand())
    {
        // Replace values by @p0, @p1, @p2, ....
        var args = Enumerable.Range(0, formattableString.ArgumentCount).Select(i => (object)("@p" + i)).ToArray();
        command.CommandType = System.Data.CommandType.Text;
        command.CommandText = string.Format(formattableString.Format, args);
        // Create parameters
        for (var i = 0; i < formattableString.ArgumentCount; i++)
        {
            var arg = formattableString.GetArgument(i);
            var p = command.CreateParameter();
            p.ParameterName = "@p" + i;
            p.Value = arg;
            command.Parameters.Add(p);
        }
        // Execute the command
        command.ExecuteNonQuery();
    }
}
using (var sqlConnection = new SqlConnection())
{
    sqlConnection.Open();
    ExecuteNonQuery(sqlConnection, $@"UPDATE Customers SET Name = {"Meziantou"} WHERE Id = {1}");
}