为什么许多nosql存储都是用java编写的
why many nosql stores are written in java?
据我所知,许多nosql存储都是用java编写的,例如HBase、Cassandra。但根据我的经验,许多高性能服务器程序都是用c/c++编写的(例如Apache、Opensips等),为什么这样的java实现程序在生产使用中表现良好?这是因为Java代码易于阅读和维护,并且用Java实现的分布式系统可以很好地扩展吗?
顺便说一句,我知道用Java编写代码肯定会更有效率,但正如有人所说,在大公司中,实现速度不是问题,因为一旦实现并重构了几轮,程序就可以运行得很好,所以从长远来看,时间成本并不高。
如果你按照右边"相关"部分的第一个链接(为什么Cassandra是用Java编写的),你会找到答案。
简要总结:
- 它是独立于平台的
- Java代码并不一定比C/C++慢很多,有时甚至更快(见下文)
- Java从一开始就内置了对任何平台的线程支持
- 安全性/安全性(无缓冲区溢出、核心转储等)
EDIT"C/C++的定义比Java快"的神话只是一个神话。看看这个问题作为反例。
相关文章:
- 在混合代码库中将C转换为C++时出现许多包含错误
- 在java中解决这段代码时面临循环中的问题
- 尝试用java代码编译和运行c++代码
- 在这种情况下,java对象是否可以调用本机函数
- 在java中读取c++字节的位字段
- 为什么C++对链表中的下一个节点使用指针,而像 C# 或 Java 这样的语言只使用类 Node 的名称?
- 使用已使用 java 编码的 openssl 解码数据
- 函数在许多数字上转换为基数 1 时减去 2?
- SWIG Java 在使用 -DSWIGWORDSIZE64 时将int64_t转换为 jlong
- Android Java USB for native cpp
- CPU 瓶颈;处理具有许多非静态对象的 3D 场景渲染的简单方法
- 在由Sublime文本3编译后在cmd上显示Java程序输出
- 我想生成许多矩阵并用随机数填充它
- C++ equivalent to Java Map getOrDefault?
- C++ 中的 Java 样式枚举
- 是否有技术原因阻止 Java 中的 final C++ 像 const 一样严格?
- Visual Studio 2017 停止工作,并在打开后显示许多控制台窗口
- 加密在 Windows、C++ 和 Java 中传输中的数据
- Java从C++回调到C++回调
- 为什么许多nosql存储都是用java编写的