- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要把implicit none
在每个函数和子程序中?
或者把它放在包含这些函数和子程序的模块的开头就足够了吗?
或者将它放在使用这些模块的程序的开头就足够了吗?
观察其他人的工作代码,implicit none
包含在所有这些地方。我不确定这是否是多余的,因为删除 implicit none
from 子程序仍然编译并产生相同的输出。
顺便说一句,我正在使用 gfortran fortran 90
.
最佳答案
implicit
声明(包括 implicit none
)适用于范围单元。这样的事情被定义为
BLOCK construct, derived-type definition, interface body, program unit, or subprogram, excluding all nested scoping units in it
implicit none
在模块中定义的每个函数和子例程(统称为过程)中。但是,包含在模块中的过程内部有一个基于主机范围单元的默认映射。因此,使用
implicit none
在模块中,没有必要在包含的过程中包含它。
implicit none
在主程序中涵盖了其中包含的所有程序;这同样适用于模块过程的内部程序。 block 结构也可以看到这个,
implicit
其中之一甚至不允许声明。
use
的程序/其他模块继承它。他们。这显然是有道理的,因为隐式类型必须在编译时知道,并且无论其最终用途如何,都必须明确定义。
implicit none
use somemodule
end program
一个
implicit
声明必须遵循所有
use
陈述。
implicit
在子模块的范围内声明默认规则将在那里应用。
module mod
implicit none
interface
subroutine external_sub()
! The default implicit typing rules apply here unless
! there is an implicit statement, such as implicit none.
! Those from the module aren't in force here.
end subroutine
end interface
end module
关于删除
implicit none
的测试来自子程序:如果代码对
implicit none
有效那么它必须是有效的并且没有那个声明是相同的。在前一种情况下,所有实体都必须显式声明,因此在后一种情况下不会应用隐含规则。
关于fortran - 在 Fortran 中将 `implicit none` 放在哪里,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24337413/
这是我的查询: INSERT INTO location_province(name, country) SELECT child.name ,location_country.id
尽管我看到 C++ 教程中广泛使用术语 implicit casting 来表示这样一个事实,即当您将某种类型分配给另一种类型时,类型的转换将自动(隐式)完成,但我经常听说应该叫implicit co
所有表格都在 utf_unicode_ci 中。 我这样做是为了检查 SELECT table_schema, table_name, column_name, character_set_name,
def MyFun(result: ListBuffer[(String, DateTime, List[(String, Int)])]): String = { val json = (r
我刚刚在 Postgres 中创建了一个表,并收到一条通知消息,我不完全理解隐式索引和序列。如有任何澄清,我们将不胜感激。 my_database=# CREATE TABLE sites my_da
我正在关注 Fernando Villalobos 的 React.js - A guide for Rails developers AirPair 教程。 这里的目标是使用 Rails 和 Rea
当我选择一个选项时,我有通过多选列表在 dbase 中搜索的代码我有这个错误: Illegal mix of collations (utf8_general_ci,IMPLICIT) and (ut
我正在尝试使用 execl 调用来执行 kernel-space-driver (driver.c) 中的二进制文件此时(从第 850 行开始): if (!retval) {
我正在尝试在内核 3.13 上编译内核模块,但出现此错误: error: implicit declaration of function 'create_proc_read_entry' [-Wer
我检查了数据库表,发现它在 latin1_swedish_ci 中,所以我将其更改为 utf8_general_ci 然后我将排序规则从 latin1_swedish_ci 更改到所有字段的 utf8
尝试通过 MySQL 中的存储过程进行选择时出现以下错误 Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_ge
我收到了这个错误; Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT)
我需要您帮助确定为什么会出现此错误 Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT
我收到了这个错误; Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT)
MySql 上的错误信息: Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) fo
在我的删除服务器上执行 MySQL 中的存储过程时,如下所示: CREATE OR REPLACE PROCEDURE `SetNextPage`( IN `inRefNo` varchar(
我正在尝试为 Kali linux 2.0 安装我的 Alfa AWUS036ACH 适配器 我已经修复了之前的错误,但现在我被困在这里了。这是错误我正在接收。 os_dep/linux/rtw_an
我们正在使用以下存储过程,并且所有提到的表都使用“Collation = utf8_general_ci”,但我们仍然收到此错误: Error Code: 1267. Illegal mix of
我想让我的 User 表的 password 列在 mysql 中区分大小写。 表的说明如下: /*Table: mst_user*/ FIELD TYPE
我对这一切都很陌生,正在尝试在内核版本为 3.10.0-957.el7.x86_64 的虚拟机上编译程序。但我收到此错误: /home/../../../isr_demux.c: In functio
我是一名优秀的程序员,十分优秀!