刚刚看fortran语言,发现定义的时候有时用::有时用空格,有时两个都可以,有时只能用::,很不明白,它们有什么区别呢?谢谢
双冒号有两个用途,第一就像一楼说的,定义类型的同时赋值。
第二就是定义类型的同时声明各种属性,比如:
integer,dimension(2,2),save::a
real,dimension(:),allocatable::b
此时不可以用空格。
双冒号是Fortran90标准引入的,是比较规范的新写法。当然,空格的写法也是兼容的。如果你不是维护Fortran77的旧程序,还是坚持用新写法比较好。
第二就是定义类型的同时声明各种属性,比如:
integer,dimension(2,2),save::a
real,dimension(:),allocatable::b
此时不可以用空格。
双冒号是Fortran90标准引入的,是比较规范的新写法。当然,空格的写法也是兼容的。如果你不是维护Fortran77的旧程序,还是坚持用新写法比较好。
温馨提示:答案为网友推荐,仅供参考
第1个回答 2010-10-23
用::时可以给变量赋初值,如
integer::a=2
至于::前后有多少空格时无所谓的。
但,单纯的空格时不能赋初值,如
integer a=2是错的。
integer::a=2
至于::前后有多少空格时无所谓的。
但,单纯的空格时不能赋初值,如
integer a=2是错的。
第2个回答 2015-08-04
冒号(:)用法
(1)表示机构内位域的定义(即该变量占几个bit空间)
typedef struct _XXX{
unsigned char a:4;
unsigned char c;
} ; XXX
双冒号(::)用法
(1)表示“域操作符”
例:声明了一个类A,类A里声明了一个成员函数void f(),但没有在类的声明里给出f的定义,那么在类外定义f时,
就要写成void A::f(),表示这个f()函数是类A的成员函数。
(2)直接用在全局函数前,表示是全局函数
例:在VC里,你可以在调用API 函数里,在API函数名前加::
(3)表示引用成员函数及变量,作用域成员运算符
例:System::Math::Sqrt() 相当于System.Math.Sqrt()
::是“作用域分解运算符”。比如声明了一个类A,类A里声明了一个成员函数voidf(),但没有在类的声明里给出f的定义,那么在类外定义f时,就要写成voidA::f(),表示这个f()函数是类A的成员函数。
:: 一般还有一种用法,就是直接用在全局函数前,表示是全局函数。当类的成员函数跟类外的一个全局函数同名时,考试,大提示在类内定义的时候,打此函数名默认调用的是本身的成员函数;如果要调用同名的全局函数时,就必须打上::以示区别。比如在VC里,你可以在调用API函数时,在API函数名前加::。
(1)表示机构内位域的定义(即该变量占几个bit空间)
typedef struct _XXX{
unsigned char a:4;
unsigned char c;
} ; XXX
双冒号(::)用法
(1)表示“域操作符”
例:声明了一个类A,类A里声明了一个成员函数void f(),但没有在类的声明里给出f的定义,那么在类外定义f时,
就要写成void A::f(),表示这个f()函数是类A的成员函数。
(2)直接用在全局函数前,表示是全局函数
例:在VC里,你可以在调用API 函数里,在API函数名前加::
(3)表示引用成员函数及变量,作用域成员运算符
例:System::Math::Sqrt() 相当于System.Math.Sqrt()
::是“作用域分解运算符”。比如声明了一个类A,类A里声明了一个成员函数voidf(),但没有在类的声明里给出f的定义,那么在类外定义f时,就要写成voidA::f(),表示这个f()函数是类A的成员函数。
:: 一般还有一种用法,就是直接用在全局函数前,表示是全局函数。当类的成员函数跟类外的一个全局函数同名时,考试,大提示在类内定义的时候,打此函数名默认调用的是本身的成员函数;如果要调用同名的全局函数时,就必须打上::以示区别。比如在VC里,你可以在调用API函数时,在API函数名前加::。