浅谈Dotnet的数据定位和匹配
Dotnet里,数据定位和匹配的相关编程现在变得很舒服。
最近项目紧,还要不停出差。
所以,写个短点的、最近经常用到的内容:数据定位和匹配。
数据定位
假设我们有这样一个数组:
var array = new int[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
我们取某个位置的值,以前的做法通常是:
int x = array[4];
int y = array[array.Length - 1];
现在,我们有了一个专门用于定位的结构System.Index
。注意,这是一个结构。
所以,取特定位置的数据,可以写成这样:
Index index = new Index(4, fromEnd: false);
int x = array[index];
或者直接合并成:
int x = array[new Index(4, false)];
看一下Index
的第二个参数fromEnd
,很明显,就是这个计数是从前往后还是从后往前计数的一个标志。所以,从尾计数,可以写成:
int y = array[new Index(1, true)];
这儿要稍注意一下,从后往前计数,索引值1是最后一个数据,索引值0指出去了,会报错。我们可以把这个数字想象成array.length-x
里的x
。
另外,在fromEnd
值为true
时,即从后往前计数时,Index
提供了一个简单的写法:
Index index = ^1;
额外的知识点:这个Index
可以用在很多需要定位的地方。看个例子:
string s = @"Hello WangPlus";
char a = s[new Index(4)];
char b = s[^2];
为了防止不提供原网址的转载,特在这里加上原文链接:https://www.cnblogs.com/tiger-wang/p/14512497.html
数据范围
有定位,就会有范围。
还是上面的例子:
var array = new int[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
通常,我们取一个范围的数据,会这么取:
var x = array.Skip(3).Take(2);
或者用个循环,我就不写了。
这儿,又有一个神奇的结构:System.Range
。
Range r = new Range(3, 5);
var xx = array[r];
结果跟上面array.Skip(3).Take(2)
是一样的。
这里,Range(Index start, Index end)
里,两个参数就是上一节的Index
。另外,开始索引是包含的,结束索引是不包含的。这儿需要注意一下。
这里又有一个简单的写法。Range(3,5)
可以简单写为3..5
。所以,代码可以简化为:
Range r = 3..5;
var xx = array[r];
省去定义,就变成:
var xx = array[3..5];
这个写法还可以延伸出:
var xx = array[3..]; //从第3个数据到最后
var xx = array[..5]; //从头到第4个数据(注意后面是不包含)
var xx = array[..]; //全部
var xx = array[0..^0]; //全部
同Index
一样,这个Range
也可以用在各种需要范围的地方,例如:
string s = @"Hello WangPlus";
string a = s[3..5];
数据匹配
还是拿例子来说。假设我们有下面的一个类定义:
class Employee
{
public int Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
使用中,我们生成了一个实例:
var employee = new Employee() { Id = 1, Name = "John Doe", Age = 0 };
然后,我们逻辑中需要一些条件判断,通常,我们可能这么写:
if(employee.Age == 0) {}
if(employee.Name != null) {}
现在,我们有了更具有可读性的写法。
简单比较
if(employee.Age is 0) {}
if(employee.Name is null) {}
if(employee.Name is not null) {}
类型检查并创建实例
if(employee is Employee emp)
{
emp.Age = 5;
}
属性比较
if (employee is { Age: 3 }) {}
if (employee is { Age: 30, Name: "aaa" }) {}
if (employee is { Age: > 25 }) {}
自己感觉,属性比较是写着最痛快的,终于不用一长串的&&
了。
这就是今天的内容了。有没有Get到爽点?
微信公众号:老王Plus 扫描二维码,关注个人公众号,可以第一时间得到最新的个人文章和内容推送 本文版权归作者所有,转载请保留此声明和原文链接 |
浅谈Dotnet的数据定位和匹配的更多相关文章
- 浅谈SQL Server数据内部表现形式
在上篇文章 浅谈SQL Server内部运行机制 中,与大家分享了SQL Server内部运行机制,通过上次的分享,相信大家已经能解决如下几个问题: 1.SQL Server 体系结构由哪几部分组成? ...
- 浅谈 sql 中数据的约束
数据约束 --对用户操作表的数据进行约束 1.默认值 --当用户对使用默认值的字段不插入值的时候,就使用默认值 1)对默认值字段插入null是可以的. 2)对默认值字段可以插入非null [例如:ad ...
- 浅谈WebService返回数据效率对比
原文链接 http://www.dotnetgeek.cn/xuexiwebservice1.html 一.什么是WebService: 简单通俗来说,就是企业之间.网站之间通过Internet来访问 ...
- 浅谈Android View的定位
引言 今天我们来介绍Android坐标系统和View的定位,当然也会介绍View的滑动相关话题.下面让我们开始介绍吧. View的基础知识 View是Android中所有控件的基类,无论是TextVi ...
- 浅谈CSS中的定位知识
1,静态定位(static) 表示按照正常定位方案,元素盒按照在文档流中出现的顺序依次格式化: 2,相对定位(relative) 将移动元素盒,但是它在文档流中的原始空间会保留下来: 相对定位元素有如 ...
- 浅谈Python小数据池
什么是小数据池 小数据池是python中提高效率的一种方式,固定数据类型的相同值使用同一内存地址. id 用于获取开辟空间的内存地址 代码块 一个文件,一个模块,一个函数,一个类,终端中的每一行代码都 ...
- Python Web 基础向(四) 浅谈数据层
数据层一般会给人带来一些困扰,在于其定位不准确.聚合Model的工作也可以放在逻辑层做,但会导致逻辑层变重,经常出现大段晦涩代码.因此我的建议是保留Model聚合层,尽管会导致工作量的略微增加,但却可 ...
- 浅谈程序员创业(要有一个自己的网站,最好的方式还是自己定位一个产品,用心把这个产品做好。或者满足不同需求的用户,要有特色)good
浅谈程序员创业 ——作者:邓学彬.Jiesoft 1.什么是创业? 关于“创业”二字有必要重新学习一下,找了两个相对权威定义: 创业就是创业者对自己拥有的资源或通过努力能够拥有的资源进行优化整合,从而 ...
- 浅谈Vue不同场景下组件间的数据交流
浅谈Vue不同场景下组件间的数据“交流” Vue的官方文档可以说是很详细了.在我看来,它和react等其他框架文档一样,讲述的方式的更多的是“方法论”,而不是“场景论”,这也就导致了:我们在阅读完 ...
随机推荐
- C# Dictionary(字典)源码解析&效率分析
通过查阅网上相关资料和查看微软源码,我对Dictionary有了更深的理解. Dictionary,翻译为中文是字典,通过查看源码发现,它真的内部结构真的和平时用的字典思想一样. 我们平时用的字典主要 ...
- 怎样优化SQL
[原则一:选择需要优化的SQL] 1,选择需要优化的SQL:不是所有的SQL都需要优化,在优化的过程中,首选更需要优化的SQL; 怎么选择?优先选择优化高并发低消耗的SQL: 1,1小时请求1W次,1 ...
- Jenkins+ant+Jmeter接口自动化框架搭建
工具准备 JDK: jdk1.8.0_111 Ant: apache-ant-1.9.9 Jmeter: apache-jmeter-3.1 Jenkins: jenkins-2.7.4 JDK安装 ...
- 如何安装Gephi工具
gephi中文版是一款开源免费跨平台基于JVM的复杂网络分析软件,安装后需要安装Java jdk API,否则就会出现gephi打不开的情况 该工具主要用于各种网络和复杂系统,动态和分层图的交互可视化 ...
- Redis 穿透 & 击穿 & 雪崩
原文:https://www.cnblogs.com/binghe001/p/13661381.html 缓存穿透 如果在请求数据时,在缓存层和数据库层都没有找到符合条件的数据,也就是说,在缓存层和数 ...
- 牛客网-Beautiful Land 【01背包 + 思维】
链接:https://www.nowcoder.com/acm/contest/119/F来源:牛客网 Now HUST got a big land whose capacity is C to p ...
- 考研最路径dijkstra和floyd
先来讲个段子:为什么 Dijkstra 不能提出 floyd 算法?因为他的名字是 ijk 而不是 kij. get不到点没有关系.我们今天的任务是看懂这个笑话. dijkstra 的效率是n^2.处 ...
- HDU 6706 huntian oy(杜教筛 + 一些定理)题解
题意: 已知\(f(n,a,b)=\sum_{i=1}^n\sum_{j=1}^igcd(i^a-j^a,i^b-j^b)[gcd(i,j)=1]\mod 1e9+7\),\(n\leq1e9\),且 ...
- SMB relay
SMB relay 0x00 SMB服务 先来了解一下什么是 SMB 服务,SMB(Server Message Block)是一个协议名称,用它可以共享计算机之间的文件.打印机.串口等,通过 SMB ...
- git alias all in one
git alias all in one workspace:工作区 staging area:暂存区/缓存区 local repository:或本地仓库 remote repository:远程仓 ...