From Java to C++ 第二篇

简介: From Java to C++ 第二篇

第一篇:

juejin.cn/post/695882…

序言


上篇我们熟悉了C++的基本用法,既然C++也是一门面向对象的语言,那么这期我们就来对比下Java和C++中,方法和类是如何书写的。

方法


Java

public void hello() {
  System.out.print("Hello, World!");
}

C++

int hello(); // C++ 函数声明阶段
/**
 * 在main方法前,可先不声明,只有类中定义的函数才允许public修饰符
 */
void hello2(){
    cout << "Hello2, World!";
}
int main() {
    hello();
    hello2();
    return 0;
}
/**
 * 函数实现
 * 如果再main方法后实现,必须先声明
 * @return 
 */
int hello(){
    cout << "Hello, World!";
}

方法参数


Java

public void hello(String name){
  System.out.print("Hello, " + name + "!");
}

C++

void hello(string); // C++ 函数声明阶段
或者
void hello(string name); // 声明阶段可以带名字,可以不带
int main(){
  string aa;
    hello(aa);
}
void hello(string name){
    cout << "Hello, " + name + "!";
}

参数默认值


Java

public void hello(String name) {
  if (name == null) {
    name = "World";
  }
  System.out.print("Hello, " + name + "!");
}

C++

void hello(string = "World"); // 声明阶段,添加默认值World
int main() {
    hello();
    return 0;
}
/**
 * 函数实现
 * 如果再main方法后实现,必须先声明
 * @return
 */
void hello(string name) {
    cout << "Hello, " + name + "!";
}

方法Return


Java

public boolean hasItems() {
  return true;
}

C++

bool hasItems() {
    return true;
}

单表达式


Java

public double cube(double x) {
  return x * x * x;
}

C++

double cube(double x) {
    return x * x * x;
}

类->New


Java

File file = new File("file.txt"); //对象在堆中,对象引用在栈中

C++

class Test {
public:
    void add() {
    }
};
int main() {
    Test test1;  //栈中分配  ,由操作系统进行内存的分配和管理
    Test *test1;  //加*表示为指向Test类对像的指针变量,不加*则为Test类对像
    Test *test = new Test();  //堆中分配  ,由管理者进行内存的分配和管理,用完必须delete(),否则可能造成内存泄漏
    delete test;
    return 0;
}

注意:栈中内存的分配和管理由操作系统决定,而堆中内存的分配和管理由管理者决定

类->不可被继承


Java

public final class User {
}

C++

//C++11的新特性
class User final {
};

类->不可被继承的成员变量


Java

class User {
     private final String name;
     public User(String name) {
         this.name = name;
     }
     public String getName() {
         return name;
     }
 }

C++

class User {
private:
   const string u_name; // const限制只能被赋值一次
public:
    User(string name); // 声明
};
User::User(string name) : u_name(name){}; //实现
int main() {
    User user = User("test");
    return 0;
}

类-> 可选的构造参数


Java

final class User {
     private String name;
     private String lastName;
     public User(String name) {
         this(name, "");
     }
     public User(String name, String lastName) {
         this.name = name;
         this.lastName = lastName;
     }
     // And Getters & Setters
 }

C++

class User {
private:
     string u_name;
     string u_last_name;
public:
    User(string name,string lastName);
};
User::User(string name,string lastName = "1") : u_name(name) ,u_last_name(lastName){};
int main() {
    User user = User("test");
    User user1 = User("test","1");
    return 0;
}

抽象类


Java

public abstract class Document{
   public abstract int calculateSize();
}
public class Photo extends Document{
    @Override
    public int calculateSize() {
    }
}

C++

/**
 * 抽象类
 * 需要用纯虚函数
 * 纯虚函数是通过在声明中使用 "= 0" 来指定
 */
class Document{
public:
    virtual int calculateSize() = 0; //纯虚函数
};
class  Photo : Document{
public:
    int calculateSize() override{
        cout << "Photo";
        return 10;
    }
};
int main() {
    Photo photo;
    photo.calculateSize();
    return 0;
}

单例


Java

public class Document {
   private static final Document INSTANCE = new Document();
   public static Document getInstance(){
       return INSTANCE;
   }
 }

C++

//懒汉版
class Document {
private:
    static Document *document;
private:
    Document() {};
    ~Document() {};
    Document(const Document &);
    Document &operator=(const Document &);
private:
    class Deletor {
    public:
        ~Deletor() {
            if(Document::document != NULL)
                delete Document::document;
        }
    };
    static Deletor deletor;
public:
    static Document *getInstance() {
        if (document == NULL) {
            document = new Document();
        }
        return document;
    }
};

在程序运行结束时,系统会调用静态成员deletor的析构函数,该析构函数会删除单例的唯一实例。使用这种方法释放单例对象有以下特征:

  • 在单例类内部定义专有的嵌套类。
  • 在单例类内定义私有的专门用于释放的静态成员。
  • 利用程序在结束时析构全局变量的特性,选择最终的释放时机。

枚举类


Java

enum Color 
{ 
    RED, BLUE, WHITE, BLACK}; 
} 

C++

enum Color {RED, BLUE, WHITE, BLACK}; // 定义枚举类型Color
enum fruit_set {apple, orange, banana=1, peach, grape}
//枚举常量apple=0,orange=1, banana=1,peach=2,grape=3。

编译系统为每个枚举常量指定一个整数值,默认状态下,这个整数就是所列举元素的序号,序号从0开始。 可以在定义枚举类型时为部分或全部枚举常量指定整数值,在指定值之前的枚举常量仍按默认方式取值,而指定值之后的枚举常量按依次加1的原则取值。

总结一下


本期,我对比了函数,类,抽象类,单例,枚举等,整体上大同小异,你可能也注意到了一些细节的不同,其实大多时候都是很小的细节决定了问题的产生,虽然我可以通过这两篇的文章快速的了解C++,但还是不够,需要更深入的研究和学习,下期我们就针对某些细节以及一些概念的理解,来完成C++的从入门到精通。加油。

目录
相关文章
|
19天前
|
Java Android开发 C++
Java和C++
Java和C++
34 15
WK
|
1月前
|
安全 Java 编译器
C++和Java哪个更好用
C++和Java各具优势,选择取决于项目需求、开发者偏好及目标平台特性。C++性能出色,适合游戏、实时系统等;Java平台独立性强,适合跨平台、安全敏感应用。C++提供硬件访问和灵活编程范式,Java有自动内存管理和丰富库支持。两者各有千秋,需根据具体需求选择。
WK
38 1
|
2月前
|
IDE Java 程序员
C++ 程序员的 Java 指南
一个 C++ 程序员自己总结的 Java 学习中应该注意的点。
26 5
WK
|
1月前
|
开发框架 移动开发 Java
C++和Java哪个更适合开发移动应用
本文对比了C++和Java在移动应用开发中的优劣,从市场需求、学习难度、开发效率、跨平台性和应用领域等方面进行了详细分析。Java在Android开发中占据优势,而C++则适合对性能要求较高的场景。选择应根据具体需求和个人偏好综合考虑。
WK
60 0
WK
|
1月前
|
安全 Java 编译器
C++和Java哪个更适合开发web网站
在Web开发领域,C++和Java各具优势。C++以其高性能、低级控制和跨平台性著称,适用于需要高吞吐量和低延迟的场景,如实时交易系统和在线游戏服务器。Java则凭借其跨平台性、丰富的生态系统和强大的安全性,广泛应用于企业级Web开发,如企业管理系统和电子商务平台。选择时需根据项目需求和技术储备综合考虑。
WK
95 0
|
2月前
|
缓存 并行计算 Java
C++矢量运算与java矢量运算
本文探讨了C++和Java中的矢量运算与标量运算的性能比较,解释了矢量运算的原理和为什么它比标量运算快,包括并行性、数据局部性、指令优化和数据重用等优势。文章还提供了C++和Java的矢量运算示例代码,并展示了运行结果,以证明矢量运算在处理大量数据时的性能优势。
26 0
C++矢量运算与java矢量运算
|
3月前
|
Java Android开发 C++
🚀Android NDK开发实战!Java与C++混合编程,打造极致性能体验!📊
在Android应用开发中,追求卓越性能是不变的主题。本文介绍如何利用Android NDK(Native Development Kit)结合Java与C++进行混合编程,提升应用性能。从环境搭建到JNI接口设计,再到实战示例,全面展示NDK的优势与应用技巧,助你打造高性能应用。通过具体案例,如计算斐波那契数列,详细讲解Java与C++的协作流程,帮助开发者掌握NDK开发精髓,实现高效计算与硬件交互。
169 1
|
4月前
|
Rust 安全 Java
Java代码规范--排版,命名.:Rust能否撼动C++的王座?
系统编程是计算机科学的核心,C++长期占据主导地位,但其内存安全问题备受诟病。Rust以安全性为核心,通过所有权和生命周期概念避免了野指针和内存泄漏。此外,Rust的并发模型和日益丰富的生态系统使其成为现代系统编程的新选择,尤其在安全性和并发性方面表现出色。尽管C++依然强大,但Rust为开发者提供了更安全、易管理的选项,未来有望推动更多系统级应用的发展。
29 0
|
5月前
|
Java Android开发 C++
🚀Android NDK开发实战!Java与C++混合编程,打造极致性能体验!📊
【7月更文挑战第28天】在 Android 开发中, NDK 让 Java 与 C++ 混合编程成为可能, 从而提升应用性能。**为何选 NDK?** C++ 在执行效率与内存管理上优于 Java, 特别适合高性能需求场景。**环境搭建** 需 Android Studio 和 NDK, 工具如 CMake。**JNI** 构建 Java-C++ 交互, 通过声明 `native` 方法并在 C++ 中实现。**实战** 示例: 使用 C++ 计算斐波那契数列以提高效率。**总结** 混合编程增强性能, 但增加复杂性, 使用前需谨慎评估。
153 4
|
4月前
|
算法 Java Linux
Intellij Java JNI 调用 C++
Intellij Java JNI 调用 C++
43 0