Java基础复习之一篇:关健字,标识符,注释,常量,进制转换,变量,数据类型,数据类型转换
1、关健字
1.1、被Java语言赋予特定意义的单词(如:class,interface,public ,static)
1.2、全部是小写
1.3、注意事项(goto和const作为关健字保留起来)
2、标识符
2.1、给类,接口,方法,变量起名字的字符
2.2、组成规则(A:英文大小写,B:数据,C:$ _)
2.3、注意事项(不能为数字开头,不能是java中的关健字,区分大小写)
2.4、常见的命名规则(见名知意)
A:包 全部是小写
单级包:小写 如:peng,com
多级包:小写 如:cn.hcc,ts.hnyj,com.baidu
B:类与接口:
一个单语:首字大写 如 Hello,Student
多个单词:每个单词首字大写 如HelloWorld,StudentName
C:方法与变量:
一个单词:首字小写 如name,main,get
多个单词:首字小写,从第二单词开始首字大写 如showAllStudents,getPersonName,className
D:常量: 全部大写
一个单词时:全部大写
多个单词时:多部大写同时每个单词之间用_分开 如 MAX_AGE
3、常量
3.1 在程序执行的过程中,其值不发生改变的量
3.2 分类:
3.2.1、字符串常量 "hello",
3.2.2、整数常量 12,23,
3.2.3、小数常量 12.33,
3.2.4、布尔常量 true,false
3.2.5、字符常量 'a','b'
3.2.6、空常量
3.3 在Java中针对整数常量提供了四种表现形式
A:二进制 以0,1组成,以0b开头
B:八进制 以0---7组成,以0开头
C:十进制 以0----9,整数默认是十进制
D:十六进制 以0----abcdef(大小写都可以)以0x开头
4、进制之间接转换
其它进制转换到十进制的方法是:
1112 = 1*10^3 + 1*10^2 + 1*10^1+2*10^0 = 1000+100+10+2 = 1112
0b00001010 = 1*2^3 + 1*2^0 = 8 + 2 = 10
02120 = 2*8^3 + 1*8^2 +1*8^1 = 1024+128+16 = 1104
0xa02 = 10*16^2+0+2*16^0 = 2560+2 = 2562
二进制到十进制的互转
0b10100100=128 64 32 16 8 4 2 0============128+32+4==========164(看位得值法)
十制转其它进制的方法:除基到商为0取余反转过来就是他的值
21转二进制:10101
5、变量与数据类型:
1、基本类型:4类8种 占用字节数(一个字节占8位)
1.1、整型:1.1.1 、 byte 1-------
1.1.2、 short 2
1.1.3、 int 4
1.1.4、 long 8
1.2、浮点型:
1.2.1、float 4
1.2.2、double 8
1.3、布尔 true/false 1
1.4、字符 char 2
注意:整数默认是int,浮点默认是double long定义时加L/l float 定义时加F/f
默认转换:是由小到大:byte char short(前三者不互相转换,是直接转换成int)---------->int------------>long------------->float-------->double
强制转换是由大到小:是默认反转过来可能丢失精度,一般不见建议
思考题:
float f1=12.36f 与float f2=(float)12.36;有区别?
下面的程序有问题吗?如果有,在哪里?
byte b1 = 3;
byte b2 = 4;
byte b3 = b1 + b2;------这里会有问题:因为两个变量相加首先转成int然后再加 int------->byte就会有问题
byte b4 = 3 + 4;----这个没有问题
下面的操作结果是什么?
byte b=(byte)130; -126要了解它的计算方法
130转成二进制是00000000 00000000 00000000 10000010-------->但由于是强转成byte 前面三位都将去掉只留
----------->最高是1说明是负数 存在计算机中是以补码的形式存在:所以是求负数的反,原码
反码:1----------->00000 01
原码:1---------->11111 10
再转换十进制:-64+32+16+8+4+2===-126
再练习一次:
byte tt =(byte)150 tt=-106
2、引用类型:类,接口,数组,字符串
3、记得三个字符的ASCII码: a=97 A=65 0=48 这样可以计算出很多值出来
4、思考题:字符串参与的运算
System.out.println("hello"+'a'+1);======helloa1
System.out.println('a'+1+"hello");======98hello
System.out.println("5+5="+5+5);======5+5=55
System.out.println(5+5+"=5+5");===== 10=5+5
6、补充知识:
计算机是以补码存在的,
正数的原,反,补码都是一样最高位是(0)
负数的原,反,补码不一样最高位是(1) 原到反直接取反,最高位不变 反到补最高位不变+1
Java基础复习之一篇:关健字,标识符,注释,常量,进制转换,变量,数据类型,数据类型转换的更多相关文章
- 2 Java基础语法(keyword,标识符,凝视,常量,进制转换,变量,数据类型,数据类型转换)
1:keyword(掌握) (1)被Java语言赋予特定含义的单词 (2)特点: 所有小写. (3)注意事项: A:goto和const作为保留字存在. B:类似于Notepad++这种高级记事本会对 ...
- C语言基础:进制转换,变量,常量,表达式,基本数据类型,输出函数,输入函数,运算符. 分类: iOS学习 c语言基础 2015-06-10 21:39 25人阅读 评论(0) 收藏
二进制:以0b开头,只有0和1两种数字.如0101 十进制:0~9十个数字表示.如25 十六进制:以0~9,A~F表示,以0X开头.如0X2B 十进制转换为X进制:连除倒取余 X进制转换为十进制:按权 ...
- Java基础复习笔记系列 七 IO操作
Java基础复习笔记系列之 IO操作 我们说的出入,都是站在程序的角度来说的.FileInputStream是读入数据.?????? 1.流是什么东西? 这章的理解的关键是:形象思维.一个管道插入了一 ...
- Java基础复习笔记系列 九 网络编程
Java基础复习笔记系列之 网络编程 学习资料参考: 1.http://www.icoolxue.com/ 2. 1.网络编程的基础概念. TCP/IP协议:Socket编程:IP地址. 中国和美国之 ...
- Java基础复习笔记系列 八 多线程编程
Java基础复习笔记系列之 多线程编程 参考地址: http://blog.csdn.net/xuweilinjijis/article/details/8878649 今天的故事,让我们从上面这个图 ...
- Java基础复习笔记系列 五 常用类
Java基础复习笔记系列之 常用类 1.String类介绍. 首先看类所属的包:java.lang.String类. 再看它的构造方法: 2. String s1 = “hello”: String ...
- Java基础复习笔记系列 四 数组
Java基础复习笔记系列之 数组 1.数组初步介绍? Java中的数组是引用类型,不可以直接分配在栈上.不同于C(在Java中,除了基础数据类型外,所有的类型都是引用类型.) Java中的数组在申明时 ...
- Java语法基础(一)----关键字、标识符、常量、变量
一.关键字: 关键字:被Java语言赋予特定含义的单词.组成关键字的字母全部小写.注:goto和const作为保留字存在,目前并不使用.main并不是关键字. 二.标识符: 标识符:就是给类,接口,方 ...
- Java基础复习笔记基本排序算法
Java基础复习笔记基本排序算法 1. 排序 排序是一个历来都是很多算法家热衷的领域,到现在还有很多数学家兼计算机专家还在研究.而排序是计算机程序开发中常用的一种操作.为何需要排序呢.我们在所有的系统 ...
随机推荐
- NEST.net Client For Elasticsearch简单应用
NEST.net Client For Elasticsearch简单应用 由于最近的一个项目中的搜索部分要用到 Elasticsearch 来实现搜索功能,苦于英文差及该方面的系统性资料不好找,在实 ...
- 【Binary Tree Maximum Path Sum】cpp
题目: Given a binary tree, find the maximum path sum. The path may start and end at any node in the tr ...
- 将通过find命令找到的文件拷贝到一个新的目录中
将通过find命令找到的文件拷贝到一个新的目录中 有这样的一个需求,需要将一部分符合条件的文件从一个目录拷贝到另一个目录中,我通过find命令从源目录查找到符合条件的文件然后使用cp命令拷贝到目标目录 ...
- bzoj 2821 分块处理
大题思路就是分块,将n个数分成sqrt(n)个块,然后 处理出一个w数组,w[i,j]代表第i个块到第j个块的答案 那么对于每组询问l,r如果l,r在同一个块中,直接暴力做就行了 如果不在同一个块中, ...
- hdu 1533 Going Home 最小费用最大流
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1533 On a grid map there are n little men and n house ...
- depthstencil buffer 不支持 msaa
phyreengine dx11 MRT不支持 depth rendertarget 的msaa 他里面竟然只写着,// not supported yet !!!! 导致hdao 时开msaa的话, ...
- Codeforces Round #253 (Div. 2) D题
题目大意是选出一个其他不选,问问最大概率: 刚开始想到DP:F[I][J][0]:表示从 前I个中选出J个的最大值, 然后对于F[I][J][1]=MAX(F[I-1][J][1],F[I-1][J- ...
- vi编辑
保存命令 按ESC键 跳到命令模式,然后: :w 保存文件但不退出vi :w file 将修改另外保存到file中,不退出vi :w! 强制保存,不推出vi :wq 保存文件并退出vi :wq! 强制 ...
- 非阻塞式JavaScript脚本介绍
JavaScript 倾向于阻塞浏览器某些处理过程,如HTTP 请求和界面刷新,这是开发者面临的最显著的性能问题.保持JavaScript文件短小,并限制HTTP请求的数量,只是创建反应迅速的网页应用 ...
- Unity3d之音效播放和调用手机震动
http://blog.csdn.net/sunshine_1984/article/details/12943979 今天研究了下Unity3d音效播放相关内容,整理下实现细节. 1,添加音效文件到 ...