Fortran数组
数组可以存储相同类型的元件的固定大小的连续集合。数组是用来存储数据的集合,但它往往是更加有用认为数组为相同类型的变量的集合。
所有数组由连续的存储单元。最低的地址对应于所述第一元件和所述最高地址的最后一个元素。
Numbers(1) | Numbers(2) | Numbers(3) | Numbers(4) | … |
数组可以是一维的(如向量),二维(如矩阵),Fortran允许最多创建7维数组。
声明数组
数组的尺寸属性声明。
例如,声明含有5个元素的实数的一个一维阵列命名号编写,
real, dimension(5) :: numbers
数组的各个元素通过指定其下标引用。数组的第一元件具有一个的下标。数组数字包含五个实变量- numbers(1), numbers(2), numbers(3), numbers(4), 和numbers(5)。
要创建一个5×5的二维矩阵命名的整数数组:
integer, dimension (5,5) :: matrix
也可以声明某些明确的下限,例如数组:
real, dimension(2:6) :: numbers integer, dimension (-3:2,0:4) :: matrix
赋值
可以将值分配给各个成员一样,
numbers(1) = 2.0
或者,可以使用一个循环,
do i=1,5 numbers(i) = i * 2.0 end do
一维数组元素可直接分配其值使用短手形符号,被称为数组构造,如,
numbers = (/1.5, 3.2,4.5,0.9,7.2 /)
请注意,不存在括号“(”和背斜杠“/”之间所允许有空格
例子
下面的例子演示了上面讨论的概念。
program arrayProg real :: numbers(5) !one dimensional integer array integer :: matrix(3,3), i , j !two dimensional real array !assigning some values to the array numbers do i=1,5 numbers(i) = i * 2.0 end do !display the values do i = 1, 5 Print *, numbers(i) end do !assigning some values to the array matrix do i=1,3 do j = 1, 3 matrix(i, j) = i+j end do end do !display the values do i=1,3 do j = 1, 3 Print *, matrix(i,j) end do end do !short hand assignment numbers = (/1.5, 3.2,4.5,0.9,7.2 /) !display the values do i = 1, 5 Print *, numbers(i) end do end program arrayProg
当上述代码被编译和执行时,它产生了以下结果:
2.00000000 4.00000000 6.00000000 8.00000000 10.0000000 2 3 4 3 4 5 4 5 6 1.50000000 3.20000005 4.50000000 0.899999976 7.19999981
数组相关某些术语
下表给出了一些阵列相关的术语:
术语 | 意思 |
---|---|
Rank | 它的尺寸数组具有的数目。例如,对于数组命名矩阵,秩为2,并且对数组命名号,秩为1。 |
Extent | 它是沿一维中的元素的数量。例如,阵列数字具有范围5和命名矩阵阵列具有在两个维度范围3。 |
Shape | 数组的形状是一维整数数组,包含在每一维的元素(程度)的数量。例如,对于数组基质,形状为(3,3)和数组数字它是(5)。 |
Size | 它是元素的数组中包含的数量。对于数组矩阵,它是9,而对于数字阵列,其为5。 |
数组传递给过程
可以传递一个数组到过程作为参数。下面的例子演示了这一概念:
program arrayToProcedure implicit none integer, dimension (5) :: myArray integer :: i call fillArray (myArray) call printArray(myArray) end program arrayToProcedure subroutine fillArray (a) implicit none integer, dimension (5), intent (out) :: a ! local variables integer :: i do i = 1, 5 a(i) = i end do end subroutine fillArray subroutine printArray(a) integer, dimension (5) :: a integer::i do i = 1, 5 Print *, a(i) end do end subroutine printArray
让我们编译和运行上面的程序,这将产生以下结果:
1 2 3 4 5
在上面的例子中,此子程序 fillArray 和 printArray 只能被称为带维度 5 的数组,当子程序可用于任何尺寸的阵列,则可以使用下面的技术来重写:
program arrayToProcedure implicit none integer, dimension (10) :: myArray integer :: i interface subroutine fillArray (a) integer, dimension(:), intent (out) :: a integer :: i end subroutine fillArray subroutine printArray (a) integer, dimension(:) :: a integer :: i end subroutine printArray end interface call fillArray (myArray) call printArray(myArray) end program arrayToProcedure subroutine fillArray (a) implicit none integer,dimension (:), intent (out) :: a ! local variables integer :: i, arraySize arraySize = size(a) do i = 1, arraySize a(i) = i end do end subroutine fillArray subroutine printArray(a) implicit none integer,dimension (:) :: a integer::i, arraySize arraySize = size(a) do i = 1, arraySize Print *, a(i) end do end subroutine printArray
请注意,该程序正在使用size函数,以获得阵列的大小。
让我们编译和运行上面的程序,这将产生以下结果:
1 2 3 4 5 6 7 8 9 10
数组部分
到目前为止,我们已经提到了整个数组,Fortran语言提供了一种简单的方法来引用几个元素,或者一个数组的一部分,使用单条语句。
访问一个数组片段,需要提供的下限和上限的部分,以及一个跨度(增量),对于所有的尺寸。这种表示法被称为下标三元组:
array ([lower]:[upper][:stride], ...)
当没有下限和上限提及,它默认为声明的范围,并且跨度值默认为1。
下面的例子演示了这一概念:
program arraySubsection real, dimension(10) :: a, b integer:: i, asize, bsize a(1:7) = 5.0 ! a(1) to a(7) assigned 5.0 a(8:) = 0.0 ! rest are 0.0 b(2:10:2) = 3.9 b(1:9:2) = 2.5 !display asize = size(a) bsize = size(b) do i = 1, asize Print *, a(i) end do do i = 1, bsize Print *, b(i) end do end program arraySubsection
让我们编译和运行上面的程序,这将产生以下结果:
5.00000000 5.00000000 5.00000000 5.00000000 5.00000000 5.00000000 5.00000000 0.00000000E+00 0.00000000E+00 0.00000000E+00 2.50000000 3.90000010 2.50000000 3.90000010 2.50000000 3.90000010 2.50000000 3.90000010 2.50000000 3.90000010
数组内部函数
FORTRAN 90/95提供了一些固有的程序。它们可分为7类。