小编And*_*ndy的帖子

从通用基接口的实例中检索类型参数

给出2个接口:

public interface BaseInterface<T> { }
public interface ExtendedInterface<T0, T1> extends BaseInterface<T0> {}
Run Code Online (Sandbox Code Playgroud)

和一个具体的类:

public class MyClass implements ExtendedInterface<String, Object> { }
Run Code Online (Sandbox Code Playgroud)

如何找到传递给BaseInterface接口的类型参数?

(我可以通过调用类似的东西来检索ExtendedInterface类型参数

MyClass.class.getGenericInterfaces()[0].getActualTypeArguments()
Run Code Online (Sandbox Code Playgroud)

但我无法找到一种简单的方法来递归到任何基础通用接口并得到任何有意义的东西).

java generics reflection

20
推荐指数
2
解决办法
2万
查看次数

如何使用嵌入式jetty在给定地址处提供特定的类路径资源?

我正在寻找从嵌入式jetty服务器公开clientacesspolicy.xml文件.

我目前的尝试看起来像这样:

ContextHandler capHandler = new ContextHandler();
capHandler.setContextPath("/clientaccesspolicy.xml");
capHandler.setBaseResource(Resource.newClassPathResource("clientaccesspolicy.xml"));
HandlerList handlers = new HandlerList();
handlers.addHandler(capHandler);
...
httpServer.setHandler(handlers);
Run Code Online (Sandbox Code Playgroud)

但我得到404访问http:// localhost:9000/clientaccesspolicy.xml

如何在Jetty中以编程方式将类路径资源公开给给定的URL?

谢谢,安迪

java jetty embedded-jetty

13
推荐指数
2
解决办法
6749
查看次数

StructureMap中的循环依赖 - 它们可以通过属性注入来打破吗?

我在结构图中有最简单的循环依赖 - 类A在其构造函数中依赖于类B,而类B在其构造函数中依赖于类A. 为了打破依赖,我让B类把A类作为属性,而不是构造函数参数,但是structmap仍然抱怨.

我已经看到在其他DI框架中使用此方法破坏了循环依赖 - 这是Structuremap的问题还是我做错了什么?

编辑: 我应该提到类B的属性是一个A类实例的数组,这样连线:

x.For<IB>().Singleton().Use<B>().Setter(y => y.ArrayOfA).IsTheDefault();
Run Code Online (Sandbox Code Playgroud)

为了澄清,我希望发生以下事件序列:

  • 构造B的实例,"b"
  • 构造一个A的实例,"a",在其构造函数中注入"b"
  • 将"b.ArrayOfA"设置为["a"]

我希望所有这一切都发生在使用自动装配,如果可能的话......

编辑2:这是一个使用显式连线的简化示例:

interface ILoader { }
interface ILoaderManager { }

class Loader : ILoader
{
    public Loader(ILoaderManager lm) { }
}
class LoaderManager : ILoaderManager
{
    public ILoader Loader { get; set; } // Was an array, but same circular dependency appears here
}

ObjectFactory.Configure
(
    x =>
    {
        x.For<ILoader>.Singleton().Use<Loader>();
        x.For<ILoaderManager>().Singleton().Use<LoaderManager>().OnCreation((c, a) => a.Loader = c.GetInstance<ILoader>());
    }
);
Run Code Online (Sandbox Code Playgroud)

验证配置会导致"使用RequestedType检测到双向依赖性问题:IocTest2.ILoader ..."

c# structuremap dependency-injection circular-dependency

9
推荐指数
2
解决办法
9659
查看次数

如何将包发布到TeamCity nuget服务器?

我们为nuget配置了TeamCity 7服务器.它托管在没有外部连接的机器上.是否可以将包发布到TeamCity nuget服务器?例如,如果我们想要将log4net包依赖项添加到我们的某个项目中,则需要将其发布到TeamCity服务器,因为nuget.org无法访问.到目前为止,我已尝试在http:// teamcity:port/guestauth/app/nuget/v1/FeedService.svc上发布变体,但到目前为止还没有运气.

谢谢,安迪

teamcity nuget teamcity-7.0

9
推荐指数
1
解决办法
1万
查看次数

取消对信号的 kotlin 流收集

我正在努力为 Flow 创建一个“takeUntilSignal”运算符 - 一种扩展方法,当另一个流生成输出时将取消一个流。

fun <T> Flow<T>.takeUntilSignal(signal: Flow<Unit>): Flow<T>
Run Code Online (Sandbox Code Playgroud)

我最初的努力是尝试在与主要流收集相同的协程范围内启动信号流的收集,并取消协程范围:

fun <T> Flow<T>.takeUntilSignal(signal: Flow<Unit>): Flow<T> = flow {
    kotlinx.coroutines.withContext(coroutineContext) {
        launch {
            signal.take(1).collect()
            println("signalled")
            cancel()
        }
        collect {
            emit(it)
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

但这不起作用(并使用禁止的“withContext”方法,该方法被 Flow 明确剔除以防止使用)。

编辑 我把以下可憎的东西混在一起,这不太符合定义(结果流只会在从主流第一次发射后取消),我觉得有一个更好的方法:

fun <T> Flow<T>.takeUntilSignal(signal: Flow<Unit>): Flow<T> =
    combine(
        signal.map { it as Any? }.onStart { emit(null) }
    ) { x, y -> x to y }
        .takeWhile { it.second == null }
        .map { it.first }
Run Code Online (Sandbox Code Playgroud)

edit2 再次尝试,使用 channelFlow:

fun <T> Flow<T>.takeUntilSignal(signal: Flow<Unit>): …
Run Code Online (Sandbox Code Playgroud)

kotlin kotlin-coroutines

9
推荐指数
1
解决办法
8124
查看次数

在Oracle中保持表同步

我们即将进行并排测试,以将遗留系统与新的闪亮版本进行比较.我们有一个Oracle数据库表A,用于存储遗留系统的数据,以及一个等效表B,用于存储新系统的数据,因此在测试期间,数据库是非规范化的.(此外,遗留系统和表A是固定的 - 不允许更改)

我想要做的是允许A上不频繁的DML操作传播到B,反之亦然.我开始使用一对触发器来执行此操作,但遇到了一个明显的问题,即当触发器运行时,表正在发生变化,并抛出异常.

有没有一种标准的方法来处理这个问题?我已经阅读了关于是否使用dbms_scheduler的不同报告......

谢谢,

安迪

更新: 我最终摆脱了整个问题并确保更新A的所有存储过程也更新B,反之亦然.

我已经将Quassnoi的答案标记为已被接受,因为如果将来遇到同样的问题我会遵循他的建议.

我已经标记了JosephStyon的答案,因为我简单地通过在表A和B上添加两个插入/更新语句级别触发器来完成工作,然后使用A或B作为主表执行其合并过程,具体取决于运行的触发器(尽管首先,我检查了目标表是否会被合并更改,如果没有,则会收到.

sql oracle synchronization triggers denormalization

6
推荐指数
1
解决办法
1万
查看次数

在java中创建包级关联数组

是否可以创建包级别oracle关联数组的java表示.例如,给出以下内容:

CREATE OR REPLACE PACKAGE MyPackage AS
    TYPE t_numbers IS TABLE OF NUMBER INDEX BY PLS_INTEGER;
Run Code Online (Sandbox Code Playgroud)

我发现我不能写下面的java:

ArrayDescriptor descriptor =
    ArrayDescriptor.createDescriptor("MyPackage.t_numbers", connection);
Run Code Online (Sandbox Code Playgroud)

(抛出SQLException"无效的名称模式").

ArrayDescriptor引用包级关联数组的正确语法是什么?这样的事情甚至存在吗?

java oracle associative-array jdbc

4
推荐指数
1
解决办法
2835
查看次数

EventHandler应该始终用于事件吗?

我一直在使用自定义委托类型和通用Action委托类型快乐地编写事件,而没有真正考虑我在做什么.

我有一些很好的扩展助手Action,EventHandler这使我倾向于使用那些预定义的委托类型而不是我自己的,但除此之外......

除了约定之外,是否有一个很好的理由支持EventHandlerEventHandler<T>优先于自定义委托类型或通用Action委托类型?

c# events conventions

4
推荐指数
1
解决办法
371
查看次数

在teamcity服务器上安装nuget

我们有一个TeamCity 7服务器,我们想为nuget启用它.

我们没有任何外部网络连接,因此当被要求下载nuget时,TeamCity说

"无法从默认Feed中获取最新的NuGet.连接到http://packages.nuget.org拒绝"

是否有一种解决方法可以从独立的exe或其他东西安装nuget,以便TeamCity识别安装?

提前谢谢,安迪

teamcity nuget teamcity-7.0

4
推荐指数
1
解决办法
2981
查看次数

JAXB 中的自定义序列化

有没有办法在 JAXB 中自定义 XML 序列化,就像在 .NET 中使用 IXmlSerializable 一样?(即使用等效的 XmlReader/Writer 直接控制对象序列化的能力)。

我查看了 XmlAdapter 和 @XmlJavaTypeAdapter,但它们似乎只是用于在类型与可序列化形式之间进行转换,这并不是我想要的。

更新:特别是,我想自定义根对象的反序列化,以编程方式确定如何反序列化内部 XML(例如,使用一组特定的已知类型创建一个 jaxb unmarshaller)。

更新:我找到了解决问题的方法,但这是一个令人讨厌的黑客攻击,我可能会采用其他海报建议的解决方案之一。

java xml jaxb xml-serialization

1
推荐指数
1
解决办法
1万
查看次数

通过命令绑定打开上下文菜单

我正试图绑定一个按钮,在左键单击打开其上下文菜单.我知道如何以编程方式执行此操作,但有没有办法使用默认命令绑定执行此操作?

我现在有:

    <Button Command="ApplicationCommands.ContextMenu">
        <Button.ContextMenu>
            <ContextMenu>
                <MenuItem ...
Run Code Online (Sandbox Code Playgroud)

但没有这样的运气...如果我这样做,那么按钮被禁用.我想这表明该命令无法执行,但为什么呢?

wpf binding command

1
推荐指数
1
解决办法
1676
查看次数

合并Kotlin流

给定2个或多个相同类型的流,是否存在现有的Kotlin协程函数来合并它们,例如RX合并运算符?

目前我正在考虑:

fun <T> merge(vararg flows: Flow<T>): Flow<T> = channelFlow {
    val flowJobs = flows.map { flow ->
        GlobalScope.launch { flow.collect { send(it) } }
    }
    flowJobs.joinAll()
}
Run Code Online (Sandbox Code Playgroud)

但看起来有些笨拙。

kotlin kotlin-coroutines

0
推荐指数
2
解决办法
351
查看次数