- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
Java for C++ programmers tutorial说(重点是我自己的):
The keyword final is roughly equivalent to const in C++
在这种情况下,“大致”是什么意思?他们不是完全一样吗?
有什么区别(如果有的话)?
最佳答案
在 C++ 中标记成员函数 const
意味着它可以在 const
实例上调用。 Java没有与此等效的。例如:
class Foo {
public:
void bar();
void foo() const;
};
void test(const Foo& i) {
i.foo(); //fine
i.bar(); //error
}
值只能在 Java 中被赋值一次,例如:
public class Foo {
void bar() {
final int a;
a = 10;
}
}
在 Java 中是合法的,但在 C++ 中不合法,而:
public class Foo {
void bar() {
final int a;
a = 10;
a = 11; // Not legal, even in Java: a has already been assigned a value.
}
}
在 Java 和 C++ 中,成员变量可能分别是 final
/const
。这些需要在类的实例完成构建时被赋予一个值。
在 Java 中,它们必须在构造函数完成之前设置,这可以通过以下两种方式之一实现:
public class Foo {
private final int a;
private final int b = 11;
public Foo() {
a = 10;
}
}
在 C++ 中,您需要使用初始化列表来为 const
成员赋值:
class Foo {
const int a;
public:
Foo() : a(10) {
// Assignment here with = would not be legal
}
};
在 Java 中,final 可用于将事物标记为不可覆盖。 C++(C++11 之前)不这样做。例如:
public class Bar {
public final void foo() {
}
}
public class Error extends Bar {
// Error in java, can't override
public void foo() {
}
}
但在 C++ 中:
class Bar {
public:
virtual void foo() const {
}
};
class Error: public Bar {
public:
// Fine in C++
virtual void foo() const {
}
};
这很好,因为标记成员函数 const
的语义不同。 (您也可以重载,只在其中一个成员函数上使用 const
。(另请注意,C++11 允许将成员函数标记为 final,请参阅 C++11更新部分)
C++11 实际上允许您将类和成员函数标记为 final
,与 Java 中的相同功能具有相同的语义,例如在 Java 中:
public class Bar {
public final void foo() {
}
}
public class Error extends Bar {
// Error in java, can't override
public void foo() {
}
}
现在可以用 C++11 完全写成:
class Bar {
public:
virtual void foo() final;
};
class Error : public Bar {
public:
virtual void foo() final;
};
我必须使用 G++ 4.7 的预发布版本来编译这个示例。请注意,在这种情况下,这不会替换 const
,而是对其进行扩充,提供最接近的等效 C++ 关键字所没有的类似 Java 的行为。因此,如果您希望成员函数既是 final
又是 const
你会这样做:
class Bar {
public:
virtual void foo() const final;
};
(这里需要const
和final
的顺序)。
以前没有直接等效的 const
成员函数,尽管使函数成为非virtual
可能是一种可能的选择,尽管不会在编译时导致错误。
Java 也是如此:
public final class Bar {
}
public class Error extends Bar {
}
在 C++11 中变为:
class Bar final {
};
class Error : public Bar {
};
(以前的 private
构造函数可能是你在 C++ 中最接近的)
有趣的是,为了保持与 C++11 之前代码的向后兼容性,final
不是通常的关键字。 (以简单、合法的 C++98 示例 struct final;
了解为什么将其设为关键字会破坏代码)
关于Java final 与 C++ const,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4971286/
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 2 年前。 Improve this q
1.final final修饰类,说明这个类不能被继承,是以个顶级类。 final修饰变量,说明这个变量是常量。 final修饰方法,表示这个方法不能被重写,不过可以冲在final方法。 比如有个
我喜欢使用 -Wsuggest-final-types 编译我的代码和 -Wsuggest-final-methods以便在可能使用 final 关键字以允许编译器更积极地优化的机会时收到警告。 不过
我在 Java 8 中有一个异步操作,它返回一个 onError 回调或一个 onSuccess 回调。如果操作成功与否,我需要在我的方法内部返回。所以我返回一个 boolean 值来说明这个信息。我
我正在阅读一些内容,需要对最终类和方法进行一些说明。我的理解是,将一个类声明为 final 会阻止该类被扩展。因此,是否有必要将最终类中的方法声明为最终的?在我看来,如果类不能扩展,则没有必要将方法声
有什么区别 try { // action A } catch(Exception e) { // action B } finally { // action C }
这个程序是我类(class)的最终作业,我无法弄清楚为什么我收到错误“从内部类引用的局部变量必须是最终的或有效的最终”。该程序正在运行并发线程来对# 数组进行排序,然后找到该数组的高值和低值。当我在没
C++11 added final. 终于! 我了解 final 做了两件事: 使类不可继承。 使类中的(虚拟)函数不可覆盖(在派生类中)。 这两者似乎是相互独立的。但以以下为例: class Foo
我想使用具有多个提交按钮的react-final-form构建表单,其中每个提交按钮在表单中设置不同的值。本质上,我想创建一个在呈现的HTML中看起来像这样的表单: Are you over 1
我想知道什么时候应该对变量和(或)方法使用静态、最终、静态最终参数。据我了解: final:类似于c++中的const参数。它基本上意味着值(或在方法中 - 返回值)不会改变。 静态:这意味着值(或方
我正在做一个编程类(class)项目,用于 400 行矩阵本身的矩阵乘法。我让它以顺序模式工作,该项目的目标是编写并行实现。 我有以下代码,当然,当我尝试引用内部类中的计数器 j 时,我收到一个关于
也许这是简单的问题,但我找不到答案。 声明为final的经典变量是否包含与非final变量不同的内存段? 最佳答案 我想说,谈到局部变量,基于 this answer 是不行的。 : The trut
考虑以下代码: #include class B { virtual void f() { std::cout << "Base" << '\n'; } }; class D
这个问题已经有答案了: java: Is it possible to set a lambda expression for an array of Buttons is a for loop? I
考虑这个代码片段 public class ConstantFolding { static final int number1 = 5; static final int numbe
我确定在内部类中访问的变量应该声明为final 或有效final。但在下面的情况下我很困惑。不知道是不是我理解错了。 public class MyClass { private boolea
我必须将一个 java.sql.Connection 对象传递给一个匿名内部类,这意味着我必须对它进行 final 引用。但是,我担心任何资源泄漏。 public static String foo(
我收到 SonarQube 错误:“强烈建议在此方法实现结束时调用 super.finalize(),以防父实现也必须释放一些系统资源。” 但我发现 Object 类没有实现 finalize方法。
我一般认为资源清理是在 finally block 中完成的, 最近我在一个类中发现了这个特定的代码片段,它覆盖了 Object 类'finalize()方法。 protected void fina
让我们在父类中使用这个方法: public void calculateSum(int a, final int b) { } 子类有: public void calculateSum(int a,
我是一名优秀的程序员,十分优秀!