Java 接口中定义抽象方法有什么意义

Runnable类的源码:
public abstract void run();

            这里用不用abstract有什么区别?

27个回答

接口方法声明只能是public abstract的,所以不管你在声明的时候加不加abstract,都是可以的。Java 8开始,接口还引入了默认方法,也就是可以给接口的方法提供默认的实现,默认方法应当声明为:public default并实现,public可以省略。

举个例子:

public interface Test() {
        // 以下四种声明方式都是合法的接口方法声明
        void test1();
        public void test2();
        abstract void test3();
        public abstract void test4();

        // 默认方法可以省略public,但不能省略default,并且需要添加实现
        default void hello() {
                System.out.println("Hello");
        }
        public default hello(String name) {
                System.out.println("Hello, "+name);
        }
}
wfskxj
wfskxj 谢谢
8 个月之前 回复

首先,run方法不实现的话继承这个类还有意义吗,如果定义成abstract的话就会强制你去实现它,如果不实现就会报错。
然后,你要理解一下什么是面向对象,这里的run方法,本来就是未完成的方法,如果你这里不写abstract的话,就会认为这个方法以及完善看不符合面向对象的思想
最后,抽象可以告诉你,,,其他地方我已经帮你写好了,你把这些我抽象的地方填好就可以运行了,你不用管其他地方了

whb3299065
whb3299065 回复qq_39738736: 开始我看错了,看成抽象类了
大约 2 年之前 回复
qq_39738736
程序小高 接口方法声明只能是public abstract的,所以不管你在声明的时候加不加abstract,都是可以的
大约 2 年之前 回复
haoxuhong
ailinghao
大约 2 年之前 回复
whb3299065
whb3299065 回复Light_0X0000: 我看错了,看成抽象了,接口的话定不定义无所谓了,其实接口都隐含了abstract关键字,写上可能只是习惯问题。反正我们公司从接口从来不用abstract
大约 2 年之前 回复
m0_37741173
bear_0X0000 接口的方法本来就是要强制实现的。
大约 2 年之前 回复

java中定义抽象方法是为了让一些公用的方法或者属性在父类中声明,然后子类可以公用公共属性,对于不同的方法,在子类中可以用不同的实现。这也就是java中的多态。

是接口,默认的修饰词就是public abstract ,你写不写都是这个

接口中的方法不都是abstract,让实现类去实现,不用去纠结的吧

默认情况下,接口内的方法都是public abstract,也就是说,如果你不写,他也是public abstract的。

规则,没什么的,只是大部分人都认为这么写好,也源于现在没有更好的方法代替。

java中如果一个类中有被abstract修饰的抽象方法,那么该该类必须是抽象类或者接口。如果其他的类继承了该抽象类那么必须就要实现这个类中的
所有抽象方法。因此这种写法是为了让开发实现Runnable时强制必须实现其里面的run方法。任务在run中执行。

接口中有抽象方法,证明这个抽象方法时必须实现。

这就是接口的思想,你具体的实现代码不管你,但我规定了你的方法签名,我可以预先调用,但具体的实现可以按实际的变动。

共27条数据 1 3 尾页
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于抽象 和 接口在java项目结构中的一些问题,有图。
mapper:接口baseMapper(公共接口),接口UserMapper继承baseMapper(其他接口); service:接口baseService(公共接口),接口UserService继承baseService(其他接口); serviceImpl:抽象baseServiceImpl,接口UserServiceImpl 实现 baseService,UserService 今天看到一个JAVA项目结构是这种,所有有点不明白,是否有baseService存在的必要性,如下图 ![图片说明](https://img-ask.csdn.net/upload/201907/14/1563051335_115732.jpg) __________________________________ 以下为2019-7-17作者补充。 经过测试后,结构重新优化,如下图: ![图片说明](https://img-ask.csdn.net/upload/201907/17/1563355451_359451.png) BaseService 为 通用接口; BaseServiceImpl 为BaseService的实现类,BaseServiceImpl定义为抽象类。 UserService 继承了 BaseService 接口,BaseService定义为接口; UserServiceImpl 继承了(extends)BaseServiceImpl,且 implements UserService接口;
java定义接口的属性修改不了
请问大神,比如职位接口,接口中定义了name属性。老板与秘书这两个类都实现了接口,创建这两个类的实例a,b。想给实例的属性赋值例如a.name="张三",发现编译不过去。这种情况下,是要把接口改为抽象类吗,还有更好的赋值方式吗。
关于Iterator接口的疑问,接口中的抽象方法是何时被实现的
JDK api文档里面对Iterator定义的是一个接口,里面有几个常用方法。接口我的理解是一个特殊的类,里面的方法都是定义好未实现的抽象方法。但为什么调用HashSet里面的iterator()方法后,返回Iterator对象,就可以使用这个对象里面的方法了。方法不是抽象的么,是什么时候被实现了呢?还是Iterator本身是个接口,又是个实体类(api中没找到是个实体类)? 这个疑问是在看Map接口中,如何输出Map中的内容时产生的,代码如下: [code="java"] Map<String,Integer> map = new HashMap<String,Integer>(); map.put("张三",4); map.put("李四",2); map.put("王五",5); Set<Map.Entry<String,Integer>> set=map.entrySet(); Iterator<Map.Entry<String,Integer>> it = set.iterator(); while (it.hasNext()) { Map.Entry<String,Integer> m = it.next(); System.out.println(m.getKey()+"-->"+m.getValue()); } [/code] Map.Entry本身是个接口,如何在 Map.Entry<String,Integer> m = it.next(); 这句代码中得到实体类,且可以调用对象中方法。是否可以理解为如: Map m = new HashMap(); 当父类对象指向子类实例,调用跟子类同名方法时,只会调用子类已经实现过的方法。于此一样,it.next()方法返回一个Map.Entry对象实例,然后接口引用指向这个实例,但HashMap是个实体类,Map.Entry是个接口啊。再观察的时候,也发现Iterator也是此种情况。 小弟肯定是有些关键东西忽略了,或者是理解出现的差错,望各位前辈能指点迷津。
关于JAVA8的新特性函数式接口与Stream的一个问题
最近在学习java8的新特性,在看到lambda时用到了函数式接口。 发现函数式接口的定义是一个接口只有一个抽象方法,但我在查看Stream时发现其中有许多抽象方法,不知到是我对函数式接口的定义理解有问题还是Stream用到了其它机制 有没有大佬指点下,万分感谢!
关于抽象类实现接口的问题
例如: 接口中定义了两个函数A、B 一个抽象类实现了这个接口中的一个函数A 请教一下问题 这个抽象类的子类是因为其父类没有实现函数B,从而需要自己去实现函数B,因为接口就是一个契约。那么既然是契约,为什么抽象类可以只实现接口中的一个函数A,不实现函数B也仍然可以编译通过呢?
GenericServlet抽象类中,为什么又自定义了一个init()方法
``` GenericServlet抽象类中,为什么重写了Servlet接口的init()后, 又自定义了一个init()方法 ``` ![图片说明](https://img-ask.csdn.net/upload/201708/07/1502087729_318878.png)
利用java抽象现实中的车
写出三个方法,其中一个是重载方法,一个是构造方法。继承父类并定义接口
利用java抽象现实中的裤子
写出三个方法,其中一个是重载方法,一个是构造方法。继承父类并定义接口
接口设计时,实现类中方法参数不同带来的设计困扰,求助。。
是这样的,小弟我定义了一个接口,接口里抽象了一个周期方法, Integer cycle(); 现在我想在教师类class teacher里实现这个方法,得出家访周期,这个时候方法体可能需要X和Y两个参数,然而我又想在教学计划类class plan中实现这个方法,得出考试周期,这个时候又的用到另外两个参数,可能数据类型不同,甚至可能参数个数也不同。碰到这种情况的话是不是接口方法抽象有问题?
关于‘abstract class和interface有什么区别’这个问题的一些疑问?
1、抽象类里面可以用普通方法,而接口中的方法全部都是抽象的; 2、抽象类中可以有非 public static final修饰的属性,接口中的属性都是public static final修饰的 3、抽象类有构造方法,接口没有构造方法 4、抽象类中可以有静态方法,接口中不能有静态方法 5、类与抽象类的关系是继承,而且是单继承。类与接口的关系是实现,而且是多实现。 6、抽象类由abstract class声明,接口由interface声明 7、子类与它继承的抽象类的关系是 B is A,实现类与它所实现的接口的关系是 B like A 8、在应用范围上来说,接口往往在程序设计的时候,用来定义程序模块的功能,方便各模块协同工作;抽象类是对相似类进行抽象,形成一个抽象的父类可供重用! 以上是问题的答案,哪位可以解释一下,每一条答案背后的含义,设计者为什么要这么做?
Java图形类是如何绘图的
如题,java图形库为awt和swing,这些类库中元件均为继承关系,基础类分别是Component与JComponent,当我们继承自这些组件的类运行时,桌面便开始绘制并形成图形,关于这个绘图的“动作”在类库中我一直没找到,在component中有个Graphics有关的变量,似乎是做边框的,而Graphics只是个接口,并没有作图“动作”的实现,后面所有的组件也没有发现对这个接口的实现。还有一个Piont类,继承自Piont2D,似乎是描点的,里面有想x,y坐标的成员变量,但也同样没有画的“动作”,前后都没找到具体实现。 抽象类Graphics里面有个drawLine()方法,应该是画直线的,里面各种坐标的定义也都是全的,这个drawLine()方法依然无定义,而且前后各组件中再也没找到这个方法的实现。 只有两种原因:1,的确存在一个画图的“动作”,应该是一种方法。2,不存在这个动作,编译器在读取到这些点啊线啊的接口类的时候会“明白”我们的意思,直接调用我们在这些类中的想x,y等坐标来绘制图形。 那么,如果是情况1,请问这个动作方法在哪呢,我一个都没找到。如果是情况2,那么这个编译器难道会侦听么,一单发现这些点啊线的类参数有变化,接开始执行画图操作。 请问大牛图形的”画“究竟是如何实现的呢。
android AIDL使用的问题
AIDL的使用步骤是: 创建两个工程,一个为client,一个为server server端在src目录下专门创建一个包用于放置创建的myInterface.aidl接口文件,定义用于通信的抽象方法,然后编译,在gen目录下生成myInterface.java文件,该文件会自动生成内部接口myInterface.Stub;再创建一个Service类,在类中创建myInterface.Stub对象,实现在接口中定义的用于通信的抽象方法; 再重写onBind方法,把Stub对象返回出去(Stub类是IBinder的子类,可以用于client端和server端的通信) 然后在AndroidManifest文件里配置Service类 然后把在server端定义的aidl接口文件复制到client端项目中(连包带文件一起复制,保持client端和server端aidl接口所在包路径一样),在client端的Activity中定义ServiceConnection类对象和server端接口myInterface对象,重写ServiceConnection对象的onServiceConnect,在该方法中获取来自server端的myInterface对象, 现在就可以调用myInterface中的方法(也就是client端调用server端的方法,也就完成了进程间通信) 上面的ServiceConnection要能获取到IBinder对象,还需要client用Intent完成与server端的Service类的绑定 我就卡在这一步了 不管是对server端Service指定Action来让client端启动,还是指定其它东西,就是无法再client端项目里启动server端项目里的Service 有谁知道怎么解决吗? 简而言之,就是如何在当前工程中调用远程Service
关于接口interface的一些小总结、问题。请求解答和更正。
1,有的接口,加上个 实现就能用里面的方法,不用自己去实现。这大概是个什么原理? A继承B,B实现C的过程,在这个过程中,A成为了B的子类,B可以替子类实现C接口的某些方法,如果B没有实现,那么就需要A来实现 2,接口和抽象类是抽象类型定义的两种机制,其赋予java强大的面向对象能力,为甚? (封装,继承,多态,,,,抽象) 3,合作,类似协议,如果针对一个比较庞大的项目,架构师可以李青业务定义接口,由别人去实 现。 定义好一个接口,文档(实现类的命名规范等,)给别人去开发、实现。 4,扩展性,需求变更后,通过接口去改或新建其实现类, 然后,从新引用实现接口的类 5,解耦,,具体是怎么达到解耦的效果的? 6,招牌,通过接口,快速的指导类的作用、用途等。 7,通过接口能更好的实现对开闭原则,修改的关闭,拓展的开放。 第二条,第五条求解答,其他的如有错误请更正!
一个java题目,感觉自己打出来的好像不是很符合题目要求
题目:定义类ActionListenerTest,实现ActionListener接口,实现抽象方法actionPerfomed,在方法中输出你自己的学号和姓名. 自己的代码: package work1; public interface ActionListener { public abstract void actionPerfomed(); } package work1; import java.util.Scanner; public class ActionListenerTest implements ActionListener { Scanner input=new Scanner(System.in); public void actionPerfomed(){ System.out.println("请输入您的学号:"); int a=input.nextInt(); System.out.println("请输入您的姓名:"); String b=input.next(); System.out.println("您的学号:"+a+"您的姓名:"+b); } public static void main(String[] args){ ActionListenerTest a=new ActionListenerTest(); a.actionPerfomed(); } } 请问是这样做吗?
JAVA 现有3老师个分别管理3个班级班级学生人数不限(即1个老师管理1个班级),录入学生期末成绩。
实现功能如下: 1. 显示所有老师信息及老师下面学生成绩; public void showAllMeassage(); 2. 在小熊老师下新增zz学生,添加该学生各科成绩,可以不用控制台录入,直接通过构造方法初始信息后添加 ;public boolean addStudent(String teacherName,Student s); 3. 删除小熊老师下的dd学生信息;public boolean deleteStudent(String teacherName,String studentName); 4. 删除兔子老师,将兔子老师下面的学生信息放到小鹿老师下面; public boolean deleteTeacher(String teacherName); 5. 修改小鹿老师下面mm学生的英语成绩改为100; public boolean updateStudent(String teacherName,String studentName); 具体要求 老师类里面属性有 编号 姓名,密码 学生表里面有 编号 姓名 语文成绩 数学成绩 英语成绩 要求用到抽象类,接口 用Map<老师姓名,List<学生>> 实现数据存取 以上方法定义按照后面要求定义,参数返回类型与要求一致;在main方法里面定义菜单循环调用输出结果,调用时传参数值按上面要求直接传,不用控制台输入。
文件无法写入!还有NullPointerException的问题
(1) 设计一个复数运算接口OperatorListener,定义抽象方法Complex add(Complex z) (2) 设计一个复数类Complex,此复数类实现OperatorListener接口,该类定义 私有属性:实部,虚部 方法:返回此复数的详细信息String toString(),输出格式例如3+4i 实现接口里的Complex add(Complex stu)抽象方法,实现复数的相加 构造方法:有参构造方法初始化成员变量 (3) 设计测试类Test,主函数要求产生两个复数对象,对象的成员变量值来自命令行参数,调用add方法,实现两个复数的相加,把相加的结果值写入到c:/ComputeInfo.txt文件中,并处理所有的异常信息。 自己写的源代码: (1) public interface OperatorListener{ public Complex add(Complex z); } (2) public class Complex implements OperatorListener{ private double real; private double imag; public Complex(){ } public Complex(double real,double imag){ this.real=real; this.imag=imag; } public Complex(Complex c){ real=c.real; imag=c.imag; } public double getReal(){ return real; } public double getImag(){ return imag; } public String toString(){ System.out.println(real+"+"+imag+"i"); return null; } public Complex add(Complex stu){ Complex p=new Complex(); p.real=real+stu.getReal(); p.imag=imag+stu.getImag(); return p; } } (3) import java.io.*; public class Test { public static void main(String[] args){ // TODO 自动生成的方法存根 try{ double x1,y1; double x2,y2; x1=Double.parseDouble(args[0]); y1=Double.parseDouble(args[1]); x2=Double.parseDouble(args[2]); y2=Double.parseDouble(args[3]); Complex com1=new Complex(x1,y1); Complex com2=new Complex(x2,y2); Complex com=com1.add(com2); File f=new File("C:\\ComputeInfo.txt"); FileOutputStream file=new FileOutputStream(f,true); file.write(com.toString().getBytes("utf-8")); file.close(); } catch(ArrayIndexOutOfBoundsException e){ System.out.println("你还没有输入呢,请输入数值!"); } catch(NumberFormatException e){ System.out.println("你输入的是字符,请输入数值!"); } catch(IOException e){ System.out.println("写入文件不成功!"); } } } 在eclipse上可以显示结果,但是下面多出了两行: Exception in thread "main" java.lang.NullPointerException at Test.main(Test.java:16) 问题出在了file.write(com.toString().getBytes("utf-8")); 这一行 也无法写入到指定文件,想求教下这一行怎么改?
为什么第一个Class必须带泛型,第二个就不需要?
@Pro(className = "com.test.annotation.Student",methodName = "study") public class ReflectTest { public static void main(String[] args) throws Exception { //1.解析注解 //获取该类的字节码对象 Class<ReflectTest> **reflectTestClass** = ReflectTest.class; //获取上面的注解对象 Pro pro = reflectTestClass.getAnnotation(Pro.class);//其实就是在内存中生成了一个该注解接口的子类实现对象 //调用注解对象中定义的抽象方法,获取返回值 String className = pro.className(); String methodName = pro.methodName(); Class **cls** = Class.forName(className); Object obj = cls.newInstance(); Method method = cls.getMethod(methodName); method.invoke(obj); } }
一个框架的讨论
公司在搞一个项目使用shh。Action类必须实现一个自定义的接口。类名叫Action ,里面只是定义一些变量,用于定义返回结果集的字符串。 struts.xml [code="java"]<result name="custom">/${ forward }</result> <result name="manager">/WEB-INF/page/${ forward }</result> [/code] Action类 [code="java"] public interface Action { /** * 后台页面返回 */ public static final String MANAGER = "manager"; /** * 自定义返回 */ public static final String CUSTOM = "custom"; /** * 后台输出返回 */ public static final String MESSAGE = "message"; } [/code] 在Struts的Action中使用一下代码返回结果集 [code="java"] return MANAGER; return CUSTOM; [/code] 我认为,这样做不好。 1、所有的Action都得实现Action类,不利于松解偶。 2、自定义的Action只是定义了变量,没有抽象方法,不算完整的接口 3、从对象来看,Struts的Action和自定义Action类没有存在和清晰的关系 没有存在“如果你是 Action 必须 实现Action的什么什么”,里面也只有静态变量。 4、我觉得在常量类里面定义这些变量会好一些 唯一存在的好处就是,如果需求改变,需要在Action中做一些初始化的时候,使用implements Action就能很好的处理,但是目前情况来看,只用于return MANAGER; return CUSTOM; 而已。 后来,我在Constant类中定义这些静态变量,Stuts的Action不在实现自定义Action接口。 [code="java"] public static final String ACTION_FORWARD_MANAGER = "manager";//后台页面返回 public static final String ACTION_FORWARD_CUSTOM = "custom";//自定义返回 public static final String ACTION_FORWARD_MESSAGE = "message";//后台输出返回 [/code] 在Action中使用 [code="java"] return Constant.ACTION_FORWARD_MANAGER; [/code] 不知道大家怎么看待这件事情?
java连连看数字换图片后重列的问题
我有一个源代码,是只有数字的,然后我加入了调用图片并且修改了一点代码后 不知道为什么点击重列就有问题了。reload函数那里是不是缺了什么,拜托各位大神帮我解决一下了~~~小女子谢过~ 下面是我的代码: import javax.swing.*; //AWT的扩展 import java.awt.*; //抽象窗口工具包 import java.awt.event.*; import java.io.*; class lianliankan implements ActionListener //实现ActionListener接口 { JFrame mainFrame; //主面板 ,JFrame定义的是一个容器,可向里面添加组件 Container thisContainer; //定义一个容器 JPanel centerPanel,southPanel,northPanel; //子面板 ,JPanel是个轻量级容器,可添加入JFrame中 JButton diamondsButton[][] = new JButton[6][5];//定义存储游戏按钮的数组 JButton exitButton,resetButton,newlyButton; //定义退出,重列,重新开始按钮 JLabel fractionLable=new JLabel("0"); //定义分数标签,并初始化为0. JButton firstButton,secondButton; //分别记录两次先后被选中的按钮 int grid[][] = new int[8][7];//储存游戏按钮位置 static boolean pressInformation=false; // 声明了一个静态布尔类型的变量,判断是否有按钮被选中 int x0=0,y0=0,x=0,y=0,fristMsg=0,secondMsg=0,validateLV; //游戏按钮的位置坐标 int i,j,k,n;//消除方法控制 //调用图片// private static Icon[] icons=new ImageIcon[6*6]; private static final String imgDir="c:/宠物连连看"; static{ try { File dir=new File(imgDir); File[] imgFiles=dir.listFiles(new FilenameFilter(){ public boolean accept(File dir,String name){ return name.toLowerCase().endsWith(".jpg"); } }); for(int i=0;i<10*10;i++){ icons[i]=new ImageIcon(imgFiles[i].getAbsolutePath()); } }catch(Exception e){ e.printStackTrace(); } } public void init(){ //init方法 mainFrame=new JFrame("连连看"); //定义主面板为命名为“连连看”的JFrame容器 thisContainer = mainFrame.getContentPane(); //初始化mainFrame. thisContainer.setLayout(new BorderLayout()); //定义布局为东西南北中的形式 centerPanel=new JPanel(); //初始化centerPanel southPanel=new JPanel(); //初始化southPanel northPanel=new JPanel(); //初始化northPanel thisContainer.add(centerPanel,"Center"); //将centerPanel加入mainFrame中的Center位置 thisContainer.add(southPanel,"South"); //将southPanel加入mainFrame中的South位置 thisContainer.add(northPanel,"North"); //将northPanel加入mainFrame中的North位置 centerPanel.setLayout(new GridLayout(6,5)); //将centerPanel初始化为6*5的网格布局 for(int cols = 0;cols < 6;cols++){ //依次对第0列到第5列进行操作 for(int rows = 0;rows < 5;rows++ ){ //依次对第0行到第4行进行操作 diamondsButton[cols][rows]=new JButton(String.valueOf(grid[cols+1][rows+1]));//新建按钮 diamondsButton[cols][rows]=new JButton(icons[grid[cols+1][rows+1]-1]); diamondsButton[cols][rows].addActionListener(this);//向此按键添加动作监听以接收来自它的动作 centerPanel.add(diamondsButton[cols][rows]);//将按键添加到centerPanel中 } } exitButton=new JButton("退出"); //新建“退出”按钮 exitButton.addActionListener(this); //向“退出”按钮添加事件监听 exitButton.setPreferredSize(new Dimension(150, 50)); exitButton.setFont(new Font("黑体", Font.PLAIN, 25)); //exitButton.setForeground(Color.red); //exitButton.setBackground(Color.white); resetButton=new JButton("重列"); //新建“重列”按钮 resetButton.addActionListener(this); //向“重列”按钮添加事件监听 resetButton.setPreferredSize(new Dimension(150, 50)); resetButton.setFont(new Font("黑体", Font.PLAIN, 25)); newlyButton=new JButton("再来一局"); //新建“再来一局”按钮 newlyButton.addActionListener(this); //向“再来一局”按钮添加事件监听 newlyButton.setPreferredSize(new Dimension(150, 50)); newlyButton.setFont(new Font("黑体", Font.PLAIN, 25)); southPanel.add(exitButton); //将“退出”按钮添加到southPanel southPanel.add(resetButton); //将“重列”按钮添加到southPanel southPanel.add(newlyButton); //将“再来一局”按钮添加到southPanel fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable.getText()))); northPanel.add(fractionLable); //将“分数”标签加入northPanel fractionLable.setPreferredSize(new Dimension(50,50)); fractionLable.setFont(new Font("黑体", Font.PLAIN, 25)); mainFrame.setBounds(280,100,1000,950); // x:X轴上的起点 ,y:Y轴上的起点 , width:长度, height:宽度 mainFrame.setVisible(true); //框架可见 } public void randomBuild() { int randoms,cols,rows; for(int twins=1;twins<=15;twins++) { randoms=(int)(Math.random()*25+1); //在1-25之间随机产生一个数字 for(int alike=1;alike<=2;alike++) { cols=(int)(Math.random()*6+1); //选中一个网格 rows=(int)(Math.random()*5+1); while(grid[cols][rows]!=0) { cols=(int)(Math.random()*6+1); //如果该格已经存在数字,则重新选择网格 rows=(int)(Math.random()*5+1); } this.grid[cols][rows]=randoms; //将随机产生的数字放入网格中 } } } public void fraction(){ fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable.getText())+100));//在原有数字上加100分 } public void reload() { int save[] = new int[30]; int n=0,cols,rows; int grid[][]= new int[8][7]; for(int i=0;i<=6;i++) { for(int j=0;j<=5;j++) { if(this.grid[i][j]!=0) { save[n]=this.grid[i][j]; //将现在任然存在的数字存入save中 n++; } } } n=n-1; this.grid=grid; while(n>=0) { cols=(int)(Math.random()*6+1); rows=(int)(Math.random()*5+1); //重新选择格子 while(grid[cols][rows]!=0) { cols=(int)(Math.random()*6+1); rows=(int)(Math.random()*5+1); //如果格子非空,则重新选择格子 } this.grid[cols][rows]=save[n];//将save中的数字放入所选择的的格子中 n--; } mainFrame.setVisible(false); pressInformation=false; //这里一定要将按钮点击信息归为初始 init(); //调用init for(int i = 0;i < 6;i++){ for(int j = 0;j < 5;j++ ){ if(grid[i+1][j+1]==0) //如果格子的值为0 diamondsButton[i][j].setVisible(false); //则按键不可见 } } } public void estimateEven(int placeX,int placeY,JButton bz) { if(pressInformation==false) //尚未有按键被选中 { x=placeX; y=placeY; secondMsg=grid[x][y]; //将该键的值存储到secondMsg secondButton=bz; //令secondButton为按下的键 pressInformation=true; //标示已经有键被选中 } else { //已经有按键被选中 x0=x; //将second中的值转存到first y0=y; fristMsg=secondMsg; firstButton=secondButton; x=placeX; y=placeY; //将该键存入second secondMsg=grid[x][y]; secondButton=bz; if(fristMsg==secondMsg && secondButton!=firstButton){ //如果两个格子数字相等且格子不相同 xiao(); //调用xiao方法 } } } public void xiao() { if((x0==x &&(y0==y+1||y0==y-1)) || ((x0==x+1||x0==x-1)&&(y0==y))){ //判断是否相邻 remove(); //调用remove } else{ for (j=0;j<7;j++ ) { if (grid[x0][j]==0){ //判断第一个按钮同行哪个按钮为空 if (y>j) { //如果第二个按钮的Y坐标大于空按钮的Y坐标说明第一按钮在第二按钮左边 for (i=y-1;i>=j;i-- ){ //判断第二按钮左侧直到第一按钮中间有没有按钮 if (grid[x][i]!=0) { k=0; break; } else{ k=1; } //K=1说明通过了第一次验证 } if (k==1) { linePassOne(); } } if (y<j){ //如果第二个按钮的Y坐标小于空按钮的Y坐标说明第一按钮在第二按钮右边 for (i=y+1;i<=j ;i++ ){ //判断第二按钮左侧直到第一按钮中间有没有按钮 if (grid[x][i]!=0){ k=0; break; } else { k=1; } } if (k==1){ linePassOne(); } } if (y==j ) { linePassOne(); } } if (k==2) { if (x0==x) { remove(); } if (x0<x) { for (n=x0;n<=x-1;n++ ) { if (grid[n][j]!=0) { k=0; break; } if(grid[n][j]==0 && n==x-1) { remove(); } } } if (x0>x) { for (n=x0;n>=x+1 ;n-- ) { if (grid[n][j]!=0) { k=0; break; } if(grid[n][j]==0 && n==x+1) { remove(); } } } } } for (i=0;i<8;i++ ) { //列 if (grid[i][y0]==0) { if (x>i) { for (j=x-1;j>=i ;j-- ) { if (grid[j][y]!=0) { k=0; break; } else { k=1; } } if (k==1) { rowPassOne(); } } if (x<i) { for (j=x+1;j<=i;j++ ) { if (grid[j][y]!=0) { k=0; break; } else { k=1; } } if (k==1) { rowPassOne(); } } if (x==i) { rowPassOne(); } } if (k==2){ if (y0==y) { remove(); } if (y0<y) { for (n=y0;n<=y-1 ;n++ ) { if (grid[i][n]!=0) { k=0; break; } if(grid[i][n]==0 && n==y-1) { remove(); } } } if (y0>y) { for (n=y0;n>=y+1 ;n--) { if (grid[i][n]!=0) { k=0; break; } if(grid[i][n]==0 && n==y+1) { remove(); } } } } } } } public void linePassOne(){ if (y0>j){ //第一按钮同行空按钮在左边 for (i=y0-1;i>=j ;i-- ){ //判断第一按钮同左侧空按钮之间有没按钮 if (grid[x0][i]!=0) { k=0; break; } else { k=2; } //K=2说明通过了第二次验证 } } if (y0<j){ //第一按钮同行空按钮在与第二按钮之间 for (i=y0+1;i<=j ;i++){ if (grid[x0][i]!=0) { k=0; break; } else{ k=2; } } } } public void rowPassOne(){ if (x0>i) { for (j=x0-1;j>=i ;j-- ) { if (grid[j][y0]!=0) { k=0; break; } else { k=2; } } } if (x0<i) { for (j=x0+1;j<=i ;j++ ) { if (grid[j][y0]!=0) { k=0; break; } else { k=2; } } } } public void remove(){ firstButton.setVisible(false); //第一个按键不可见 secondButton.setVisible(false); //第二个按键不可见 fraction(); //调用fraction, 在当前分数上加100分 pressInformation=false; //使该静态变量还原为false k=0; grid[x0][y0]=0; //清除该游戏按钮 grid[x][y]=0; //清除该游戏按钮 } public void actionPerformed(ActionEvent e) { if(e.getSource()==newlyButton){ //如果newlyButton产生动作 int grid[][] = new int[8][7]; //产生新的存储按键的数组 this.grid = grid; randomBuild(); //调用randomBuild mainFrame.setVisible(false); //使当前mainFrame不可见 pressInformation=false; //使该静态变量还原为false init(); //调用init } if(e.getSource()==exitButton) //如果exitButton产生动作 System.exit(0); //退出程序 if(e.getSource()==resetButton) //如果resetButton产生动作 reload(); //调用reload for(int cols = 0;cols < 6;cols++){ for(int rows = 0;rows < 5;rows++ ){ if(e.getSource()==diamondsButton[cols][rows]) //如果游戏按键产生动作 estimateEven(cols+1,rows+1,diamondsButton[cols][rows]); //调用estimateEven } } } public static void main(String[] args) { lianliankan llk = new lianliankan(); //初始化 llk.randomBuild(); //调用randomBuild llk.init(); //调用init } } ![图片说明](https://img-ask.csdn.net/upload/201606/18/1466244507_872958.png)
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问