• C#中字符串的拼接符号
  • 发布于 2个月前
  • 237 热度
    0 评论
string是开发过程中,使用频度最高的类型之一,所以在构建类型时作了很多处理,如“不可变性”,“保留性”等特点。string的常量是在""引号中进行赋值的。
var str1 = "这是一段文字";
Console.WriteLine(str1);
之后,为了字符串的格式化,引入了$""定义方式,这样就可以在字符串中用{}来标注格式化的内容了。
var str2 = $"时间:{DateTime.Now}";
Console.WriteLine(str2);
//输出结果是:时间:1/6/2023 15:37:13

var str2_1 = $"时间:{DateTime.Now:yyyy-MM-dd}";
Console.WriteLine(str2_1);
//输出结果是:时间:2023-01-06
为了解决字符串内容的换行,引定入@"",来定义有换行的字符串,比如下面的一条SQL查询,可以按格式化后的样式来定义。$和@可以混用,不分先后。
var str3 = @"SELECT ID
,Question
,Score
,QuestionTypeID
,SubjectTypeID
FROM Questions";
Console.WriteLine(str3);

var str3_1 = @$"SELECT ID
,Question
,Score
,QuestionTypeID
,SubjectTypeID
FROM Questions WHERE Score>{10}";
Console.WriteLine(str3_1);
关于上面的写法,一个java的哥们还吐过槽,因为不整齐,字段应该和SELECT对齐,如果做过,只能手动补空格或tab了,但慈禧太后到DB上的也是有这些空格的,不完美。于是,C#11中安排了这个功能。用""" """来定义原始字符串,这样看上去就要清晰一些了。
var str4 = """
           SELECT ID
           ,Question
           ,Score
           ,QuestionTypeID
           ,SubjectTypeID
           FROM Questions
           """;
Console.WriteLine(str4);

var str4_1 = $"""
           SELECT ID
           ,Question
           ,Score
           ,QuestionTypeID
           ,SubjectTypeID
           FROM Questions
           WHERE Score>{10}
           """;
Console.WriteLine(str4_1);
其实原始字符串还解决了一个问题,就是字符串中有"的问题,以前需要有转义字符来实现,现在原始字符串都搞定了。
Console.WriteLine("\"a\" 是小写的");//通过\来转义
Console.WriteLine(@"""a"" 是小写的");//前缀是@时,通f这"转义
最佳demo是json字符串的定义,用原始字符串的方式定义json字符串,最合适不过了。
var jsonString = """
                 {
                     "firstName": "John",
                     "lastName": "Smith",
                     "sex": "male",
                     "age": 25,
                     "address": 
                     {
                         "streetAddress": "21 2nd Street",
                         "city": "New York",
                         "state": "NY",
                         "postalCode": "10021"
                     }                    
                 } 
                 """;
Console.WriteLine(jsonString)

用户评论