传递参考与价值:Java是一个混合体吗
Pass by reference vs value: Is Java a hybrid?
我是一名过渡到C++的Java程序员,需要澄清Java是如何被视为"传递值"而不是"混合"的。Java的baz()的行为与下面的C++的foo()相同,后者是一个通过引用的特性。
编辑:我试图理解的是,尽管行为不同,为什么bar()和baz()是按值传递的我在论坛上找不到这个具体的答案。
Java
public class CountKeeper {
private static void baz(CountKeeper ck) {
ck.inc();
}
public static void main(String[] args) {
CountKeeper ck = new CountKeeper();
System.out.println(ck.count()); // 0
baz(ck);
System.out.println(ck.count()); // 1
}
private int count;
private int count() {
return count;
}
private void inc() {
count++;
}
}
C++
#include <iostream>
class CountKeeper
{
public:
CountKeeper();
CountKeeper& operator++();
int count();
private:
int count_;
};
CountKeeper::CountKeeper() :
count_(0)
{}
CountKeeper& CountKeeper::operator++()
{
++count_;
return *this;
}
int CountKeeper::count()
{
return count_;
}
//pass by reference
void foo(CountKeeper& ck)
{
++ck;
}
//pass by value
void bar(CountKeeper ck)
{
++ck;
}
int main()
{
CountKeeper ck;
std::cout<<ck.count(); // 0
foo(ck);
std::cout<<ck.count(); // 1
bar(ck);
std::cout<<ck.count(); // 1
return 0;
}
否。Java总是传递值。但看起来是Object
的实际上是Object
引用,因此(引用的值)是在传递Object
时传递的值。
将CountKeeper
对象传递给baz
将传递对该对象的引用的副本。因此,baz
可以更改该对象的状态(因为引用指向同一对象),但不能更改引用本身。
如果不是
private static void baz(CountKeeper ck) {
ck.inc();
}
你会写
private static void baz(CountKeeper ck) {
ck = new CountKeeper();
}
方法的调用方将不会看到传递给CCD_ 8的CCD_。
Java中的一切都是按值传递的。我认为在Java中阅读这个参数传递(通过引用还是通过值?)会很有趣,也很有益?。
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 运行同一解决方案的另一个项目的项目
- 挂起和取消挂起一个文件DLL
- 用C++中的一个变量定义一个常量
- 函数向量_指针有不同的原型,我可以构建一个吗
- 在c++中用vector填充一个简单的动态数组
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 预处理器:插入结构名称中的前一个行号
- 我在c++代码中生成了一个运行时#3异常
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 从链接列表c++中删除一个项目
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '