java中一些关键字的区别_第1页
java中一些关键字的区别_第2页
免费预览已结束,剩余5页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

个人收集整理-ZQjava中一些关键字的区别一、让我们来看,、三者,在中的区别:在中:表示大于,如:().结果是类型表示右移,如: ; 的结果是,移出的部分将被抛弃。转为二进制的形式可能更好理解, ()右移位的结果是 (), ()右移位的结果是 ()。叫什么我也不是很清楚,但是我知道它表示的含义: 与 ()()的结果相同,其中和是整形。测试代码如下:1. 2. 3. () 4. 5. (、以下测试:); 6. ,; 7. (); 8. (、以下测试:); 9. (); 10. (、以下测试:); 11. (;) 12. 13. (;); 17. 18. 19. 20. ()()是什么意思?答:的平方,并且转换成整数二、中与的区别用于字符串的值比较。,如果是基本类型比较值,如果是对象类型则比较内存地址首先这个方法是存在于类里,我们写的任何一个类都默认是的子类也就是说 类名 ( )括号里的是会自动添加的,那么我们就有必要先了解里的方法了,例如 (); (); ()的结果为,可以得到的信息是方法有个返回值,是类型的。b5E2R。b5E2R。方法原始的功能就是比较两个对象是不是一样,可以说任何两个不一样的对象之间的值为,因为任何两个对象的引用是不可能相同的,而这样的他()的结果是,可是这样的比较没有意义,所以我们通常将要比较的对象的所在类重写他的方法,里面有的类有些已经重写了方法,比如说类,();的结果就是,因为重写的方法规定只要他们的内容相同就是,这样更加符合我们现实中的需要.p1Ean。p1Ean。运算符是基础数据类型之间比较用的,比如 等,如果是对象 对象二,这就是错误的了,对象之间比较引用,也就是他们在内存中的地址,出来之后就不可能相同了。DXDiT。DXDiT。总之引用数据类型之间使用方法比较,(自己写的类要重写方法,指定比较规则),基础数据类型比较可以使用。 ; ; ;a. () 三、中和的区别?单个的表示位运算符,两个的表示逻辑运算符。位运算符可以用于逻辑运算,而逻辑运算不能用于位运算。如: ; ; 则 ;位运算符在逻辑运算中是非短路运算,意思就是两个表达式都要判断,即使第一个表达式已经判断出结果,但是还会继续往下判断,有一个为真即为真;RTCrp。RTCrp。:如果前一个条件为真,那后面的那个条件就不会判断了。例如( ) 已经判断出是此表达式已经是了,但是还会判断下一个表达式 。如果是( ) 如果已经判断出是,则不会判断下一个表达式。5PCzV。5PCzV。四、中类型与类的区别在中,数据类型包括以下两类:()基本数据类型:包括整型(), 浮点型(),字符型(),布尔型()等四种类型。在中,整型和浮点型的数据都是有符号的,这是不同于的一个地方。()复合数据类型:包括数组和类两种。其中类包括等,参见类库的所有子类;数组就是将数字与保存的数据对象联系起来的容器,可以是多维的,可以保存基本数据类型的数据,也可以保存类类型的数据。请看下例:() ;() ();在上例中,变量的值都是整型值,但是在第一个方法中,变量是一个类型变量,属于一个基本数据类型;在第二个方法中,变量是一个类的实例对象,属于一个复合类型类的一个实例变量,更确切地说,是一个指向类实例对象的引用,在“”右边是构造一个新分配的类型的变量,该对象表示整型值,而“”左边是定义一个指向类型对象的引用(对象句柄),使得该对象引用指向新分配的对象。小结:类是一种特殊的数据类型,这就是类型与类的区别:)jLBHr。jLBHr。五、中和有什么区别是回车符,是换行符,两者意义是不一样的。.先解释一下回车和换行的来历及概念:在计算机还没有出现之前,有一种叫做电传打字机( )的玩意,每秒钟可以打个字符。但是它有一个问题,就是打完一行换行的时候,要用去秒,正好可以打两个字符。要是在这秒里面,又有新的字符传过来,那么这个字符将丢失。xHAQX。xHAQX。于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。LDAYt。LDAYt。这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。后来,计算机发明了,这两个概念也就被般到了计算机上。基本的概念应该是回车表示回到最前面,换行表示换一行。但是那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。Zzz6Z。Zzz6Z。.目前具体情况:在上述分歧下不同系统采取了不同的实现:系统里,每行结尾只有“”,即“”;系统里面,每行结尾是“”,即“”;系统里,每行结尾是“”。一个直接后果是,系统下的文件在里打开的话,所有文字会变成一行;而里的文件在下打开的话,在每行的结尾可能会多出一个符号。dvzfv。dvzfv。六、中和的区别的作用手动抛出异常但是有时候有些错误在看来不是错误,比如说 ; ;();很正常的整形变量赋值,但是在我们眼中看来就不正常,谁的年龄会是负的呢。所以我们需要自己手动引发异常,这就是的作用。rqyn1。rqyn1。 ; ;() ( )创建异常对象 抛出异常();的作用声明方法可能回避的异常有异常被抛出了,就要做处理,所以中有。可是有时候一个方法中产生了异常,但是不知道该怎么处理它,那么就放着不管,当有异常抛出时会中断该方法,而异常被抛到这个方法的调用者那里。这个有点像下属处理不了的问题就交到上司手里一样,这种情况称为回避异常。Emxvx。Emxvx。但是这使得调用这个方法就有了危险,因为谁也不知道这个方法什么时候会丢一个什么样的异常给调用者,所以在定义方法时,就需要在方法头部分使用来声明这个方法可能回避的异常。SixE2。SixE2。 () .这表示 方法可能会丢两个异常出来,那么在调用的时候就会做好准备,比如可以这样();( ) ( ) 七、区别中堆与栈的堆是一个运行时数据区,类的对象从中分配空间。这些对象通过、和等指令建立,它们不需要程序代码来显式的释放。堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要在运行时动态分配内存,存取速度较慢。6ewMy。6ewMy。栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。栈中主要存放一些基本类型的变量(, , , , , )和对象句柄。kavU4。kavU4。栈有一个很重要的特殊性,就是存在栈中的数据可以共享。假设我们同时定义: ; ;编译器先处理 ;首先它会在栈中创建一个变量为的引用,然后查找栈中是否有这个值,如果没找到,就将存放进来,然后将指向。接着处理 ;在创建完的引用变量后,因为在栈中已经有这个值,便将直接指向。这样,就出现了与同时均指向的情况。y6v3A。y6v3A。这时,如果再令;那么编译器会重新搜索栈中是否有值,如果没有,则将存放进来,并令指向;如果已经有了,则直接将指向这个地址。因此值的改变不会影响到的值。M2ub6。M2ub6。要注意这种数据的共享与两个对象的引用同时指向一个对象的这种共享是不同的,因为这种情况的修改并不会影响到,它是由编译器完成的,它有利于节省空间。而一个对象引用变量修改了这个对象的内部状态,会影响到另一个对象引用变量。0YujC。0YujC。是一个特殊的包装类数据。可以用: (); ;两种的形式来创建,第一种是用()来新建对象的,它会在存放于堆中。每调用一次就会创建一个新的对象。而第二种是先在栈中创建一个对类的对象引用变量,然后查找栈中有没有存放,如果没有,则将存放进栈,并令指向”,如果已经有”则直接令指向“”。eUts8。eUts8。比较类里面的数值是否相等时,用()方法;当测试两个包装类的引用是否指向同一个对象时,用,下面用例子说明上面的理论。sQsAE。sQsAE。;()可以看出和是指向同一个对象的。();();()用的方式是生成不同的对象。每一次生成一个。因此用第一种方式创建多个”字符串,在内存中其实只存在一个对象而已.这种写法有利与节省内存空间.同时它可以在一定程度上提高程序的运行速度,因为会自动根据栈中数据的实际情况来决定是否有必要创建新对象。而对于();的代码,则一概在堆中创建新对象,而不管其字符串值是否相等,是否有必要创建新对象,从而加重了程序的负担。GMsIa。GMsIa。另一方面, 要注意: 我们在使用诸如 ;的格式定义类时,总是想当然地认为,创建了类的对象。担心陷阱!对象可能并没有被创建!而可能只是指向一个先前已经创建的对象。只有通过()方法才能保证每次都创建一个新的对象。TIrRG。TIrRG。由于类的性质,当变量需要经常变换其值时,应该考虑使用类,以提高程序效率。申请后系统的响应栈:只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。堆:首先应该知道操作系统有一个记录空闲内存地址的链表,当系统收到程序的申请时,会遍历该链表,寻找第一个空间大于所申请空间的堆结点,然后将该结点从空闲结点链表中删除,并将该结点的空间分配给程序,另外,对于大多数系统,会在这块内存空间中的首地址处记录本次分配的大小,这样,代码中的语句才能正确的释放本内存空间。另外,由于找到的堆结点的大小不一定正好等于申请的大小,系统会自动的将多余的那部分重新放入空闲链表中。7EqZc。7EqZc。申请大小的限制栈:在下,栈是向低地址扩展的数据结构,是一块连续的内存的区域。这句话的意思是栈顶的地址和栈的最大容量是系统预先规定好的,在下,栈的大小是(也可能是,它是一个编译时就确定的常数),如果申请的空间超过栈的剩余空间时,将提示。因此,能从栈获得的空间较小。lzq7I。lzq7I。堆:堆是向高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表来存储的空闲内存地址的,自然是不连续的,而链表的遍历方向是由低地址向高地址。堆的大小受限于计算机系统中有效的虚拟内存。由此可见,堆获得的空间比较灵活,也比较大。zvpge。zvpge。申请效率的比较:栈由系统自动分配,速度较快。但程序员是无法控制的。堆是由分配的内存,一般速度比较慢,而且容易产生内存碎片,不过用起来最方便.另外,在下,最好的方式是用分配内存,他不是在堆,也不是在栈是直接在进程的地址空间中保留一快内存,虽然用起来最不方便。但是速度快,也最灵活。NrpoJ。NrpoJ。堆和栈中的存储内容栈:在函数调用时,第一个进栈的是主函数中后的下一条指令(函数调用语句的下一条可执行语句)的地址,然后是函数的各个参数,在大多数的编译器中,参数是由右往左入栈的,然后是函数中的局部变量。注意静态变量是不入栈的。1nowf。1nowf。当本次函数调用结束后,局部变量先出栈,然后是参数,最后栈顶指针指向最开始存的地址,也就是主函数中的下一条指令,程序由该点继续运行。fjnFL。fjnFL。堆:一般是在堆的头部用一个字节存放堆的大小。堆中的具体内容有程序员安排。存取效率的比较 ; * ;是在运行时刻赋值的;而是在编译时就确定的;但是,在以后的存取中,在栈上的数组比指针所指向的字符串(例如堆)快。比如:();*;对应的汇编代码;第一种在读取时直接就把字符串中的元素读到寄存器中,而第二种则要先把指针值读到中,在根据读取字符,显然慢了。小结:堆和栈的区别可以用如下的比喻来看出:使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。tfnNh。tfnNh。使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且自由度大。八、 和的区别 在 语言中表示的是一种继承关系,一个类只能使用一次继承关系。但是,一个类却可以实现多个。.在 中可以有自己的数据成员,也可以有非的成员方法,而在中,只能够有静态的不能被修改的数据成员(也就是必须是 的,不过在 中一般不定义数据成员),所有的成员方法都是的。HbmVN。HbmVN。 和所反映出的设计理念不同。其实 表示的是关系,表示的是关系。 .实现抽象类和接口的类必须实现其中的所有方法。抽象类中可以有非抽象方法。接口中则不能

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论