- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
受到上一个问题的启发what is the easiest way to pass a list of integers from java to a frege function?以及@Ingo 对答案的评论,我试过了
(Foo/myfregefunction (java.util.List. [1,2,3,4]))
但是得到(ctor = constructor):
CompilerException java.lang.IllegalArgumentException: No matching ctor found for interface java.util.List
有什么想法吗?至少 java.util.List
没有产生 ClassCastException;这是否意味着这是在正确的轨道上?
我可以从 Clojure 向 Frege 发送几乎任何 Java 集合类型,参见 Converting Clojure data structures to Java collections .
顺便说一句,使用普通 (Foo/myfregefunction [1,2,3,4])
会产生 ClassCastException clojure.lang.PersistentVector cannot be cast to free.runtime.Lazy
,@Ingo 指出,“clojure 列表不是 frege 列表。”转换为 java.util.ArrayList
时的类似响应。
在弗雷格这边,代码是这样的
module Foo where
myfregefunction :: [Int] -> Int
-- do something with the list here
最佳答案
好吧,我不懂 Clojure,但是根据你提供的链接,我认为你需要给出一个可实例化类的名称(即 java.util.ArraList
),因为 java.util .List
只是一个接口(interface),因此无法构造。
对于 Frege 端,在这种情况下是消费者,假设接口(interface)就足够了。
整个事情变得有点复杂,因为 Frege 知道 java 列表是可变的。这意味着不存在纯函数
∀ s a. Mutable s (List a) → [a]
并且每次用纯语言编写这样的函数的尝试都必须失败,并且会被编译器拒绝。
相反,我们需要的是一个 ST
操作来包装纯部分(在本例中,您的函数 myfregefunction
)。 ST
是使处理可变数据成为可能的单子(monad)。这将是这样的:
import Java.Util(List, Iterator) -- java types we need
fromClojure !list =
List.iterator list >>= _.toList >>= pure . myfregefunction
从 clojure,你现在可以调用类似的东西(如果我把 clojure 语法弄错了请原谅我(欢迎编辑)):
(frege.prelude.PreludeBase$TST/run (Foo/fromClojure (java.util.ArrayList. [1,2,3,4])))
恕我直言,这种通过 Java 的接口(interface)有两个缺点。首先,我们引入了可变性,Frege 编译器不允许我们忽略它,因此接口(interface)变得更加复杂。此外,列表数据将被复制。我不知道 Clojure 是怎么做到的,但至少在 Frege 方面,有这段代码遍历迭代器并将数据收集到 Frege 列表中。
所以更好的方法是让 Frege 知道什么是 clojure.lang.PersistentVector
并直接在 Frege 中处理 clojure 数据。我知道有人用 clojure 持久性 HashMap 以这种方式做到了这一点,所以我想应该可以对列表做同样的事情。
(此时我不得不指出贡献一个深思熟虑的 Clojure/Frege 接口(interface)库是多么有值(value)!)
编辑:正如@0dB 的 self 回答所暗示的那样,他即将实现前几段中提到的卓越解决方案。我鼓励大家通过投票支持这项崇高的事业。
第三种方法是直接在 Clojure 中构造 Frege 列表。
关于java - 如何将整数列表从 Clojure 传递给 Frege 函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34379301/
出于好奇,我在 Frege 中尝试了以下代码: println (mydrop 30000000 [1..30000001]) 不用说,3000 万个条目的序列有点愚蠢,我对 OOME 没问题。我想看
一些语言允许模块跨越多个文件。在 Frege 中,这意味着模块的命名空间将对以后的扩展“开放”。 我认为这是不可能的,因为模块是由它们编译的类文件定位的——除非会有一些聪明的命名技巧。 我只是想确定一
按照 how to use multiple inline assertions in Frege 的回答我学会了如何编译两个 Frege 模块 A 和 B,其中 B 依赖于 A:你必须编译 B。如果
在交互式 shell 和(在线)REPL 中我可以输入 :type 1 找出表达式“1”的类型。我可以从代码中使用任何函数来达到相同的效果吗? 最佳答案 目前没有简单的方法可以做到这一点。 但是,RE
在尝试学习弗雷格时,我从 Dierk's Real World Frege 复制了一些代码到在线 REPL 并尝试执行它(另请参见 How to execute a compiled code sni
在尝试处理异常时我发现了一个相关的问题: what is the Frege equivalent to Haskell's "interact" function? 但我不清楚如何使用 try/ca
我正在尝试找出 native 界面。我正在尝试使用 UDP 发送一些消息。这是我所拥有的: module UDPTest where data StringAsBytes = native ja
如果 Frege 有一个 POM 并被上传到 maven central 或 bintray,我可以很容易地将它用作 maven、gradle、buildr 和 via grapes 中的 maven
我尝试从在 Frege 中运行的真实 Haskell 中获取字数示例: main _ = interact wordCount where wordCount input = show (le
该程序在GHC下编译运行正常: type Church a = (a -> a) -> a -> a ch :: Int -> Church a ch 0 _ = id ch n f = f . ch
我想构建一个抽象来使用不同的模板引擎: class Template a where process :: a -> Model -> IO String class TemplateEngine
您将如何调整这个简单的递归示例,以便进行尾调用优化(而不是 StackOverflowError)? count 0 = 0 count n = succ (count (pred n)) count
尾调用是否在 Frege 中进行了优化。我知道 Java 和编译为 JVM 字节码的语言(如 Clojure 和 Scala)都没有 TCO。弗雷格呢? 最佳答案 Frege 通过简单地生成 whil
我是在阅读 Frege language specification 后发布的并使用搜索引擎寻找示例。我希望我没有忽略一个明显的答案。 我正在尝试将一些 Haskell 代码移植到 Frege,但我找
我正在努力将 GHC/Arr.hs 移植到弗雷格。 数组定义: data Array i e = Array{u,l::i,n::Int,elems::(JArray e)} 有函数: amap ::
根据 Hoogle,>= (bar <=< baz) 无积分,它给了我 bar <=< baz =<< foo 考虑到固定性,这看起来不太正确。 最佳答案 Frege 就像 Haskell,但 Fre
假设我有一个所有素数的列表,定义为 primes :: (Enum α, Integral α) => [α] primes = sieve [2..] where sieve :: (Integ
我正在尝试加载文件。 我有: wf :: STMutable a File wf = File.new "worlds/seed_77.world" data PickleSerialization
我认为我在这里犯了一个简单的错误,但我无法让 Frege 找到本地 Eclipse 项目之外的任何类。 我有一个正在运行的重要 Java 项目(不是我的),我不想修改它。我想要一个新的、干净的弗雷格启
假设我想映射 Java 代码: package mypackage; class A { public String[] values() { return new String
我是一名优秀的程序员,十分优秀!