草庐IT

java - Java中System.out.println()和return的区别

coder 2024-03-09 原文

我试图了解在方法中使用 System.out.println()return blah 的区别和好处。

好像System.out.println()是用来显示静态信息的,return是方法返回的值。然而,我看到了如下示例,其中在 System.out.println() 语句中使用了一个函数

System.out.println(name.substring(1, 3));

什么时候使用System.out.println()return 是正确的。是不是return以后可以被另一段代码使用,而System.out.println()不可以?

最佳答案

您的最后一句话实际上是正确的,但这两个操作之间的区别巨大,因此我想对它们的区别进行更深入的解释。

区别:

return 是控制程序执行流程的指令。它是 Java 语法的基本组成部分。它告诉计算机要执行代码的哪一部分,以及在执行期间要使用什么值。当您返回一个值时,您说的是“调用此方法的结果是 XXXX”(“XXXX”是您返回的值)。

System.out.println 不用于控制程序的执行方式。它只是一种通知用户程序内部正在发生的事情的方式。 System.out.println(简称syso)可以打印任何信息到控制台;它是变量、表达式还是方法调用的结果并不重要。对“静态”数据没有限制。

让我们看看它们的实际效果:

int addInts(int arg0, int arg1)
{
    return arg0 + arg1;
}

这意味着当我们在我们的程序中调用 addInts 时,它将计算其参数的总和。因此,当我们编写 addInts(3, 7) 时,就好像在我们的源代码中简单地编写了 3 + 710 一样。控制台没有打印任何内容;我们所做的只是为我们的程序提供一种计算方法。

但是,如果所有计算都放在计算机中,我们可能进行的任何计算最终都是无用的,因此我们需要一种方法来向用户显示此信息。输入系统:

System.out.println(addInts(22, 16));

addInts 方法被调用并返回 38。这个值被放置在计算机内存中的某个地方,以便我们的程序可以找到它。

接下来,syso 获取该值 (38) 并将其打印到控制台,让用户知道计算出的值。此过程没有计算出任何新内容,我们的程序继续执行下一条语句。

那我该用哪个呢?

在简单的程序中,您需要跟踪的值非常少,因此可能很想在计算位置打印您想知道的所有内容。例如,如果您正在编写一个程序来完成您的代数作业(我去过那里)并且您编写了一个求解二次方程的方法,那么您可能很想像这样构造它:

class Algebra
{
    static void quadSolve(double a, double b, double c)
    {
        double result = /* do math...  we're ignoring the negative result here*/;

        System.out.println("The solution to the quadratic equation is: " + result);
    }

    public static void main(String[] args)
    {
        quadSolve(1.0, -6.0, 9.0);
    }
}

但是,如果您想让您的程序稍微复杂一点,这种方法很快就会变成一个非常糟糕的主意。假设有一个问题要求您求解二次方程,然后使用该计算结果计算圆柱体的体积。在上面的例子中,我们不能这样做:在我们通过 syso 将 result 的值转储到控制台后,它会在 quadSolve 方法结束时消失。如果我们让 quadSolve 返回 result 并让“调用者”(调用 quadSolve 的地方)处理处理,这将更有意义那个值。这是一种更加灵活的设计,使我们能够相对轻松地使我们的程序变得更加复杂。这种增加的灵 active 和模块化确实使方法变得有用。这是实现:

class Algebra
{
    static double quadSolve(double a, double b, double c)
    {
        double result = /* do math...  we're ignoring the negative result here*/;

        return result;
    }

    public static void main(String[] args)
    {
        double x = quadSolve(1.0, -6.0, 9.0);
        //now we can do whatever we want with result: 
        //print it, negate it, pass it to another method-- whatever.
        System.out.println("The solution to the quadratic equation is: " + x);
        System.out.println("And it's square is: " + (x * x));
    }
}

我希望这能解决问题。如果您需要进一步说明,请随时询问。

关于java - Java中System.out.println()和return的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25456472/

有关java - Java中System.out.println()和return的区别的更多相关文章

  1. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  2. ruby - 触发器 ruby​​ 中 3 点范围运算符和 2 点范围运算符的区别 - 2

    请帮助我理解范围运算符...和..之间的区别,作为Ruby中使用的“触发器”。这是PragmaticProgrammersguidetoRuby中的一个示例:a=(11..20).collect{|i|(i%4==0)..(i%3==0)?i:nil}返回:[nil,12,nil,nil,nil,16,17,18,nil,20]还有:a=(11..20).collect{|i|(i%4==0)...(i%3==0)?i:nil}返回:[nil,12,13,14,15,16,17,18,nil,20] 最佳答案 触发器(又名f/f)是

  3. ruby-on-rails - `a ||= b` 和 `a = b if a.nil 之间的区别? - 2

    我正在检查一个Rails项目。在ERubyHTML模板页面上,我看到了这样几行:我不明白为什么不这样写:在这种情况下,||=和ifnil?有什么区别? 最佳答案 在这种特殊情况下没有区别,但可能是出于习惯。每当我看到nil?被使用时,它几乎总是使用不当。在Ruby中,很少有东西在逻辑上是假的,只有文字false和nil是。这意味着像if(!x.nil?)这样的代码几乎总是更好地表示为if(x)除非期望x可能是文字false。我会将其切换为||=false,因为它具有相同的结果,但这在很大程度上取决于偏好。唯一的缺点是赋值会在每次运行

  4. ruby - 这两个 Ruby 类初始化定义有什么区别? - 2

    我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是

  5. ruby - 怎么来的(a_method || :other) returns :other only when assigning to a var called a_method? - 2

    给定以下方法:defsome_method:valueend以下语句按我的预期工作:some_method||:other#=>:valuex=some_method||:other#=>:value但是下面语句的行为让我感到困惑:some_method=some_method||:other#=>:other它按预期创建了一个名为some_method的局部变量,随后对some_method的调用返回该局部变量的值。但为什么它分配:other而不是:value呢?我知道这可能不是一件明智的事情,并且可以看出它可能有多么模棱两可,但我认为应该在考虑作业之前评估作业的右侧...我已经在R

  6. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  7. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  8. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  9. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  10. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

    HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

随机推荐