1.eclipse什么时候编译java类文件

2.在同一包中的类可以相互引用,无需用import语句

3.在Java eclipse用ALT输入特殊符号

4.if else等语句,什么时候可以不加括号

5.HashMap桶中链表转红黑树为什么选择数字8,hashcode 用数字31?

6.++i和i++的区别

7.nanoTime vs currentTimeMillis 比较

8.JAVA import静态类的方法import static java.lang.System.out

9.Java import的作用

1.eclipse什么时候编译java类文件

1)第一次创建类的时候会编译一次

2) 每次修改了这个文件保存之后会编译一次

2.在同一包中的类可以相互引用,无需用import语句

(1)引入包中的类(如果我们只想引入某个包中的类)
import java.io.File;
(2)引入整个包

  import java.io.*;(①这样虽然方便,但是当导入包中所有的类时,java编译器就会用额外的内存来存储包中类和方法的名字,以便跟踪这个包中所有的元素,这在pc机上没有太大的性能差异。然而当在手持设备上,一般的手持设备内存都比较小,这种方式就不太好了,更适合第一种方式想引用哪个类就具体引用哪个②当通过网络远程加载一个类时,如果它导入了一包中所有的类,那么在加载的时候就会把所有的类和方法加载到本地来,这就会造成java程序执行时间上的延迟。所以只有当需要导入这个包中很多类的时候,再用这种方式。)
(3)在同一包中的类可以互相引用,无需import语句(非要手动加入也不会报错)
 注意:java.lang包是自动引入的,不需要显式的加import引入。因此可以直接引用System、String

3.在Java eclipse代码注释后如何输入n的3次方,就是n的右上角的数字3如何写上出?

平方的输入是按住alt后不放,依次按小键盘上的178三个键,放开所有按键,就会得到² 同样,立方还是上面的方法,按小键盘上的179

扩展:详见:https://www.cnblogs.com/lukelook/p/6840113.html#t4

4.if else等语句,什么时候可以不加括号

今天在写代码的时候无意间发现了 if 和 else 后面不用带括号

if (Boolean)
true
else
false

有大括号的时候
大括号里面所有的 都归if管。只有条件为真的时候 才会执行。
没有大括号的时候 只有下面的一句归if管,

也就是说 当只有一句的时候 大括号可以省略 其它的 没区别。

这种情况,没多久就忘了,再记录一次,加深印象。不然读代码的时候让人很疑惑。

今天分享这个就是想到java规范里面很多都有if后面即使一句都要使用大括号,不只是直观,很多时候能帮我们避免很多错误。以后编程一定要尽量根据规范进行。

看如下代码:

案例1:

if(Character.isLowerCase(c))
if(count[c-'a']==1)
return i;
else
if(count[c-'A'+26]==1)
return i;

预期的执行效果

if(Character.isLowerCase(c)){
if(count[c-'a']==1)
return i;
}
else{
if(count[c-'A'+26]==1)
return i;
}

而其实编译后为

if(Character.isLowerCase(c))
if(count[c-'a']==1)
return i;
else
if(count[c-'A'+26]==1)
return i;

案例2:

if (status == null)
x=1;y=2;z=3;

预期的执行效果

if (status == null){
x=1;y=2;z=3;
}

而实际编译后为

if (status == null)
{ x=1};
y=2;
z=3;

所以说,为了防止类似错误发生,以后一律统统按规范加括号,这样就OK了

5.HashMap桶中链表转红黑树为什么选择数字8,hashcode 用数字31?

.在JDK8及以后的版本中,HashMap引入了红黑树结构,其底层的数据结构变成了数组+链表或数组+红黑树。添加元素时,若桶中链表个数超过8,链表会转换成红黑树。之前有写过篇幅分析选择数字8的原因,觉得不够严谨。最近重新翻了一下HashMap的源码,发现其源码中有这样一段注释:

Because TreeNodes are about twice the size of regular nodes, we use them only when bins contain enough nodes to warrant use (see TREEIFY_THRESHOLD). And when they become too small (due to removal or resizing) they are converted back to plain bins. In usages with well-distributed user hashCodes, tree bins are

rarely used. Ideally, under random hashCodes, the frequency of nodes in bins follows a Poisson distribution (http://en.wikipedia.org/wiki/Poisson_distribution) with a parameter of about 0.5 on average for the default resizing threshold of 0.75, although with a large variance because of resizing granularity. Ignoring variance, the expected occurrences of list size k are (exp(-pow(0.5, k) / factorial(k)). The first values are:

0: 0.60653066

1: 0.30326533

2: 0.07581633

3: 0.01263606

4: 0.00157952

5: 0.00015795

6: 0.00001316

7: 0.00000094

8: 0.00000006

more: less than 1 in ten million

翻译过来大概的意思是:理想情况下使用随机的哈希码,容器中节点分布在hash桶中的频率遵循泊松分布(具体可以查看http://en.wikipedia.org/wiki/Poisson_distribution),按照泊松分布的计算公式计算出了桶中元素个数和概率的对照表,可以看到链表中元素个数为8时的概率已经非常小,再多的就更少了,所以原作者在选择链表元素个数时选择了8,是根据概率统计而选择的。

为什么在定义hashcode时要使用31这个数呢?

散列计算就是计算元素应该放在数组的哪个元素里。准确的说是放到哪个链表里面。按照Java的规则,如果你要想将一个对象放入HashMap中,你的对象的类必须提供hashcode方法,返回一个整数值。

https://blog.csdn.net/HNUST_LIZEMING/article/details/88709589

https://blog.csdn.net/steveguoshao/article/details/12576849

6.++i 和 i++的区别

前者先自增再使用,

后者先使用再自增;

public class ClassTest {

    public static void main(String[] args) {
// TODO Auto-generated method stub
int i = 0;
int j = 0; System.out.println(++i);
System.out.println(j++);
    System.out.println(j);
     
} }

输出结果为

1
0
1

另外 i++ (i = i + 1)不是原子操作,而 i = 1 是原子操作。

7.nanoTime vs currentTimeMillis 比较

1.currentTimeMillis返回的是系统当前时间和1970-01-01之前间隔时间的毫秒数,如果系统时间固定则方法返回值也是一定的(这么说是为了强调和nanoTime的区别),精确度是毫秒级别的;

nanoTime的返回值本身则没有什么意义,因为它基于的时间点是随机的,甚至可能是一个未来的时间,所以返回值可能为负数。但是其精确度为纳秒,相对高了不少。

2.currentTimeMillis不仅可以用来计算代码执行消耗的时间 ,也可以和Date类方便的转换。而nanoTime则不行
可以这么说吧,currentTimeMillis是一个时钟,而nanoTime是一个计时器,你可以用时钟来计算时间差,也可以用来单纯的看时间,但是作为计时器的nanoTime则只能用来计算时间差,好在优点是精确度高

3.currentTimeMillis是基于系统时间的,也就是说如果你再程序执行期间更改了系统时间则结果就会出错,而nanoTime是基于CPU的时间片来计算时间的,无法人为干扰
前面说了nanoTime基于的时间点是随机的,但是对于同一个JVM里,不同地方使用到的基点时间是一样的

此方法只能用于测量已过的时间,与系统或钟表时间的其他任何时间概念无关。返回值表示从某一固定但任意的时间算起的毫微秒数(或许从以后算起,所以该值可能为负)。此方法提供毫微秒的精度,但不是必要的毫微秒的准确度。它对于值的更改频率没有作出保证。在取值范围大于约 292 年(263 毫微秒)的连续调用的不同点在于:由于数字溢出,将无法准确计算已过的时间。

public class ClassTest {

    public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("Test for currentTimeMillis");
for (int i = 0; i < 5; i++) {
System.out.println(i + " : " + System.currentTimeMillis());
} System.out.println("Test for nanoTime");
for (int i = 0; i < 5; i++) {
System.out.println(i + " : " + System.nanoTime());
} } }

输出结果

Test for currentTimeMillis
0 : 1588297108093
1 : 1588297108093
2 : 1588297108093
3 : 1588297108094
4 : 1588297108094
Test for nanoTime
0 : 10509981773594
1 : 10509981950048
2 : 10509982119115
3 : 10509982337424
4 : 10509982888533

8.JAVA import静态类的方法import static java.lang.System.out; 

java。System.out.print(); 能够通过使用import来省略System甚至是System.out吗?

import static java.lang.System.out; // 静态导入System类的 out 静态属性

import static java.lang.System.*; // 静态导入System类内的所有静态成员 以上都能省略“System”,调用时只需这样写:
out.println();

9.Java import的作用

详见:java中import作用详解:https://blog.csdn.net/qq_25665807/article/details/74747868

java基础点的更多相关文章

  1. java基础点总结

    基础知识这种东西,没注意到的永远比想象中多.大部分都是在面试中问到的... 1.static关键字 变量,方法修饰;静态代码块;静态内部类; 静态导入:import static ,静态方法省略类名, ...

  2. 需要了解的几个Java基础点

    关键字 native:表示要调用非Java语言写函数,比如用C语言使用JNI实现的接口.比如windows环境的dll文件.举例:Object.hashcode() 位运算 << n:左移 ...

  3. java基础点<一>

    1. 九种基本数据类型的大小,以及他们的封装类.byte,short,int,long,boolue,float,double,char,特殊voidByte,Short,Integer,Long,B ...

  4. Java学习---面试基础知识点总结

    Java中sleep和wait的区别 ① 这两个方法来自不同的类分别是,sleep来自Thread类,和wait来自Object类. sleep是Thread的静态类方法,谁调用的谁去睡觉,即使在a线 ...

  5. Java如何打好牢固的基础?

    如果纯粹是为了学Java,那么不建议阅读本文,因为本文不是从理论和教科书的角度讲述如何打好java基础,而是会从"快速用java挣钱"这个角度,讲边学.边做项目和边提升的方法. 在 ...

  6. spring-retry的简单使用

    添加Maven依赖: <dependency> <groupId>org.springframework.retry</groupId> <artifactI ...

  7. Spark案例分析

    一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...

  8. Java虚拟机垃圾回收:基础点(转载)

    1.Java虚拟机垃圾回收 垃圾回收,或称垃圾收集(Garbage Collection,GC)是指自动管理回收不再被引用的内存数据. 在1960年诞生于MIT的Lisp语言首次使用了动态内存分配和垃 ...

  9. java类及编写public类的基础点

    1.一个java文件中只能有一个public类.且公共类名称必须与java文件名一致,否则会出现错误提示.与其他面向对象编程语言的一样,在利用java分析问题时,基本思路即为将问题的属性(静)与行为( ...

随机推荐

  1. source insight 使用配置(私人)

    1.输入两个空格,两个空格全消失,前后的字粘在一起显示,不想这样,就取消下图的勾.

  2. k8s版jenkins--master/slave模式实现CI/CD---带solo开源博客项目--带maven、djk、git工具

    k8s环境: 192.168.0.91 master 192.168.0.92 node 192.168.0.96 gitlab 192.168.0.98 harbor k8s集群安装请参照:http ...

  3. 阿里nacos k8s部署

    阿里nacos k8s部署 [root@master1 nacos]# cat nacos-quick-start.yaml --- apiVersion: v1 kind: Service meta ...

  4. vmware linux 硬盘空间不足时增加硬盘并挂载

    不同的版本的vmware在设置界面中可能稍有不同,基本是一致的. 还有一种方式是扩展,这里没有记录,扩展时需要在虚拟机关机状态下. 1.选择在vmware中点击设置并打开,将光标定位在hard Dis ...

  5. LeetCode 94. 二叉树的中序遍历(Binary Tree Inorder Traversal)

    94. 二叉树的中序遍历 94. Binary Tree Inorder Traversal 题目描述 给定一个二叉树,返回它的 中序 遍历. LeetCode94. Binary Tree Inor ...

  6. SCI-hub使用技巧(下载外文文献)

    下载外文文献方法指南: (1)首先查找需要下载文献的DOI (2)在Sci-Hub主页搜索框输入URL.DOI或者PMID. (3)点击open即可看见下载界面. 参考文献:https://mp.we ...

  7. 定时任务-C#线程类 windows服务

    原理 最常用的就是C#中 timer类写一个定时方法,然后在把他宿主到windows服务里面. C#中Timer分类 关于C# Timer类  在C#里关于定时器类就有3个 C# Timer使用的方法 ...

  8. Springmvc在项目启动时查询数据库并初始化静态变量

    private static List<ResourceEntity> resourceList = null; //初始化的全局静态变量 @Autowired private Resou ...

  9. SpringBoot中使用@Scheduled创建定时任务

    SpringBoot中使用@Scheduled创建定时任务 定时任务一般会在很多项目中都会用到,我们往往会间隔性的的去完成某些特定任务来减少服务器和数据库的压力.比较常见的就是金融服务系统推送回调,一 ...

  10. Redis--zset类型操作命令

    有序集合类型 zset (sorted set ) redis 有序集合zset和集合set一样也是string类型元素的集合,且不允许重复的成员. 不同的是 zset 的每个元素都会关联一个分数(分 ...