- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先是代码:
module Boolean = struct
exception SizeMismatch
type boolean = T | F | Vec of boolean array
let to_bool v = match v with
T -> true
| F -> false
| _ -> raise SizeMismatch
end
module Logic = struct
type 'a var_t = { name: string; mutable value: 'a }
type 'a bexp = Const of 'a
| Var of 'a var_t
let eval exp = match exp with
Const x -> x
| Var x -> x.value
let make_var s v = { name = s; value = v }
let set v n = v.value <- n
let get_var_name v = v.name
let get_var_val v = v.value
end
module type EXP =
sig
type 'a var_t
type 'a bexp
val eval_exp : 'a bexp -> bool
val get_var_name : 'a var_t -> string
val get_var_val : 'a var_t -> 'a
end
module LogicExp =
struct
include Logic
let eval_exp exp = Boolean.to_bool (Logic.eval exp)
end
module FSM ( Exp : EXP ) =
struct
let print_var v = Printf.printf "%s = %d\n" (Exp.get_var_name v)
(Exp.get_var_val v)
end
module MyFSM = FSM(LogicExp)
let myvar = Logic.make_var "foo" 1;;
MyFSM.print_var myvar ;;
编译时出现以下错误:
File "test.ml", line 57, characters 19-27:
Error: Signature mismatch:
Modules do not match:
sig
type 'a var_t =
'a Logic.var_t = {
name : string;
mutable value : 'a;
}
type 'a bexp = 'a Logic.bexp = Const of 'a | Var of 'a var_t
val eval : 'a bexp -> 'a
val make_var : string -> 'a -> 'a var_t
val set : 'a var_t -> 'a -> unit
val get_var_name : 'a var_t -> string
val get_var_val : 'a var_t -> 'a
val eval_exp : Boolean.boolean Logic.bexp -> bool
end
is not included in
EXP
Values do not match:
val eval_exp : Boolean.boolean Logic.bexp -> bool
is not included in
val eval_exp : 'a bexp -> bool
我不明白的是,更具体的类型为何不包含在更一般的类型中?
最佳答案
错误信息实际上是相当准确的:
Values do not match:
val eval_exp : Boolean.boolean Logic.bexp -> bool
is not included in
val eval_exp : 'a bexp -> bool
MyFSM
仿函数需要一个模块参数,除其他外,应该包含一个函数 eval_exp
类型 'a bexp -> bool
.这意味着给定类型的值 'a bexp
对于 'a
的任何选择该函数应产生 bool
类型的值.但是,您提供的模块包含一个函数,该函数仅针对 'a
的一个特定选择执行此操作。 ,即'a
是类型 boolean
来自模块 Boolean
.
最快的解决方法是定义您的签名 EXP
作为
module type EXP =
sig
type b (* added *)
type 'a var_t
type 'a bexp
val eval_exp : b bexp -> bool (* changed *)
val get_var_name : 'a var_t -> string
val get_var_val : 'a var_t -> 'a
end
所以eval_exp
现在对固定类型的 bool 表达式进行运算 b
然后定义 LogicExp
作为
module LogicExp =
struct
type b = Boolean.boolean (* added *)
include Logic
let eval_exp exp = Boolean.to_bool (Logic.eval exp)
end
以便修复 b
至 Boolean.boolean
.
实现这些更改将使您的代码编译通过。
现在,让我们看看您的问题“更具体的类型为何不包含在更一般的类型中?”。这假设 'a bexp -> bool
确实比boolean bexp -> bool
更通用,但实际上并非如此。函数类型A -> B
被认为比函数类型更通用 C -> D
如果C
比 A
更通用和 B
比 D
更通用:
A <: C D <: B
--------------------
C -> D <: A -> B
注意 C
的“翻转”和 A
在前提下。我们说函数空间构造函数 ... -> ...
在其参数位置是逆变(相对于在其结果位置是协变)。
直觉上,如果一种类型包含更多值,则它比另一种类型更通用。要了解为什么函数空间构造函数在其参数位置是逆变的,请考虑一个函数 f
类型 A -> C
对于某些类型 A
和 C
.现在,考虑一个类型 B
这比 A
更一般,即 A
中的所有值也在B
,但是B
包含一些不在 A
中的值.因此,至少有一个值b
。我们可以为其分配类型 B
, 但不输入 A
.它的类型告诉我们 f
知道如何对 A
类型的值进行操作.但是,如果我们要(错误地!)从 A <: B
得出结论那A -> C <: B -> C
, 那么我们可以使用 f
就好像它有类型 B -> C
因此,我们可以传递值 b
作为 f
的参数.但是b
不是 A
类型和 f
只知道如何操作 A
类型的值!
很明显,... -> ...
的协方差在争论的立场上是行不通的。要查看逆变性是否有效,请考虑相同的类型 A
, B
, 和 C
现在还考虑一个函数 g
类型 B -> C
.即 g
知道如何对 B
类型的所有值进行操作.函数空间构造函数在其参数位置的逆变允许我们得出结论 g
也可以安全地分配类型 A -> C
.我们知道 A
中的所有值也在B
和 g
知道如何处理所有B
这不会造成任何问题,我们可以安全地传递 A
中的值。至 g
.
关于ocaml - 仿函数编译问题 : Signature mismatch: Modules do not match,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10240184/
我有 4 个文件。 C:\perlCode2\start.pl6 C:\perlCode2\file0.pm6 C:\perlCode2\folder1\file1.pm6 C:\perlCode2\
我有一个结构如下的模块: /module __init__.py /submod_1 __init__.py submod_1_class.py
我的源代码在 java 7 上编译并在 java 11 上运行。 我正在尝试将 imperva RASP 作为 java 代理集成到 tomcat 中。但是,当我启动 tomcat 服务器时,它抛出以
justExport.js const first = () => { console.log('frist from justExport') } const second = () => {
以下模块用JS文件编写: module.exports = { propA: 1, propB: 2 } 允许稍后从模块导入属性,如:从“路径/到/模块”导入 { propA} 然而,将文件格
我一直在尝试在嵌套的惰性加载模块中实现ngx翻译,但一直未能如愿。我面临的唯一问题是,每当我通过选择器更改语言时,嵌套延迟加载模块中的语言都不会更改。 HttpLoader 工作正常,其他一切工作正常
我没有可重复的示例,因为问题更多是关于模块如何工作。我试图了解如何将一些 react 功能从一个模块传递到下一个模块。过去我收到过有关使用 ObserveEvent 的回复,但是当我在一个模块中使用响
我正在阅读Wikipedia's definition of Dependency inversion principle ,它使用了两个术语高级模块和低级模块,我无法弄清楚。 它们是什么以及依赖倒置
问题 我遇到的一个问题是将两个模块的类型和值带入一个新的组合模块中。我举个例子。目前我有以下两种类型签名 module type Ordered = sig type t (* the type
我是 JavaScript 的新手,最近一直在努力处理导入问题。有一件事我无法理解。 在较旧的节点模块(主要是那些在 ES6 之前出现的模块)中,可以使用 npm 安装,例如 express,通常没有
我正在尝试使用 System.JS 将 material-ui 导入我的 React 应用 在我的应用中,我这样做: import {AppBar, Tabs, Tab, Card, CardTitl
我想使用功能module->exports查找模块提供的所有导出。不幸的是,传递给该函数的模块必须在当前命名空间中声明,然后才能在其上使用该函数。当我静态地知道模块是什么时,这没问题,我只需要将其引入
目录结构如下 outdir |--lib |--- __init__.py |--- abc.py |--indir
这与提到的非常相似 here但是评论或回答中提供的每个解决方案都没有解决我的问题。想看看是否还有其他我应该看的东西。我尝试了不同的路径,比如 ./app/mycomponent/mycomponent
我有两个 Angular 模块:main 和 feature: 主/根模块: @NgModule({ imports: [ StoreModule.forRoot({route
我尝试在 Ubuntu 04.12 LTS x64 中安装“Userful MultiSeat-X64-5.0.1 ...”,在安装结束时遇到以下错误: File "", line 6, in Im
我正在尝试优化我的 vendor bundle.js,因为它已经膨胀并且我正在使用 material-ui 库。 import Card from 'material-ui'; // Very bad
错误: Import-Module : The specified module 'msonline' was not loaded because no valid module file was
我在 Server 2008 SP2(64 位)上执行导入模块 ActiveDirectory 时遇到问题。 NET Framework 3.5 SP1 已安装 我下载了 Windows6.0-KB9
嗯,你好! 我正在编写一个脚本来获取 Sql 作业历史记录,并且需要使用“SqlServer”模块。它已安装,但由于上面的错误消息,我无法导入它。当我到达模块路径时,文件夹“SqlServer”存在并
我是一名优秀的程序员,十分优秀!