- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我试图了解在方法中使用 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 + 7
或 10
一样。控制台没有打印任何内容;我们所做的只是为我们的程序提供一种计算方法。
但是,如果所有计算都放在计算机中,我们可能进行的任何计算最终都是无用的,因此我们需要一种方法来向用户显示此信息。输入系统:
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/
平时很少在jquery中用到this。查看代码时发现用到了,就调试出this的值,心想原来如此。还是挺有用的。这里总结一下this与$(this)的区别和使用。 $(this)生成的是什么?
使用单例类和应用程序范围的托管 bean 来保存应用程序数据有区别吗? 我需要查找某些 JNDI 资源,例如远程 bean 接口(interface),因此我为自己编写了一个单例来缓存我的引用并且只允
如果您仔细查看包含的图片,您会注意到您可以使用 Eclipse IDE 重构 Groovy 代码并将方法转换为闭包,反之亦然。那么,闭包到底是什么,它与方法有什么不同呢?有人可以举一个使用闭包的好例子
vagrant box repackage有什么区别( docs ) 和 vagrant package ( docs )? 我意识到 vagrant package仅适用于 VirtualBox 提
我想看看是否有人可以解释为什么以下代码适用于 valueOf 但不适用于其他代码。 import java.math.BigDecimal; public class Change { publ
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicates: What is Closures/Lambda in PHP or Javascript in layman te
This question already has answers here: Vagrant, Docker, Puppet, Chef (3个答案) 2年前关闭。 docker和chef有什么共同
以下代码在95%的机器上产生相同的输出,但是在几台机器上却有所不同。在 Debug模式下,输出: Changing from New to Fin OK 但在 Release模式下: Changing
////Creating Object var Obj; // init Object Obj= {}; 它们之间有什么区别两个? 有没有可能把它变成一个单行? 这样使用有什么好处吗?
我想找出定时器服务之间的区别。我应该使用哪个以及何时使用。我正在使用 Jboss 应用服务器。 1) java.ejb.Schedule。 @Schedule注解或配置自xml。 2) javax.e
我发现在 C++ 中可以通过三种不同的方式将对象传递给函数。假设我的类(class)是这样的: class Test { int i; public: Test(int x);
有什么区别。 public class Test { public static void main(String args[]) { String toBeCast = "c
如果我有一列,设置为主索引,设置为INT。 如果我不将其设置为自动递增,而只是将唯一的随机整数插入其中,与自动递增相比,这是否会减慢 future 的查询速度? 如果我在主索引和唯一索引为 INT 的
这两种日期格式有什么区别。第一个给出实际时间,第二个给出时间购买添加时区偏移值。 NSDateFormatter * dateFormatter = [[NSDateFormatter alloc]
如果有一个函数,请说foo: function foo() { console.log('bar'); } 那么在 JavaScript 中,从另一个函数调用一个函数有什么区别,如下所示: f
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 4 年前。 Improv
代码是什么: class Time { private: int hours; int minutes; int seconds; pu
我知道这是非常基本的,但有人介意解释一下这两个数组声明之间的区别吗: #include array myints; ...和: int myints[5]; ...以及为什么 myints.size
我学会了如何根据 http://reference.sitepoint.com/css/specificity 计算 css 特异性但是,基于this reference,我不明白伪类(来自c)和伪元
为什么在运行 2) 时会出现额外的空行?对我来说 1 就像 2。那么为什么 2) 中的额外行? 1) export p1=$(cd $(dirname $0) && pwd) #
我是一名优秀的程序员,十分优秀!