Java 学习 第五篇;面向对象
1:基本数据类型的拆装;
基本变量类型 通过 new WrapperClass(primitive) 创建包装类对象;
包装类的对象 通过 WrapperInstance.XXXValue() 获取包装类对象的值;
例如
int it=5;
Integer itObject=new Integer(it);装包
it = itObject.intValue(); 拆包取出变量值;
<实际上java提供了自动装箱,自动卸箱的功能可以直接赋值>
2:基本类型变量和字符串之间的转换;
String intstr="123" ,intstr2="3.34";
int it =Integer.parseInt(intstr);
Float.parseInt(intstr2);
......
public static void main(String[] args)
{ String str="232423";
String str1="23.45";
//字符串转换为其他类型
int intstr=Integer.parseInt(str);
float flostr=Float.parseFloat(str1);
System.out.println(intstr);
System.out.println(flostr);
//232423
//23.45
//其他类型转换为字符串
String str2=String.valueOf(intstr);
System.out.println(str2);
//
}
3:equals & ==
String 已经重写了 Object的equals()方法通过equals判断两个字符串是否相等;标准是只要两个字符串包含的字符序列相同即认为相等;
public boolean equals(Object obj);为其原型;
String str ;
String str1;
str="222";
str1="222"; if(str==str1)
System.out.println("true1"); str =new String("222");
str1=new String("222"); if(str==str1)
System.out.println("true2"); if(str .equals(str1) )
System.out.println("true3");
output:
true1
true3
4:再次警示一下为什么static关键字修饰的成员不能访问实例成员
那是因为呀 很久很久以前.......是因为static修饰的是类成员(包括初始化块、方法、内部类和枚举类),类成员作用域大呀,很可能在类成员已经初始化完成
但是实例成员还没有初始化,也就是说实例成员可能还没哟实际存在只是一个引用而已(我的意思是举个栗子实例成员是变量的话)所以那怎么可以随便访问
不能,明显不能.
5:一种特殊的类 -----只能创建一个对象;计划生育的良好贯彻,只准有一个;
如何实现呢:答案很简单---->>>>>隐藏构造器,将构造器用private修饰, 另外得保证时刻得知道有没有创建这个类的对象,所以最好,缓存已经创建的对象,
让后再保证只创建一次就行了,如何保证,看看缓存是否存在呗,有的话就不能继续创建没有的话可以;
举个栗子:
class OnlyOne
{
private static OnlyOne instance;
private OnlyOne(){};
public static Onlyone getInstance()//为什么多了这个呢?为了判断呗 如果有申请创建新的对象,那么根据情况进行判断, 为什么是public?因为总得创建一次
{
if(instance==null)
instance=new OnlyOne;
return instance;
} }
可以测试下 新建两个对象 看看是否==
6:final 用于修饰不可变的类、方法、变量。
可修饰成员变量、局部变量 形参 等等 很类似与const of Cpp;(我是这么认为的)
一旦获取初始化之后就不能被再次赋值;
执行静态初始快块时为类属性赋初值;执行普通初始化快和构造器时可以为实例属性赋初值;
如果定义的final实例属性变量,如果没有及时为之赋初值,即没有在初始化块中、没有在构造器中、没有在初始化时、对其进行赋初值那么定义这个变量有毛用啊,
都TM系统默认了!
记住! 1:final修饰的类属性不能在普通初始化块中赋初值,如果要赋就在静态初始化快中赶紧初始化,因为在加载类的时候系统已经为其初始化完毕;
2:没有初始化不要访问!
3:final 修饰的局部变量 系统不会对其进行“隐式初始化”所以可以
4:final 修饰引用类型,与基本类型有区别,修饰引用类型时只能保证其引用的未知不变“相当于指针的值不变”但是引用的具体内容是可以更改的并且也是合法的;
final 修饰方法:
修饰方法时候,该方法就不能被重写了,注意是不能重写而不是不能重载!
特数情况是 如果父类方法有private修饰时,即便加final 因为该方法对父类是不可见的那么,子类中当然可以再写一个相同的;
7:还有就是所谓的不可变类通过限定其对类的改变、所谓的缓存不可变类;
8:重点是:抽象类 abstract 抽象类和抽象方法 抽象类 顾名思义 从很多类中抽象出来的类没,更具有一般性的类;
-> 抽象类不能被实例化,即不能用new 创建一个抽象类的对象;
-> 抽象方法没有方法体,不能有
-> 抽象类只能被继承;
-> 抽象类可以有构造器,虽然他不能创建实例,但是有构造器主要是用于被其子类调用;
-> 含有抽象方法的类必须定义被抽象类;抽象类可以有普通方法哦
-> 没有抽象变量,抽象属性,抽象构造器的说法!
-> 不能用static和abstract同时修饰一个方法,因为抽象方法没有方法体,通过类调用肯定会出错!
-> abstract修饰的方法一定要被子类重写,所以不能用private修饰;即两者不能同时使用
-> 父类普通方法依赖于一个抽象方法,那么该方法仍然必须推迟到子类中实现;
对抽象类定义下吧:抽象类体现的是模板思想,抽象抽象抽象!!!!!!避免子类设计的随意,子类可以以此为模板进行扩充、改造。
例子:
package five; abstract class Abstract {
{
System.out.println("hello abstract");
}
private String color;
public abstract String xiangtongxingwei1();
public Abstract(){};
public Abstract(String color)
{
System.out.println("using Constructor wiht one parameter");
this.color=color;
}
public String getcolor()
{
return this.color;
} }
class Example extends Abstract
{
public Example(String str)
{
super("str");
System.out.println("using Constructor example wiht one parameter");
}
public String xiangtongxingwei1()
{
System.out.println("xiangtongxingwei1");
return "I am an example";
}
} public class TestAbstract
{
public static void main(String[] args)
{
String str="ssss";
Example exa1=new Example(str);
str=exa1.xiangtongxingwei1();
System.out.println(str);
}
}
output:
hello abstract
using Constructor wiht one parameter
using Constructor example wiht one parameter
xiangtongxingwei1
I am an example
Java 学习 第五篇;面向对象的更多相关文章
- 从.Net到Java学习第五篇——Spring Boot &&Profile &&Swagger2
从.Net到Java学习系列目录 刚学java不久,我有个疑问,为何用到的各种java开源jar包许多都是阿里巴巴的开源项目,为何几乎很少见百度和腾讯?不是说好的BAT吗? Spring Boot 的 ...
- Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题
一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...
- 201671010140. 2016-2017-2 《Java程序设计》java学习第五周
java学习第五周心得体会 本周,是Java学习第五周,随着时间推移,随着课本内容的推进,我们接触到的程序也开始变得越来越复杂,不再是二三章那些用来练手的小程序了,这一点,在我们的例题运 ...
- 从.Net到Java学习第十一篇——SpringBoot登录实现
从.Net到Java学习系列目录 通过前面10篇文章的学习,相信我们对SpringBoot已经有了一些了解,那么如何来验证我们的学习成果呢?当然是通过做项目来证明啦!所以从这一篇开始我将会对之前自己做 ...
- Java学习之反射篇
Java学习之反射篇 0x00 前言 今天简单来记录一下,反射与注解的一些东西,反射这个机制对于后面的java反序列化漏洞研究和代码审计也是比较重要. 0x01 反射机制概述 Java反射是Java非 ...
- Java学习之jackson篇
Java学习之jackson篇 0x00 前言 本篇内容比较简单,简单记录. 0x01 Json 概述 概述:JSON(JavaScript Object Notation, JS 对象简谱) 是一种 ...
- Java学习之注解篇
Java学习之注解篇 0x00 前言 续上篇文章,这篇文章就来写一下注解的相关内容. 0x01 注解概述 Java注解(Annotation)又称Java标注,是JDK5.0约会的一种注释机制. 和J ...
- java学习(五)
学号 20189214 <Java程序设计>第五周学习总结 教材学习内容总结 输入输出 文件系统可以包含3种类型的对象:文件.目录和符号链接. 一个文件或路径是一个java.io.File ...
- 从.Net到Java学习第八篇——SpringBoot实现session共享和国际化
从.Net到Java学习系列目录 SpringBoot Session共享 修改pom.xml添加依赖 <!--spring session--> <dependency> & ...
随机推荐
- 《Programming WPF》翻译 第7章 7.我们进行到哪里了?
原文:<Programming WPF>翻译 第7章 7.我们进行到哪里了? WPF提供了一个范围的高质量生成和合成服务.一组形状元素支持各种的绘图基础.一些笔刷类型是可利用的,对于决定如 ...
- 利用btrace工具监控在线运行java程序
一.作用 可以用于对运行中java程序进行诊断监控分析,也可以用于开发阶段查看一些异常信息或者调用过程(如有些第三方代码没有源代码,不便于debug调试). 注:如果用于对在线运行系统的诊断,需 ...
- 【转】20个Java 代码生成器
From: http://www.cnblogs.com/skyme/archive/2011/12/22/2297592.html 1.1 CodeSmith 一款人气很旺国外的基于模板的dotne ...
- POJ 2752 Seek the Name, Seek the Fame (KMP next 数组 变形)
题意:给一个字符串S,判断在什么下标的时候,前缀和后缀相等,输出前缀和后缀相等的点. 分析:next数组的一种很巧妙的用法 next数组表示的意义是当前下标前面k字符和开头的前面k个字符相等 所以就会 ...
- nodejs 设置网络代理
在使用nodejs的过程中,加入使用代理上网,那么安装组件会失败,此时配置代理即可,命令如下: [root@oracle ~]#npm config set proxy=http://10.101.1 ...
- OpenStack术语名词及问题调试
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAnoAAAEkCAIAAAA3pAtBAAAgAElEQVR4nOy953tUx7o9uCrt2EmtHB
- 第11讲- Android中进程及其优先级
第11讲Android中进程及其优先级 进程与线程: 进程:操作系统结构的基础,资源分配的最小单元,一个操作系统包括多个进程: 线程:线程存在于进程当中,是操作系统调试执行的最小单元,一个进程包括多个 ...
- PHP文件目录copy
/**(2) PHP文件目录copy @param string $dirsrc 原目录名称字符串 @param string $dirto 目标目录名称字符串 */ function copyDir ...
- (3)选择元素——(5)为项目列表加样式(Styling list-item levels)
Let's suppose that we want the top-level items, and only the top-level items, to be arranged horizon ...
- [转]Laravel 4之路由
Laravel 4之路由 http://dingjiannan.com/2013/laravel-routing/ Laravel 4路由是一种支持RESTful的路由体系, 基于symfony2的R ...