FormattableString
已在C#6.0中引入。由于我们可以使用string
对象使用相同的字符串格式,因此需要使用FormattableString
或IFormattable
。三者之间有什么区别?
我的代码
var name = "Pravin";
var s = $"Hello, {name}";
System.IFormattable s1 = $"Hello, {name}";
System.FormattableString s2 = $"Hello, {name}";
最重要的是产生相同的结果。即'Hello Pravin'.
如果有人对此有深入的了解,我能否得到更详细的答案。
答案 0 :(得分:46)
FormattableString
是.NET 4.6中的新类型,只有在尝试使用它时,编译器才会使用它。换句话说,插值字符串文字的类型通常为string
- 使用string.Format
构建 - 但如果您要求,则可以FormattableString
(通过FormattableStringFactory
)。< / p>
FormattableString
包含将传递给string.Format
的格式字符串(例如"Hello, {0}"
)以及为了格式化而传递的参数。至关重要的是,此信息是在格式化之前捕获的。
这允许您适当地调整格式 - 最常见的是在不变文化中执行它,通常使用Invariant
static method。
将插值字符串文字分配给IFormattable
变量时,也会使用FormattableString
。 IFormattable.ToString(string, CultureInfo)
implementation忽略了这种情况下的第一个参数,这可能是它使用显式接口实现的原因。
示例代码:
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
答案 1 :(得分:1)
顺便说一句,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}");
}