Clojure

开源公司:甲骨文公司

作品详情

中文名
clojure
展开
特 点
函数式编程语言引入
展开
风格
Clojure是一种LISP风格的语言
展开
性 质
当今最主流的运算平台JVM
展开
释 义
JVM的字节码进行运算
展开
特色
支持不可变的数据结构
展开

1基本内容

  

概述

Clojure是一种LISP风格的语言,运行在JVM上。Clojure的一大特色就是其并发机制,它支持不可变的数据结构(Clojure是来自于可持久化的数据结构)。Clojure还有一个特色是软件事务存储(Software Transactional Memory,STM),其支持用事务代替锁和互斥器来更新共享内存。STM还是一个有争议的技术,还需要更好的证明自己,一个简单的办法就是访问一个JVM上的实现。

作为当今最主流的运算平台JVM,把函数式编程语言引入JVM也是很多人尝试的方向,Clojure就是其中之一。Clojure是一个在JVM平台运行的动态函数式编程语言,其语法解决于LISP语言,在JVM平台运行的时候,会被编译为JVM的字节码进行运算。  

特点

Clojure保持了函数式语言的主要特点,例如immutable state,Full Lisp-style macro support,persistent data structures等等,并且还能够非常方便的调用Java类库的API,和Java类库进行良好的整合。

2编程举例

Hello world:

(println "Hello, world!")

定义一个函数:

(defn square [x] (* x x))

使用Java Swing库的 GUI Hello World:

(javax.swing.JOptionPane/showMessageDialog nil "Hello World")

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
技术栈:Flink,Spark,Kafka,HBase,Mysql ,语种识别引擎,语音转写引擎 该项目主要是建设重点人管控分析平台,利用只能语音技术,意图分析技术,实现重点管控人员的的及时发现,并进行预警防范。系统依托大数据平台的存储与运算能力,实时接入通话、短信、上网、轨迹数据,分别按照多种规则进行分析过滤后,实现重点人员的识别入库以及敏感行为的预警触发。 我在项目中的职责: 1.预处理服务:使用 Flink 实时从 Kafka 接入通话、短信、上网数据,并分别按照不同规则进行分析,若满足一定条件则将该数据对应人保存至重点人库中。 2.重点人预警服务:使用 Flink 实时从 Kaf
1. **用户管理** - 用户注册、登录、注销 - 用户信息维护 - 用户角色分配 2. **权限管理** - 角色创建与管理 - 权限配置与分配 - 多层级权限体系支持 3. **资源管理** - 系统资源的分类与定义 - 资源访问控制策略 - 资源使用监控与日志记录 4. **安全管理** - 用户身份认证(支持多种认证方式) - 数据加密传输 - 安全日志与异常行为检测 5. **报表与分析** - 权限使用情况报表 - 用户行为分析 - 安全事件统计与报告 **技术架构** 该系统基于
技术栈:SparkSQL,Hive,Flinkx,ClickHouse,海豚调度,数仓维度建模,Kafka,PolarDB 数据化服务平台提供了各种业务数据的分析与展示,便捷地获取完整、准确、丰富的数据分析结果,支撑业务精准和快速决策。但由于1.0版本的数据存储与计算完全基于Mysql,导致数据计算过慢,历史数据无法获取,对于一些复杂指标的统计无法直接通过Mysql中现有数据直接计算得到。所以数据化服务平台中需要一种新的存储及计算方式。2.0版本使用数据仓库进行改造,并结合大数据能力进行存储与计算,彻底解决了1.0版本中存在的性能瓶颈与功能缺失。 我在项目中的职责: 1.设计数据化服务平台2.
资金管理系统 1、财务报表 2、财务对账 3、财务会计 使用客户:泸州老窖、迅销商贸、追觅科技、康师傅、东风日产
技术栈:Flink,Flink CDC,Kafka,Redis,PolarDB 随着公司越来越多的业务场景对实时性要求越来越高,传统的Java程序已无法满足业务需求,需要采用Flink实时计算框架来对业务进行支撑。Flink大数据实时计算服务内部包含了多个Flink任务流,分别处理多个不同的业务流程。并且结合Flink cdc服务进行数据同步,使得业务处理更加高效、便捷。 我在该项目中的职责: 1.构建Flink实时计算项目框架,搭建整体服务架构,包括Flink项目工程样例创建,数据库工具类、Kafka工具类、Redis工具类、日期工具类等。 2.java程序改造Flink,某些新的功能需求使
当前共17993个项目

评论