❶ C 语言怎么判断传入数据的类型
通过约定参数类型或者约定参数格式,确定传入数据的类型。
1、 大多数情况下,参数类型都是确定的,在函数定义时就可以确定类型。此种情况下,不需要函数本身判断,编译器会做判断或转换。
如
voidfunc(intn);
声明这样的函数,参数为int型,当调用时如果实参不是int型,C编译器会尝试转换为int型,如果转换失败,则编译报错。
2、 对于参数个数和类型不确定的情况,也就是不定参数形式,一般增加一个格式字符串,通过格式字符串解析后续有几个参数,每个类型是什么。
典型例子为printf:
intprintf(constchar*fmt,...);
在printf中,后续参数类型及个数都是不确定的,printf会根据参数fmt中包含的格式字符串,来确定后续的参数类型。 比如传入fmt为"%s%d%lu",那么printf就会尝试在后续参数中读取三个值,类型分别为char *, int,和unsigned long。
除此外,也可以采用其他方式进行约定。
❷ 要怎么判断什么时候用什么数据类型
2.各种数据类型介绍
2.1整型
整形包括短整型、整形和长整形。
2.1.1短整形
short a=1;
2.1.2整形
一般占4个字节(32位),最高位代表符号,0表示正数,1表示负数,取值范围是-2147483648~2147483647,在内存中的存储顺序是地位在前、高位在后,例如0x12345678在内存中的存储如下:
地址:
数据:78563412
定义:用int关键字,举例如下:
int a=6;
2.1.3长整形
long a=10;
2.2浮点型
浮点型包括单精度型和双精度型。
2.2.1单精度型
浮点型,又称实型,也称单精度。一般占4个字节(32位),
float a=4.5;
地址:
数据:00009040
2.2.2双精度型
一般占8个字节(64位)
doublea=4.5;
地址:
数据:0000000000001240
2.3字符类型
在各种不同系统中,字符类型都占一个字节(8位)。定义如下:
char c='a';
也可以用字符对应的ASCII码赋值,如下:
char c=97;
3.数据类型与“模子”
short、int、long、char、float、double 这六个关键字代表C 语言里的六种基本数据类型。
怎么去理解它们呢? 举个例子:见过藕煤球的那个东西吧?(没见过?煤球总见过吧)。那个东西叫藕煤器,拿着它在和好的煤堆里这么一咔,一个煤球出来了。半径12cm,12 个孔。不同型号的藕煤器咔出来的煤球大小不一样,孔数也不一样。这个藕煤器其实就是个模子。
现在我们联想一下,short、int、long、char、float、double 这六个东东是不是很像不同类型的藕煤器啊?拿着它们在内存上咔咔咔,不同大小的内存就分配好了,当然别忘了给它们取个好听的名字。
在32 位的系统上short 咔出来的内存大小是2 个byte;
int 咔出来的内存大小是4 个byte;
long 咔出来的内存大小是4 个byte;
float 咔出来的内存大小是4 个byte;
double 咔出来的内存大小是8 个byte;
char 咔出来的内存大小是1 个byte。
(注意这里指一般情况,可能不同的平台还会有所不同,具体平台可以用sizeof 关键字测试一下)
很简单吧?咔咔咔很爽吧?是很简单,也确实很爽,但问题就是你咔出来这么多内存块,你总不能给他取名字叫做x1,x2,x3,x4,x5…或者长江1
号,长江2
号…吧。它们长得这么像(不是你家的老大,老二,老三…),过一阵子你就会忘了到底哪个名字和哪个内存块匹配了(到底谁嫁给谁了啊?^_^)。所以呢,给
他们取一个好的名字绝对重要。下面我们就来研究研究取什么样的名字好。
4.变量的命名规则
1)命名应当直观且可以拼读,可望文知意,便于记忆和阅读。
标识符最好采用英文单词或其组合,不允许使用拼音。程序中的英文单词一般不要太复杂,用词应当准确。
2)命名的长度应当符合“min-length && max-information”原则。
C 是一种简洁的语言, 命名也应该是简洁的。例如变量名MaxVal 就比MaxValueUntilOverflow 好用。标识符的长度一般不要过长,较长的单词可通过去掉“元音”形成缩写。
另外,英文词尽量不缩写,特别是非常用专业名词,如果有缩写,在同一系统中对同一单词必须使用相同的表示法,并且注明其意思。
3)当标识符由多个词组成时,每个词的第一个字母大写,其余全部小写。比如:
int CurrentVal;
这样的名字看起来比较清晰,远比一长串字符好得多。
4)尽量避免名字中出现数字编号,如Value1,Value2 等,除非逻辑上的确需要编号。比如驱动开发时为管脚命名,非编号名字反而不好。
初学者总是喜欢用带编号的变量名或函数名,这样子看上去很简单方便,但其实是一颗颗定时炸弹。这个习惯初学者一定要改过来。
5)对在多个文件之间共同使用的全局变量或函数要加范围限定符(建议使用模块名(缩写)作为范围限定符)。
(GUI_ ,etc)标识符的命名规则:
6)标识符名分为两部分:规范标识符前缀(后缀) + 含义标识。非全局变量可以不用使用范围限定符前缀。
❸ vb 中判断数据类型
VB可使用TypeName 函数来判断某变量的数据类型。
TypeName 函数,返回一个 String,提供有关变量的信息。
TypeName 函数示例
本弯缓示例让档使用 TypeName 函数返回有关变量的信息。
' 声明变量。
Dim NullVar, MyType, StrVar As String, IntVar As Integer, CurVar As Currency
Dim ArrayVar (1 To 5) As Integer
NullVar = Null ' 设置变量值为 Null。
MyType = TypeName(StrVar) ' 返回 "String"。
MyType = TypeName(IntVar) ' 返回 "Integer"。
MyType = TypeName(CurVar) ' 返回 "Currency"。
MyType = TypeName(NullVar) ' 返回 "Null"。
MyType = TypeName(ArrayVar) '坦闹乱 返回 "Integer()"。
❹ c语言需要定义数据类型,那怎么判断定义什么数据类型
根据自己需要保存的数据是什么性质来选择合适的变量类型。如果需要保存的是字符,那么就选用char类型,如果是一串字符,比方说用来保存姓名或者密码等等,那么就可以选用char数组。如果保存的数据没有小数,那么就可以选用int类型,在32位的编译系统下,int类型可以保存,绝对值不大于21亿的整数。如果是带有小数的数据,那么就需要选用浮点型,float类型可以保存最多有七位有效数据,doubld类型,最多可以保存有15位有效数字。如果保存的数据只有是和否两种可能,那么可以选用bool类型。