草庐IT

privates

全部标签

java - 如何测试只修改私有(private)类成员变量的void方法?

我正在尝试对初始化一些私有(private)字段的类中的方法进行单元测试:publicvoidinit(Propertiesprops)throwsException{this.language=props.getProperty(Constants.LANGUAGE,Constants.LANGUAGE_DEFAULT);this.country=props.getProperty(Constants.COUNTRY,Constants.COUNTRY_DEFAULT);try{this.credits=Integer.valueOf(props.getProperty(Consta

Java OOP 公共(public)、私有(private)、 protected

我了解public、private和protected的作用。我知道您应该使用它们来遵守面向对象编程的概念,并且我知道如何在使用多个类的程序中实现它们。我的问题是:我们为什么要这样做?为什么我不应该让一个类直接修改另一个类的全局变量?即使您不应该,为什么还需要protected、private和public修饰符?就好像程序员不相信自己不会这样做,即使他们是编写程序的人。提前致谢。 最佳答案 你是对的,这是因为我们不能相信自己。可变状态是计算机程序复杂性的一个主要因素,构建一开始看起来不错的东西太容易了,但随着系统变大,它会失去控制

java - 我们可以重写 Java 中的构造函数吗?构造函数可以是私有(private)的吗?

我将不胜感激对这些问题的解释:我们能否在Java中覆盖构造函数?Constructor可以是私有(private)的吗? 最佳答案 不,您不能覆盖构造函数。它们不是遗传的。但是,每个子类构造函数都必须将或者链接到子类中的另一个构造函数或到父类(superclass)中的构造函数。例如:publicclassSuperclass{publicSuperclass(intx){}publicSuperclass(Stringy){}}publicclassSubclassextendsSuperclass{publicSubclass(

java - 通过 Dijkstra 算法中私有(private)方法的 JUnit 测试用例

我正在尝试找出为类练习实现测试用例的最佳方法。我的类练习提供了已知的错误,因此我应该编写一个测试用例使其失败,从而找到错误。它涉及使用Dijkstra算法。这是所提供代码的正确版本:privateintgetNodeWithMinimumDistanceFromUnsettled(){intmin;intnode=0;Iteratoriterator=unsettled.iterator();node=iterator.next();min=distances[node];for(inti=1;i单独版本已知bug如下:if(unsettled.contains(i)){if(dist

java - 启动和运行私有(private) Maven 存储库的最快方法是什么?

我正在与一些开发人员合作,我们希望在我们完成项目代码的早期迭代时分享一些jar。我们只想pop一个快速的私有(private)maven存储库服务器以供短暂使用。在ruby​​中,它就像键入一样简单:gemserver好像没有?mvnserver即使是对github的简单maven依赖也可以暂时使用。显然,也没有主流可靠的maven插件吗?gem'nokogiri',:git=>'https://github.com/tenderlove/nokogiri.git',:branch=>'1.4'我找到的最简单的答案在这里:HostingaMavenrepositoryongithub.

java - 使用包私有(private)方法以促进单元测试是一种好习惯吗?

有时我发现自己处于这样的情况下,如果我将某些方法的可见性从私有(private)更改为包私有(private),以便促进单元测试模拟、断言...,单元测试会更容易。一个例子就是这个假设我有一个包含4个属性X、Y、Z和R的对象A,其中X、Y和Z是集合,R是每个集合的不同元素之间的关系,例如关系将由元素组成X,Y的一个元素和Z的一个元素。对象A不允许直接访问X、Y、Z或R,相反它提供了丰富的API,允许您在X、Y和Z上创建新元素,也允许您将这些元素混合到新的R元素中。对于单元测试,拥有publicgetX()、publicgetY()、publicgetZ()和publicgetR()方法

java - 带有私有(private)构造函数的最终类,设计原则是什么

我最近正在浏览一个Netflixopensourceproject在那里我发现了final类和私有(private)构造函数的使用。我完全知道final是为了避免继承private是不允许实例化但我只是想知道为什么将它们一起使用。虽然方法是静态的,所以我们可以在不实例化的情况下使用它们,但仍然渴望了解其背后的设计原则。 最佳答案 有了这段代码,你将拥有这些功能不允许任何人子类化(扩展)您的类不允许实例化你的类将变量或类设置为final可以提高性能(虽然不多,但在大型项目中作为常见做法使用会有所不同)在这种情况下,我看不到用于获取实例

java - 使用 Spring security 和 JWT 在 REST 中使用 <img> 标签访问私有(private)图像

当前场景Spring项目使用SpringSecurity和JWT保护RESTAPI。这些API生成JSON响应。UsernamePasswordAuthenticationFilter用于验证在Authorization中发送的JWTheader。经过身份验证和未经身份验证的API均按预期工作。要求现在我需要在HTTP响应中为登录用户发送图像。解决方案1发送了一个byte[],将图像表示为“图像”键的值以及其他信息。但是,如果图像很大,完整的JSON响应可能需要一些时间。解决方案2将链接作为“图像”键的值连同其他信息一起发送。客户可以分配,它应该在单独的请求中获取大图像。然后用@Req

java - 使用 Spock 模拟 Java 中的私有(private)静态最终变量

我正在尝试使用Groovy编写一些Spock测试来测试一些Java代码(特别是servlet过滤器)。我有一些privatestatic和privatestaticfinal变量我想模拟,但我无法确定是否有办法做到这一点。我知道metaClass可用于方法,是否有类似的变量?例如,我有:publicclassMyFilterimplementsFilter{privatestaticWebResourceRESOURCE;privatestaticfinalStringCACHE_KEY="key-to-be-used-for-cache";...actualmethods,etc..

java - 使用 java.lang.invoke.MethodHandle 调用私有(private)方法

如何使用方法句柄调用私有(private)方法?据我所知,只有两种可公开访问的Lookup实例:MethodHandles.lookup()MethodHandles.publicLookup()并且都不允许不受限制的私有(private)访问。有一个非公开的Lookup.IMPL_LOOKUP可以满足我的要求。是否有一些公共(public)方式来获取它(假设SecurityManager允许)? 最佳答案 事实证明,使用Lookup#unreflect(Method)并暂时使方法可访问是可能的(除非在程序初始化期间完成,否则可能会