类的5大成分(成员变量、成员方法、构造器、代码块、内部类)之一
类中的类
当一个事物的内部,还有一个部分需要一个完整的结构进行描述时。
1、静态内部类
是什么?有static修饰,属于外部类本身。
特点:只是位置在类里面。类有的成分它都有。
创建对象:
外部类.内部类名 对象名 = new 外部类名.内部类构造器;
拓展
1、静态内部类可以直接访问外部类的静态成员吗? 可以的
2、静态内部类中是否可以直接访问外部类的实例成员? 不可以的
2、成员内部类(实例内部类)
是什么?
无static修饰,属于外部类的对象的。
特点:JDK 16中类有的成分,它都有。
创建对象 :
外部类.内部类 对象名 = new 外部类构造器.new 内部类构造器;
拓展
1、成员内部类中是否可以直接访问外部类的静态成员? 可以
2、成员内部类的实例方法中是否可以直接访问外部类的实例成员? 可以
3、局部内部类
定义在方法,代码块,构造器中,执行代码处的类。鸡肋语法!
4、匿名内部类(重点)
使用匿名内部类的好处:
方便构建子类对象,最终目的:简化代码
格式:
new 类名|接口|抽象类(){
方法重写;
}
特点:
匿名内部类是一个没有名字的局部内部类,本身也是一个所谓的子类对象。
匿名内部类产生的对象类型,相当于是当前new的那个的类型的子类类型。
是什么? 是一种特殊类型。 枚举的特征:
枚举类都是继承了枚举类型:java.lang.Enum
枚举都是最终类,不可以被继承。
构造器都是私有的,枚举对外不能创建对象。
枚举类的第一行默认都是罗列枚举对象的名称的。
枚举类相当于是多例模式。
定义类、接口、方法时,同时声明了一个或者多个类型变量(如:<E>) ,称为泛型类、泛型接口,泛型方法、它们统称为泛型。
作用
泛型提供了在编译阶段约束所能操作的数据类型,并自动进行检查的能力!这样可以避免强制类型转换,及其可能出现的异常。
定义类的同时定义了泛型的类就是泛型类
泛型类的格式
修饰符 class 类名<类型变量,类型变量,…> {
}
作用
在编译阶段可以指定能操作的数据的类型
原理
把出现泛型变量的地方全部替换成传输的真实数据类型。
使用了泛型定义的接口就是泛型接口
格式
修饰符 interface 接口名称<泛型变量> {
}
作用
泛型接口可以让实现类选择当前功能需要操作的数据类型
原理
实现类可以在实现接口的时候传入自己操作的数据类型,这样重写的方法都将是针对于该类型的操作。
定义方法时同时定义了泛型的方法就是泛型方法
格式
修饰符 <类型变量,类型变量,…> 返回值类型 方法名(形参列表) {
}
作用
方法中可以使用泛型接收一切实际类型的参数,方法更具备通用性。
原理
把出现泛型变量的地方全部替换成传输的真实数据类型。
? 可以在“使用泛型”的时候代表一切类型。
E T K V 是在定义泛型的时候使用的。
泛型的上下限
? extends Car: ?必须是Car或者其子类 泛型上限
? super Car : ?必须是Car或者其父类 泛型下限
泛型是工作在编译阶段的,一旦程序编译成class文件,class文件中就不存在泛型了,这就是泛型擦除。
泛型不支持基本数据类型,只能支持对象类型(引用数据类型)。
API全称是应用程序编程接口,是Java写好的程序,程序员可以直接调用。
Object是祖宗类,它里面的方法,一切子类对象都可以使用。
public String toString()
默认是返回当前对象的地址信息。
Student s = new Student("张三",'女', 23);
System.out.println(s.toString());
返回对象地址
System.out.println(s);
直接输出对象名,默认是调用toString方法的
toString存在的意义:
默认返回对象的地址其实是没有意义的
真实存在的意义是被子类重写,以便返回子类对象的内容。
public boolean equals(Object o )
默认是比较2个对象的地址是否一样,返回true 或者false
equals存在的意义
默认比较对象的地址其实是没有意义的,因为== 号可以更简单的完成
存在的的真实意义是被子类重写,以便比较对象的内容。
protected Object clone()
当某个对象调用这个方法时,这个方法会复制一个一模一样的新对象返回。
分类:
浅克隆:拷贝出的新对象,与原对象中的数据一模一样(引用类型拷贝的只是地址)
深克隆:
对象中基本类型的数据直接拷贝。
对象中的字符串数据拷贝的还是地址。
对象中还包含的其他对象,不会拷贝地址,会创建新对象。
Objects是一个工具类,提供了更安全的方式比较2个对象。
Student s = null;
s.equals(s2); 空指针异常
Objects.equals(s, s2); 返回false
Objects常见方法:
| 方法名 | 说明 |
|---|---|
| public static boolean equals(Object a, Object b) | 比较两个对象的,底层会先进行非空判断,从而可以避免空指针异常。再进行equals比较 |
| public static boolean isNull(Object obj) | 判断变量是否为null ,为null返回true ,反之返回false |
其实就是8种基本数据类型对应的引用类型。
作用:实现一切皆对象
| 基本数据类型 | 引用数据类型 |
|---|---|
| byte | Byte |
| short | Short |
| int | Integer |
| long | Long |
| char | Character |
| float | Float |
| double | Double |
| boolean | Boolean |
包装类其实可以随便用的:int integer
自动装箱
基本类型的数据可以赋值其给包装类
自动拆箱
包装类的数据赋值给基本数据类型
1、基本类型变成字符串
// 1、调用包装类继承自Object的toString方法
String rs1 = it6.toString(); // "23"
System.out.println(rs1 + 1); // 231
// 2、调用静态方法: public static String toString(int i)
String rs2 = Integer.toString(it6);// "23"
System.out.println(rs2 + 1);
// 3、直接加 “”
String rs3 = it6 + ""; // "23"
System.out.println(rs3 + 1);
2、把字符串变成基本数据类型(重点)
String age = "23";
// int ageInt = Integer.parseInt(age);
int ageInt = Integer.valueOf(age);
System.out.println(ageInt + 1);
String price = "98.5";
// double priceDb = Double.parseDouble(price);
double priceDb = Double.valueOf(price);
System.out.println(priceDb + 0.5);
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我在Rails工作并有以下类(class):classPlayer当我运行时bundleexecrailsconsole然后尝试:a=Player.new("me",5.0,"UCLA")我回来了:=>#我不知道为什么Player对象不会在这里初始化。关于可能导致此问题的操作/解释的任何建议?谢谢,马里奥格 最佳答案 havenoideawhythePlayerobjectwouldn'tbeinitializedhere它没有初始化很简单,因为你还没有初始化它!您已经覆盖了ActiveRecord::Base初始化方法,但您没有调
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
我想让一个yaml对象引用另一个,如下所示:intro:"Hello,dearuser."registration:$introThanksforregistering!new_message:$introYouhaveanewmessage!上面的语法只是它如何工作的一个例子(这也是它在thiscpanmodule中的工作方式。)我正在使用标准的rubyyaml解析器。这可能吗? 最佳答案 一些yaml对象确实引用了其他对象:irb>require'yaml'#=>trueirb>str="hello"#=>"hello"ir
假设我有一个FireNinja我的数据库中的对象,使用单表继承存储。后来才知道他真的是WaterNinja.将他更改为不同的子类的最干净的方法是什么?更好的是,我很想创建一个新的WaterNinja对象并替换旧的FireNinja在数据库中,保留ID。编辑我知道如何创建新的WaterNinja来self现有FireNinja的对象,我也知道我可以删除旧的并保存新的。我想做的是改变现有项目的类别。我是通过创建一个新对象并执行一些ActiveRecord魔法来替换行,还是通过对对象本身做一些疯狂的事情,或者甚至通过删除它并使用相同的ID重新插入来做到这一点,这是问题的一部分。
根据ActiveRecord::Base的文档:==(comparison_object)Returnstrueifcomparison_objectisthesameexactobject,orcomparison_objectisofthesametypeandselfhasanIDanditisequaltocomparison_object.id.Notethatnewrecordsaredifferentfromanyotherrecordbydefinition,unlesstheotherrecordisthereceiveritself.Besides,ifyoufet