.NET record 使用探讨

.net 里面的record我之前也很少用,最近net6也出来了,看到了一些新特性的内容,其中record引起了我的注意,因为很少使用它,对它比较陌生,看了网上关于它一些知识后,了解到它兼顾了class和struct双重优点,让我很是惊喜。

在编写代码过程中,经常需要创建临时对象,这些对象属性字段不会很多主要作用也只是为了进行逻辑判断的过渡,之前我的做法是创建内部class或者使用Tuple对象,但写内部class代码不够简洁,用Tuple吧代码可读性又很差,现在使用record的话既能让代码更加简洁还能保持代码的可读性。定义record示例。

record Person(string Id,string Name);

当然作用还有具有数据清洗的功能,因为record包含了struct基于值相等性的比较优点,对于Equals,==,!=等操作,能方便分辨出两对象是否相等,结合System.Linq语法对于几何中点集坐标去重或者人员信息去重等能方便的获取清洗后的结果。代码如下。

var p1 = new Person("1","王五");
var p2 = new Person("1", "王五");
var p3 = new Person("3", "张三");
var p4 = new Person("4", "李四");
var isEqual = p1.Equals(p2);
Console.WriteLine($"[{isEqual}]");
Person[] peoples = (new Person[] {p1,p2,p3,p4 }).Distinct().ToArray();
Console.WriteLine($"[{string.Join(";", peoples.Select(s => $"[{s.Id},{s.Name}]"))}]");

运行结果如下

大家如果有更好的使用场景,欢迎留言交流学习。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Apache Kafka 中,SourceRecord 是一个用于表示单个消息的类。它包含了来自 Kafka 源头的消息的所有元数据,包括 topic、partition、offset、key 和 value 等信息。下面是一个使用 SourceRecord 的示例: ```java import org.apache.kafka.connect.source.SourceRecord; import org.apache.kafka.connect.data.Schema; import org.apache.kafka.connect.data.Struct; import org.apache.kafka.connect.data.Field; import java.util.HashMap; import java.util.Map; import org.apache.kafka.connect.source.SourceTaskContext; public class MySourceTask extends SourceTask { private SourceTaskContext context; public void start(Map<String, String> props) { context = this.context; } public void stop() { // Perform any necessary cleanup operations here } public void poll() throws InterruptedException { // Poll for new records from the source system // Construct a new SourceRecord for each record String myTopic = "my-topic"; int myPartition = 0; long myOffset = 12345L; String myKey = "my-key"; String myValue = "my-value"; Schema valueSchema = Schema.STRING_SCHEMA; Struct value = new Struct(valueSchema); value.put("field1", "value1"); value.put("field2", "value2"); Map<String, String> sourcePartition = new HashMap<>(); sourcePartition.put("partition", String.valueOf(myPartition)); Map<String, Object> sourceOffset = new HashMap<>(); sourceOffset.put("offset", myOffset); SourceRecord record = new SourceRecord(sourcePartition, sourceOffset, myTopic, myPartition, Schema.STRING_SCHEMA, myKey, valueSchema, value); context.sourceTask().commit(); } public String version() { return "1.0"; } } ``` 在这个示例中,我们创建了一个名为 `MySourceTask` 的子类,它实现了 `SourceTask` 接口。在 `poll()` 方法中,我们模拟从源系统中拉取了一条新的记录,并为其构建一个新的 `SourceRecord` 对象。然后,我们使用 `context.sourceTask().commit()` 方法将偏移量提交给 Kafka Connect 进行跟踪和管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值