我想下面的C#转换为F#:在类型使用F#索引属性
public class Matrix
{
double[,] matrix;
public int Cols
{
get
{
return this.matrix.GetUpperBound(1) + 1;
}
}
public int Rows
{
get
{
return this.matrix.GetUpperBound(0) + 1;
}
}
public Matrix(double[,] sourceMatrix)
{
this.matrix = new double[sourceMatrix.GetUpperBound(0) + 1, sourceMatrix.GetUpperBound(1) + 1];
for (int r = 0; r < this.Rows; r++)
{
for (int c = 0; c < this.Cols; c++)
{
this[r, c] = sourceMatrix[r, c];
}
}
}
public double this[int row, int col]
{
get
{
return this.matrix[row, col];
}
set
{
this.matrix[row, col] = value;
}
}
}
这是我到目前为止有:以上
type Matrix(sourceMatrix:double[,]) =
let mutable (matrix:double[,]) = Array2D.create (sourceMatrix.GetUpperBound(0) + 1) (sourceMatrix.GetUpperBound(1) + 1) 0.0
member this.Item
with get(x, y) = matrix.[(x, y)]
and set(x, y) value = matrix.[(x, y)] <- value
do
for i = 0 to matrix.[i].Length - 1 do
for j = (i + 1) to matrix.[j].Length - 1 do
this.[i].[j] = matrix.[i].[j]
我的类型似乎有两个问题我不知道如何解决。第一个是矩阵。[(x,y)]预计有类型`a []但是类型为double [,]。第二种是类型定义在成员和接口定义之前必须有let/do绑定。这个问题是我试图填充do块中的索引属性,这意味着我必须先创建它。
由于提前,
鲍勃
对不起,我只是编辑它,粘贴在错误的构造函数中。 – Beaker 2011-03-05 21:48:20
优秀的答案,以及只读的这是你的一个正确的假设。原来的C#不是我的,我忽略了这一点。对C#和F#都很好。 :) – Beaker 2011-03-05 23:35:46
如果有人感兴趣,我添加了这个问题的后续问题:http://stackoverflow.com/questions/5212570/adding-overloaded-constructors-to-implicit-f-type – Beaker 2011-03-06 19:07:13