class 类名 { 类体; } // 一般状况下, 当类名由多个单词组成时, 要求每一个单词首字母都要大写
class 类名 { 数据类型 成员变量名 = 初始值; } // 当成员变量由多个单词组成时,一般要求从第二个单词起每一个单词的首字母大写
new 类名();
类名 引用变量名; 引用变量名.成员变量名;
Person p = new Person(); p.name = "乌冬面"; System.out.println(p.name);
对象建立后, 其成员变量能够按照默认的方式初始化, 具体规则以下编程
成员变量的类型 | 默认初始值 |
---|---|
数值类型 byte, short ,int ,long, float, double, char | 0 |
boolean | false |
引用类型 | null |
class 类名{ 返回值类型 成员方法名(形参列表){ 成员方法体; } } // 当成员方法名由多个单词组成时, 要求从第二个单词起每一个单词的首字母大写
String s
便可)数据类型 形参变量名1, 数据类型 形参变量名2,...
.(好比, 当带入的数据内容是66和"hello"时, 则形参列表写int i, String s
便可)引用变量名.成员方法名(实参列表);
p.show();数组
返回值类型 方法名(参数的类型...参数名)
数据结构
int max(int ia, int ib){...} public static void main(String[] args){ int a = 5; int b = 6; int res = m.max(a,b); }
public class ArgumentTest{ // 自定义成员方法用于打印传入的参数 public void show1(int ia){ ia = 333; // 为形参变量赋值的语句a System.out.println("ia = " + ia); } public static void main(String[] args){ // 建立对象 ArgumentTest at = new Argument(); // 调用成员方法show1 int ib = 3; at.show1(ib); System.out.println("ib = " + ib); } } /* * 当成员方法show1()中只有打印语句,没有其它赋值语句(语句a)时, 该程序打印结果为: * ia = 3 /n ib = 3 * 当成员方法show1()中有打印语句,也有为形参变量赋值的语句a时,该程序打印结果为: * ia = 333 /n ib = 3 * 也就是实参变量ib的值没有发生改变 */
public class ArgumentTest{ // 自定义成员方法, 用来打印传入的参数(引用数据类型) pubic void show2(int[] arr){ arr[0] = 333; // 修改形参变量数值的语句b System.out.println("show2方法中 arr[0] = " + arr[0]); } public static void main(String[] args){ // 建立对象 ArgumentTest at = new ArgumentTest(); // 调用成员方法show2 int[] arr1 = new int{11,22}; at.show2(arr1); System.out.println("main方法中 arr1[0] = " + arr1[0]); } } /* * 当成员方法中只有打印语句,没有修改形参变量数值的语句b时,程序运行的打印结果为: * show2方法中 arr[0] = 11 /n main方法中 arr1[0] = 11 * 当成员方法中不仅有打印语句,还有修改形参变量数值的语句b时,程序运行的打印结果为: * show2方法中 arr[0] = 333 /n main方法中 arr1[0] = 333 * 也就是实参变量的数值由于形参变量中数值的修改而修改(下面还有内容) * 缘由是: 对于引用数据变量, 堆区中存放变量的具体数值(在该例中即为数组 {11,22}), 栈区中存放的是堆区的地址,也就是说存放的是指向具体数值的地址信息,而非实际的具体数值 * 因此在调用show2方法而且传参时, 实际上传的是数组的地址信息 * 那么在show2方法体内对数组元素进行修改后, 实际上修改的就是实参变量所指向的同一个数组内元素的数值 * 再好比, 同窗a(实参)向同窗b(形参)要苹果吃, 同窗b告诉a本身的苹果放在书桌上,还有5颗,而后同窗b就走到书桌处拿苹果. * 此时对于两个同窗而言, 他们面对的是同一堆苹果(堆区). 若是同窗b将一颗苹果换成橘子,那么对于同窗a来讲,他所拥有的就是4颗苹果+1颗橘子 */
public class ArgumentTest{ // 自定义成员方法实现打印参数的功能 public void show3(int[] arr1){ arr1 = new int[2]; //为形参建立了新的数组c arr1[0] = 333; System.out.println("show2方法中 arr1[0] = " + arr1[0]); } public static void main(String[] args){ // 建立对象 ArgumentTest at = new ArgumentTest(); // 调用成员方法 int[] arr1 = new int{11,22}; at.show3(arr1); System.out.println("main方法中 arr1[0] = " + arr1[0]); } } /* * 程序运行的打印结果为: * show2方法中 arr1[0] = 333 /n main方法中 arr1[0] = 11 * 此时形参中对数组元素的改变没有影响到实参中本来的元素数值 * 这里的缘由是 * 在show3方法体内, 为形参在堆区申请了一块新的内存空间,而下面语句的改变数值改变的也是这块新的内存空间 * 而实参本来的数据就是没有改变的 */
i=10
, 真实传参时, 把10赋值给了形参. 当参数是对象是, 传递的是对象的值, 也就是把对象的<u>地址</u>赋值给形参08-29 看到有人收藏了,小开心😗编程语言