Fortran没有内置的异常处理机制,但可以通过一些技巧和编程习惯来实现自定义的异常处理机制。以下是一种常见的方法:
function divide(a, b, result, err)
real :: a, b, result
integer :: err
if (b == 0) then
err = 1
else
result = a / b
err = 0
end if
end function divide
function divide(a, b, result, has_error)
real :: a, b, result
logical :: has_error
if (b == 0) then
has_error = .true.
else
result = a / b
has_error = .false.
end if
end function divide
subroutine handle_error(error_code)
integer :: error_code
select case(error_code)
case(1)
print *, "Error: Division by zero"
case default
print *, "Unknown error"
end select
end subroutine handle_error
function divide(a, b, result)
real :: a, b, result
integer :: err
if (b == 0) then
err = 1
call handle_error(err)
else
result = a / b
end if
end function divide
通过以上方法,可以实现简单的异常处理机制,但需要程序员自行管理异常状态和处理逻辑。在复杂的程序中,可以考虑使用现代化的编程语言或库来实现更灵活和强大的异常处理机制。