前言

在我们的程序中,经常使用到字符串,字符串的写法非常多,但是有一个问题就是我们写的字符串是否合适呢?

正文

内插符

介绍一个东西叫做内插字符,如下:

static void Main(string[] args)
{
string w = "Word";
string s = $"Hello {w}";
}

也就是说在字符串前面加上$,然后我们就可以在字符串中加入{}来实现表达式插入其他字符。

这让我们想起了string.format。

string ss = string.Format("Hello {0}",w);

只不过我们写在后面。

内插字符是我们方便了很多,我们可以在我们想加入的位置直接插入字符。

有一个问题,请看:

string pi1= $"pi is {Math.PI}";
string pi2 = $"pi is {Math.PI.ToString()}";

这上下两条语句是否相同?

第一条一句通过装箱拆箱操作。

而第二条,请看:

public override string ToString() =>
Number.FormatDouble(this, null, NumberFormatInfo.CurrentInfo);

而是通过优化来实现。

所以呢,下面那条性能更好。

前面提及内插符可以简化我们的操作,那么是否能接受一些复杂的操作,如内插符语句内内插内插符。

同样是可以的:string s =$"{$""}",只要符合表达式要求即可。

nameof

private string name;

private Dictionary<string, string> data;

public string StudentName
{
get { return data.GetValueOrDefault(nameof(name)); }
set { SetData(nameof(name),value); }
} private void SetData(string key,string value) {
data[key] = value;
}

如下面需要卸载Dictionary,如果直接写入name字符串的话,那么会出现一个问题,就是万一哪天我们属性名改了之后呢,可能我们会忘记去改。

这样子是否我们的nameof会影响我们的性能呢?答案是否定的,因为其运作在编译期。

public string StudentName
{
get =>
CollectionExtensions.GetValueOrDefault<string, string>((IReadOnlyDictionary<string, string>) this.data, "name");
set
{
this.SetData("name", value);
}
}

nameof 在try catch 中使用的比较多。

public int calc(int x,int y)
{
try
{
return x / y;
} catch(Exception e)
{
throw new Exception($"{nameof(y)+":"+y.ToString()}");
}
}

总结一个nameof:

nameof的好处是,如果符号名字改了之后,使用nameof来获取符号名称的地方或获得修改后的名字,使我们的静态检查功能得到了充分的发挥。

注意:

public class A1<T>
{
public static string getname() {
return nameof(A1<T>);
}
}

这里getname返回的是A1,而不会动态打印泛型是啥,因为其在编译期。

总之nameof这种既不影响性能同时还能给我们提供静态检查的,我个人认为是值得使用的。

c# 优化代码的一些规则——字符串使用优化[四]的更多相关文章

  1. c# 优化代码的一些规则——const 和 readonly[二]

    前言 在c# 的世界中,在初学的时候,可能很难区分readonly 和 const,两者都是不可修改. 看到这两个单词,我们想的是,最多他们的区别也不会太大.然后事实却出乎我们的意料. 正文 这两个声 ...

  2. c# 优化代码的一些规则——优先隐式类型[一]

    前言 说到底就是优先使用var,这个关键字,在c# 3.0中出现了. 首先要确认几点,一个就是var 是静态变量,而不是动态变量,也就是说使用var 你是不必去担心性能问题得, 百度百科: 1)静态存 ...

  3. c# 优化代码的一些规则——使用is或as和强制类型转换的区别[三]

    前言 使用as和强制类型转换的时候的区别是否仅仅是代码形式上的区别. 答案是肯定不是的. 正文 看两段代码: object o = Factory.GetObject(); Student stude ...

  4. PL/SQL 美化器&规则解释&优化代码

    前言 PLSQL有非常强大的自定义设置功能,比如美化文件规则, 使用者可以自行定义编辑规则,以便更好的优化SQL语句,增加可读性. 例如以下的部分代码,又长,分段不好,空格太多,结构散乱,还没有注释. ...

  5. 前端页面卡顿?或是DOM操作惹的祸,需优化代码

    文档对象模型(DOM)是一个独立 于特定语言的应用程序接口.在浏览器中,DOM接口是以JavaScript语言实现的,通过JavaScript来操作浏览器页面中的元素,这使得 DOM成为了JavaSc ...

  6. Web前端开发最佳实践(13):前端页面卡顿?可能是DOM操作惹的祸,你需要优化代码

    文档对象模型(DOM)是一个独立于特定语言的应用程序接口.在浏览器中,DOM接口是以JavaScript语言实现的,通过JavaScript来操作浏览器页面中的元素,这使得DOM成为了JavaScri ...

  7. [好文翻译]WEB前端性能优化的14条规则

    作为一个半前端工程师,而且只会写点HTML5和CSS3的“假”前端工程师,为了能更好地理解一下前端的花花世界,最近拜读了<高性能网站建设指南>一书,对作者提出的前端性能优化的14个规则获益 ...

  8. Yahoo网站性能优化的34条规则

    摘自:http://blog.chinaunix.net/uid/20714478/cid-74195-list-1.html Yahoo网站性能优化的34条规则 1.尽量减少HTTP请求次数 终端用 ...

  9. Yahoo关于性能优化的N条规则

    本来这是个老生常谈的问题,上周自成又分享了一些性能优化的建议,我这里再做一个全面的Tips整理,谨作为查阅型的文档,不妥之处,还请指正: 一. Yahoo的规则条例: 谨记:80%-90%的终端响应时 ...

随机推荐

  1. 数据库SQL语言从入门到精通--Part 1--SQL语言概述

    数据库从入门到精通合集(超详细,学习数据库必看) 一.SQL概述 关系数据库标准语言SQL(结构化查询语言). 结构化查询语言(Structured Query Language)简称SQL,是一种特 ...

  2. 图论--2-SAT--POJ Ikki's Story IV - Panda's Trick

    Description liympanda, one of Ikki's friend, likes playing games with Ikki. Today after minesweeping ...

  3. F. Cards and Joy

    F. Cards and Joy 题目大意: 给你n个人,每一个人恰好选k张牌. 第一行是 n 和 k 第二行有n*k个数,代表有n*k张牌,每张牌上的数字 第三行有n个数,代表第i个人喜欢的数字 第 ...

  4. Spring Cloud学习 之 Spring Cloud Hystrix(基础知识铺垫)

    Spring Boot版本:2.1.4.RELEASE Spring Cloud版本:Greenwich.SR1 文章目录 前述: 快速入门: 命令模式: RxJava: 前述: ​ 在微服务架构中, ...

  5. Coursera课程笔记----C程序设计进阶----Week 5

    指针(二) (Week 5) 字符串与指针 指向数组的指针 int a[10]; int *p; p = a; 指向字符串的指针 指向字符串的指针变量 char a[10]; char *p; p = ...

  6. Docker知识点整理

    目录 1. Docker简介 1.1 Docker是什么 1.2 在隔离的容器中运行软件 1.3 分发容器 2. Docker镜像 2.1 Docker镜像简介 2.2 Docker镜像常见操作 2. ...

  7. Android如何设置只有边框背景透明的背景呢?

    很简单,只需要新建一个 drawable 文件 <?xml version="1.0" encoding="utf-8"?> <shape x ...

  8. 安装laravel环境之homestead(for mac)

    1.先下载virtualbox + vagrant 2.执行命令 vagrant box add laravel/homestead 3.新建一个空文件夹,在里面下载代码.我是放在当前用户下的新建的W ...

  9. JS防抖和节流:原来如此简单

    一.函数防抖 前端开发工作中,我们经常在一个事件发生后执行某个操作,比如鼠标移动时打印一些东西: window.addEventListener("mousemove", ()=& ...

  10. python--正则表达式中(.)(*)(.*?)以及re.S的认识

    https://yiyibooks.cn/xx/python_352/library/re.html 看command: #-*-coding:gb2312-*- __author__ = 'fuda ...