java基础语法二
2013-10-30 21:33
288 查看
标识符问题。
1、不能用数字开头
2、不能使用关键字
不能使用关键字很明显是因为禁用,而数字是因为
如果某一种语言的编译器使用了自顶向下的语法分析,那么为了分析效率,产生式的正交性是必须保证的,那么,这种语言的编译器就不能有两种不同的语法符合以相同类型的字符开头。
其实,不是所有语言的变量名,或者更准确的称之为标识符,都不可以以数字开头,在一门很古老的语言LISP中就是可以的。这个问题,@张正雄 同学给出来了一个以前回答过的答案,但是那个回答中的答案是片面的。
====================================================
我一开始也认为是和歧义有关系,后来知道LISP是允许这样类型的变量的,然后就试图去推导,发现数字开头的标识符并不会产生影响,能够对编译产生影响的只有一种情况。所以,能不能使用数字开头的变量名,取决与分析方法。
我画了上面这个图,如果是自底向上的分析(LR)的话,标识符是否以数字开头,并不会增加算法的复杂度,按照这个状态图一路走过去,走到什么就是什么,数字和标识符完全可以区分。也就是说,语法完全可以定义以数字开头的标识符而不产生任何的歧义。
但是,如果采用自顶向下的分析(LL)的话,就不可以了。LL分析为了保证效率,进行无回溯的语法分析,有一个要求,就是对于某一个非终结符的所有产生式,他们的FIRST集必须正交,也就是,他们的开头的符号必须不相同。所以,如果某一种语言的编译器使用了自顶向下的语法分析,那么为了分析效率,产生式的正交性是必须保证的,那么,这种语言的编译器就不能有两种不同的语法符合以相同类型的字符开头。早期的一些语言,甚至还有标识符的开头不能包含关键字(比如,dodoro可能会是一个非法的标识符,因为开头包含了关键字do)。
现在,我们知道大部分语言的编译器是使用CLR或者LALR方法进行语法分析的,所以这种影响效率的问题是不存在的。但是,同@倪玉哲 所说的情况,C语言里面类似「2L」这样的长整型立即数的定义可能会产生歧义,是不使用数字开头的标识符的主要原因。
===============================================================
常量
字符常量 要用单引号''
字符串常量用双引号" "
进制
八进制 0-7 以0开头
十六进制 0x开头,0-9 A-F
数值转换
十进制 728 = 7*10(2) +2*10(1) +8*10(0) =728
二进制转化为 10进制
1 0 1 0 1 1
32 16 8 4 2 1
记住每个有效位置的数值 当非0的时候可以相加所以 101011 = 32+8+2+1 = 44。
二进制转化为八进制
101111 每三位转为十进制数
101 111
5 7
所以八进制是057
转化为十六进制
0010 1111
2 15
所以16进制是0x2F
1、八进制即每三位个二进制变成10进制,然后在前面加个0
2、十六进制既每四位变为10进制,然后在前面加0x
十进制变为二进制,除以2取余
二进制转化为十进制,乘以2的幂
把6不断除以2,然后从最小的余数拼成110。
负数的二进制取反加1。
以6为例
0000-0000 0000-0000 0000-0000 0000-0110 取反
1111-1111 1111-1111 1111-1111 1111-1001 加1
1111-1111 1111-1111 1111-1111 1111-1010 为-6
内存中1开头的为负数。
byte b = 3
b = b+200; //这个不能通过编译。200默认是int
而如果通过强制转换,会被截断b =(byte) (b+200) = -57
1、不能用数字开头
2、不能使用关键字
不能使用关键字很明显是因为禁用,而数字是因为
如果某一种语言的编译器使用了自顶向下的语法分析,那么为了分析效率,产生式的正交性是必须保证的,那么,这种语言的编译器就不能有两种不同的语法符合以相同类型的字符开头。
其实,不是所有语言的变量名,或者更准确的称之为标识符,都不可以以数字开头,在一门很古老的语言LISP中就是可以的。这个问题,@张正雄 同学给出来了一个以前回答过的答案,但是那个回答中的答案是片面的。
====================================================
我一开始也认为是和歧义有关系,后来知道LISP是允许这样类型的变量的,然后就试图去推导,发现数字开头的标识符并不会产生影响,能够对编译产生影响的只有一种情况。所以,能不能使用数字开头的变量名,取决与分析方法。
我画了上面这个图,如果是自底向上的分析(LR)的话,标识符是否以数字开头,并不会增加算法的复杂度,按照这个状态图一路走过去,走到什么就是什么,数字和标识符完全可以区分。也就是说,语法完全可以定义以数字开头的标识符而不产生任何的歧义。
但是,如果采用自顶向下的分析(LL)的话,就不可以了。LL分析为了保证效率,进行无回溯的语法分析,有一个要求,就是对于某一个非终结符的所有产生式,他们的FIRST集必须正交,也就是,他们的开头的符号必须不相同。所以,如果某一种语言的编译器使用了自顶向下的语法分析,那么为了分析效率,产生式的正交性是必须保证的,那么,这种语言的编译器就不能有两种不同的语法符合以相同类型的字符开头。早期的一些语言,甚至还有标识符的开头不能包含关键字(比如,dodoro可能会是一个非法的标识符,因为开头包含了关键字do)。
现在,我们知道大部分语言的编译器是使用CLR或者LALR方法进行语法分析的,所以这种影响效率的问题是不存在的。但是,同@倪玉哲 所说的情况,C语言里面类似「2L」这样的长整型立即数的定义可能会产生歧义,是不使用数字开头的标识符的主要原因。
===============================================================
常量
字符常量 要用单引号''
字符串常量用双引号" "
进制
八进制 0-7 以0开头
十六进制 0x开头,0-9 A-F
数值转换
十进制 728 = 7*10(2) +2*10(1) +8*10(0) =728
二进制转化为 10进制
1 0 1 0 1 1
32 16 8 4 2 1
记住每个有效位置的数值 当非0的时候可以相加所以 101011 = 32+8+2+1 = 44。
二进制转化为八进制
101111 每三位转为十进制数
101 111
5 7
所以八进制是057
转化为十六进制
0010 1111
2 15
所以16进制是0x2F
1、八进制即每三位个二进制变成10进制,然后在前面加个0
2、十六进制既每四位变为10进制,然后在前面加0x
十进制变为二进制,除以2取余
二进制转化为十进制,乘以2的幂
把6不断除以2,然后从最小的余数拼成110。
负数的二进制取反加1。
以6为例
0000-0000 0000-0000 0000-0000 0000-0110 取反
1111-1111 1111-1111 1111-1111 1111-1001 加1
1111-1111 1111-1111 1111-1111 1111-1010 为-6
内存中1开头的为负数。
byte b = 3
b = b+200; //这个不能通过编译。200默认是int
而如果通过强制转换,会被截断b =(byte) (b+200) = -57
相关文章推荐
- JAVA入门[11]-jsp几点基础语法
- java基础语法要点<一>(基于1.8)
- Java基础语法
- java基础语法(二)
- Java基础语法<八> 继承 多态 抽象 反射
- Java基础语法(一)---数据、数值类型、运算符、程序流程控制语句和循环结构
- 黑马程序员 ---- java基础之基本语法
- Java基础语法
- 第一章 –– Java基础语法
- Java基础语法(五)----面向对象(2) 继承
- 第二章:Java语言的基础语法
- Java语法基础练习题
- day01---Java基础语法--计算机知识点
- 一、Java的基础语法
- 黑马程序员——java基础语法
- Java私塾跟我学系列――JAVA篇 第二章 基础语法 作业
- Java语法基础看这篇就够了
- Java基础学习之Java基本语法(1)【Java命名规范+程序执行过程】
- JavaSE复习之一 基础知识:Java的基础语法
- 黑马程序员----java基础语法笔记(函数、重载、数组)(下)