- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试创建一个描述嵌套结构的 Fluent API,因此我想使用泛型来键入生成的对象。我想做类似的事情:
var test = new Query<Entity>().Select(x => x.UniqueValue<string>())
.Select(x => x.UniqueValue<DateTime>())
.Select(x => x.UniqueValue<decimal>());
测试的类型:
Result<Entity, string, Result<Entity, DateTime, Result<Entity, decimal>>>
到目前为止,我的代码如下:
class Program
{
static void Main(string[] args)
{
// test : ResultWithResult<Entity,string, Result<Entity, DateTime, ChildLessResult<Entity, decimal>>>
var test = new Query<Entity>().Select(x => x.UniqueValue<string>())
.Select(x => x.UniqueValue<DateTime>())
.Select(x => x.UniqueValue<decimal>());
}
}
public class Entity
{
public string Item1 { get; set; }
}
public class Aggregate<TEntity>
{
public ChildLessResult<TEntity, TReturnValue> UniqueValue<TReturnValue>()
{
return new ChildLessResult<TEntity, TReturnValue>();
}
}
public class Query<TEntity>
{
public ChildLessResult<TEntity, TReturnValue> Select<TReturnValue>(Func<Aggregate<TEntity>, ChildLessResult<TEntity, TReturnValue>> predicate)
{
var aggregator = new Aggregate<TEntity>();
return predicate(aggregator);
}
}
public class ChildLessResult<TEntity, TReturnValue>
{
public Result<TEntity, TReturnValue, TChild> Select<TChild>(Func<Aggregate<TEntity>, ChildLessResult<TEntity, TChild>> predicate)
{
return new Result<TEntity, TReturnValue, TChild>();
}
}
public class Result<TEntity, TReturnValue, TChild>
{
private ChildLessResult<TEntity, TChild> _child = new ChildLessResult<TEntity, TChild>();
public ResultWithResult<TEntity, TReturnValue, Result<TEntity, TChild, ChildLessResult<TEntity, TNewChild>>> Select<TNewChild>(Func<Aggregate<TEntity>, ChildLessResult<TEntity, TNewChild>> predicate)
{
return new ResultWithResult<TEntity, TReturnValue,
Result<TEntity, TChild, ChildLessResult<TEntity, TNewChild>>>();
}
}
public class ResultWithResult<TEntity, TReturnValue, TChild>
{
}
如您所见,这是非常有限的,因为它只允许您深入到您定义的结构,并且您需要为每个更深的级别创建一个新结构。是否可以创建允许无限数量级别的类型(即,在没有相同相应数量类型的情况下,您可以根据需要选择任意数量的选择)。
最佳答案
是的,有点……可以或多或少地自动创建一些很长很深的嵌套类型。诀窍是你需要使用泛型类型推断,因为 constructors don't do inference ,你必须使用工厂方法。例如:
public class MyType<TData,TChild>
{
public MyType(TData data, TChild child)
{
}
}
public class MyTypeFactory
{
public static MyType<TData,TChild> Create<TData,TChild>(TData data, TChild child)
{
return new MyType<TData,TChild>(data, child);
}
public static MyType<TData,object> Create<TData>(TData data)
{
return new MyType<TData,object>(data, null);
}
}
public static class Program
{
static public void Main()
{
var grandchild = MyTypeFactory.Create( 12 );
var child = MyTypeFactory.Create( 13D, grandchild );
var parent = MyTypeFactory.Create( 14M, child) ;
var grandparent = MyTypeFactory.Create( 15F, parent );
Console.WriteLine( grandchild.GetType().FullName );
Console.WriteLine( child.GetType().FullName );
Console.WriteLine( parent.GetType().FullName );
Console.WriteLine( grandparent.GetType().FullName );
}
}
输出:
MyType'2[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[System.Object, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]]
MyType'2[[System.Double, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[System.Object, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]]
MyType'2[[System.Decimal, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Double, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[System.Object, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]]
MyType'2[[System.Single, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Decimal, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Double, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[MyType'2[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[System.Object, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]], uy2zelya, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]]
它甚至是类型安全的,这已经足够令人惊讶了。如果您添加必要的属性...
public class MyType<TData,TChild>
{
protected readonly TChild _child;
protected readonly TData _data;
public MyType(TData data, TChild child)
{
_data = data;
_child = child;
}
public TChild Child
{
get
{
return _child;
}
}
public TData Data
{
get
{
return _data;
}
}
}
...这会起作用:
var grandchildValue = grandparent.Child.Child.Child.Data;
Console.WriteLine(grandchildValue); //12
Console.WriteLine(grandchildValue.GetType().Name); //int32
当然你可以使用构建器模式:
public static class ExtensionMethods
{
static public MyType<TDataAdd,MyType<TDataIn,TResultIn>> AddColumn<TDataIn,TResultIn,TDataAdd>(this MyType<TDataIn,TResultIn> This, TDataAdd columnValue)
{
return MyTypeFactory.Create(columnValue, This);
}
}
var grandparent = MyTypeFactory.Create( 12 )
.AddColumn( 13D )
.AddColumn( 14M )
.AddColumn( 15F );
var grandchildValue = grandparent.Child.Child.Child.Data;
Console.WriteLine(grandchildValue); //12
Console.WriteLine(grandchildValue.GetType().FullName); //System.Int32
附言这是一个很好的例子,说明了为什么我们需要 var
关键字!否则你将永远打字。
关于c# - 是否可以创建可以在 C# 中多次嵌套泛型类型的流畅接口(interface),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49764089/
我想在单击按钮时进行移动:向左。这是针对移动运动的... 问题在于它的移动,但只有一次。我需要点击按钮发送垃圾邮件... 代码: 在创建中: this.buttonleft.inputEnabled
前言 今天大姚给大家分享一个.NET开源(MIT License)、免费、现代化、流畅、可测试、可移植的URL构建器和HTTP客户端库:Flurl。 项目介绍 Flurl是一个集现代性、流畅性、
我不确定其他与我的问题明显相似的问题是否归结为同一主题。 请考虑这段代码(为更清楚起见,为 head 部分提取了 CSS 代码): body { margin: 0;
我是一名学习 html/css 的学生,我在创建第一个网站时遇到了问题。我在配置页面时遇到了很多困难,因此它是流动的而不是固定的。我配置了一个框、图像和一些文本,因此它们在页面上是绝对的,但我无法使页
在我的游戏中,我已将角色设置为移动。它的设置方式是: if game_over_state == False: if event.type == pygame.KEYDOWN:
我一直在研究代码,但似乎无法让它工作。我用谷歌搜索,在这个网站上搜索了 13 页,但仍然找不到我要找的答案。 我希望视频以特定尺寸开始,然后随着我调整浏览器大小(从桌面到 iPad/iPhone)而缩
我已经从 sql server 2005 切换到 mysql,这并不是一个真正的问题。 我对 sql server 中存在的 (n)varchar 有一个小问题。通常我用过: mapping.Map(
我必须使用自定义 odbc 驱动程序。 我需要作为连接字符串传递的只是 DSN。 我如何使用(流畅)nhibernate 做到这一点? FluentNHibernate.Cfg.Db 仅提供带有 DS
我无法找到我们网站上动态显示的弹出窗口。最初该元素处于以下 html 状态: 使用jquery的show和hide,div显示5秒,稍后隐藏。 在我的 Selenium 脚本中,我尝试使用以下语句等
我有一个 two/three基于屏幕尺寸的列布局。 如果窗口大小大于 1000比我需要遵循 3 column其他布局我需要遵循 two column布局。 我是用JS实现的,但是代码很乱。现在我想用
我有一个 Flutter 应用程序,随着时间的推移和添加的功能越来越多,它变得越来越笨拙。因此,是否有一些实用程序可以使其像 60FPS 一样流畅? 我知道这里有一些官方指南:https://docs
我在如何实现 $(window).smartresize() 上纠结了几个小时使我的 div 流畅的功能。 我使用了这个 theme 中的 javascript但是当我尝试自己实现它时,我的 div
当我尝试通过 canvas.getContext('2d') 和 canvas.getContext('webgl') 将相同的 PNG 文件加载到 Canvas 中时,发现与canvas2d相比,w
我有一个所有实体的基类: public class BaseClass { public int SomeProperty {get; set;} } public class SomeEnt
我正在从事一个对时间相当敏感的元素。任务是制作一个微型网站,用户可以通过他们的智能手机访问该网站,在那里他们可以访问许多电影。他们会扫描二维码(我知道他们已经死了,我没有计划这次事件)。并登陆这个网站
我们正在使用Entity Framework 5.0。和数据库MySQL。当我们尝试迁移时间时出现异常。 could not be created because the principal key
快速问题:如何将传递给shiny.fluent::Text函数的文本设置为粗体?更广泛地说,如何将样式选项传递给此函数?。在函数的帮助页面中,它是这样写的。但我不明白如何使用这个变量参数。。我试着在不
我是一名优秀的程序员,十分优秀!