Java怎么重新复写(已经复写了一次)同一个类里的一个方法,能有这种办法吗
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java怎么重新复写(已经复写了一次)同一个类里的一个方法,能有这种办法吗相关的知识,希望对你有一定的参考价值。
private Printer.Progress printHz1 = new Printer.Progress()
@Override
public void doPrint(Printer prnHz1) throws Exception
// TODO Auto-generated method stub
Format formatHz1 = new Format();
formatHz1.setHzSize(Format.HZ_DOT16x8);
prnHz1.setFormat(formatHz1);
str1 = (formatHz1.getHzSize()+"");
System.out.println("汉字大小类型是" + str1);
str2 = (formatHz1.getHzScale()+"");
System.out.println("汉字缩放类型是" + str2);
想再次复写public void doPrint(Printer prnHz1) throws Exception
有什么办法
各位大虾帮帮呀
亲们,我再补充具体点,参数printHz1这个不变,其次别给我加参数呀。
真的就是复写呀。我的目的是这个方法复写一次用完后,再一次复写呀。
也就是在保留前面性质的情况下再一次复写,有木有办法。
或给点其他建议,目的就是重复利用上述的方法
还有一种是重写(Overriding):子类中定义某方法与其父类有相同的名称和参数,这是父类与子类之间的多态性的体现。
还有一种办法就是使用JAVA的泛型方法。
不知道你的具体要求是什么? 参考技术A 加个int参数,写成
public void doPrint(Printer prnHz1,int temp) throws Exception 参考技术B 除非你用不同的继承类来重写或者多继承,在同一个类中是不可能实现不改变方法参数的情况下实现重载的。Java是很灵活的不要再一棵树上吊死,多换换思路。
有什么不清楚的地方可以继续问。 参考技术C 重写是子类重写父类的 参考技术D 那你可以把方法写成一个公共方法,在你需要就调用它 第5个回答 2012-10-08 重载这个方法,参数不同就行了
1089. 复写零
给你一个长度固定的整数数组 arr,请你将该数组中出现的每个零都复写一遍,并将其余的元素向右平移。 注意:请不要在超过该数组长度的位置写入元素。 要求:请对输入的数组 就地 进行上述修改,不要从函数返回任何东西。 示例 1: 输入:[1,0,2,3,0,4,5,0] 输出:null 解释:调用函数后,输入的数组将被修改为:[1,0,0,2,3,0,0,4] 示例 2: 输入:[1,2,3] 输出:null 解释:调用函数后,输入的数组将被修改为:[1,2,3] 提示: 1 <= arr.length <= 10000 0 <= arr[i] <= 9 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/duplicate-zeros
代码如下:
时间复杂度O(n),空间复杂度O(1)。
1 func duplicateZeros(_ arr: inout [Int]) 2 // 数组为空 或 只有1个元素时,直接返回 3 if arr.count < 2 4 return 5 6 7 // 本次遍历目的:找出可复写0的个数 8 var i = 0, j = 0 9 while j < arr.count 10 if arr[i] == 0 11 j += 1 12 13 i += 1 14 j += 1 15 16 17 // 没有元素为0; 18 if i == j 19 return 20 21 // 当且仅当最后一个元素为0 22 else if i == arr.count-1 && j > arr.count 23 return 24 25 26 // i,j回到下次遍历的开始位置 27 i -= 1 28 j -= 1 29 while i >= 0 30 if j < arr.count 31 arr[j] = arr[i] 32 33 if arr[i] == 0 34 j -= 1 35 arr[j] = arr[i] 36 37 38 i -= 1 39 j -= 1 40 41
以上是关于Java怎么重新复写(已经复写了一次)同一个类里的一个方法,能有这种办法吗的主要内容,如果未能解决你的问题,请参考以下文章