内部类

内部类:如果A类需要直接访问B类中的成员,而B类又需要建立A类的对象。这时,为了方便设计和访问,直接将A类定义在B类中。就可以了。A类就称为内部类。内部类可以直接访问外部类中的成员。而外部类想要访问内部类,必须要建立内部类的对象。

-----------------------------------------------------

class Outer{

    int num = 4;   

    class  Inner {

        void show(){

            System.out.println("inner show run "+num);         

        }

    }

    public void method(){

        Inner in = new Inner();//创建内部类的对象。

        in.show();//调用内部类的方法。

    }

}

-------------------------------------------------------

当内部类定义在外部类中的成员位置上,可以使用一些成员修饰符修饰 private、static。

1:默认修饰符。

直接访问内部类格式:外部类名.内部类名 变量名 =  外部类对象.内部类对象;

Outer.Inner in = new Outer.new Inner();//这种形式很少用。

  但是这种应用不多见,因为内部类之所以定义在内部就是为了封装。想要获取内部类对象通常都通过外部类的方法来获取。这样可以对内部类对象进行控制。

2:私有修饰符。

  通常内部类被封装,都会被私有化,因为封装性不让其他程序直接访问。

3:静态修饰符。

  如果内部类被静态修饰,相当于外部类,会出现访问局限性,只能访问外部类中的静态成员。

  注意;如果内部类中定义了静态成员,那么该内部类必须是静态的。

 

内部类编译后的文件名为:“外部类名$内部类名.java”;

 

为什么内部类可以直接访问外部类中的成员呢?

那是因为内部中都持有一个外部类的引用。这个是引用是 外部类名.this

内部类可以定义在外部类中的成员位置上,也可以定义在外部类中的局部位置上。

当内部类被定义在局部位置上,只能访问局部中被final修饰的局部变量。

 public void method(){
           final String name = "asd";
            int aa;
            Inner in = new Inner();//创建内部类的对象。
            in.show();//调用内部类的方法。

            class Inner2{
                public void inmethod(){
                    System.out.println(name);
                }
            }

 

匿名内部类:没有名字的内部类。就是内部类的简化形式。一般只用一次就可以用这种形式。匿名内部类其实就是一个匿名子类对象想要定义匿名内部类:需要前提,内部类必须继承一个类或者实现接口。

 

匿名内部类的格式:new 父类名&接口名(){ 定义子类成员或者覆盖父类方法 }.方法。

 

匿名内部类的使用场景:

当函数的参数是接口类型引用时,如果接口中的方法不超过3个。可以通过匿名内部类来完成参数的传递。

其实就是在创建匿名内部类时,该类中的封装的方法不要过多,最好两个或者两个以内。

--------------------------------------------------------

//面试

        //1

        new Object(){

            void show(){

                System.out.println("show run");           

            }

        }.show();

        //2

        Object obj = new Object(){

            void show(){

                System.out.println("show run");

            }

        };

        obj.show();

       

        1和2的写法正确吗?有区别吗?说出原因。

        写法是正确,1和2都是在通过匿名内部类建立一个Object类的子类对象。

        区别:

        第一个可是编译通过,并运行。

        第二个编译失败,因为匿名内部类是一个子类对象,当用Object的obj引用指向时,就被提升为了

        Object类型,而编译时检查Object类中是否有show方法,所以编译失败。

-------------------------------------------------------

class InnerClassDemo6 {

    +(static)class Inner{

        void show(){}

    }

    public void method(){

        this.new Inner().show();//可以

    }

    public static void main(String[] args) {//static不允许this

        This.new Inner().show();//错误,Inner类需要定义成static

    }

}

------------------------------------------------------

interface Inter{

    void show();

}

class Outer{//通过匿名内部类补足Outer类中的代码。

    public static Inter method(){

        return new Inter(){

            public void show(){}

        };

    }

}

class InnerClassDemo7 {

    public static void main(String[] args) {

        Outer.method().show();

    /*

        Outer.method():意思是:Outer中有一个名称为method的方法,而且这个方法是静态的。

        Outer.method().show():当Outer类调用静态的method方法运算结束后的结果又调用了show方法,意味着:method()方法运算完一个是对象,而且这个对象是Inter类型的。

    */

        function (new Inter(){

            public void show(){}

        }); //匿名内部类作为方法的参数进行传递。

    }

    public static void function(Inter in){

        in.show();

    }

}

 

 

public class Outer
{
        int num = 4;
        class  Inner {
            void show(){
                System.out.println("inner show run "+num);
            }
        }
        public void method(){
            Inner in = new Inner();//创建内部类的对象。
            in.show();//调用内部类的方法。
        }

        @Test//内部类外围
        public void test(){
            Outer.Inner in =new Outer().new Inner();
//this. 只能在外部类内使用,引用内部类
            Outer.Inner inn = this.new Inner();

        }
    }
//外部
class test {
  
    public void testasd() {
//在外部,只能通过这个创建内部类,但不推荐使用。
        Outer.Inner in = new Outer().new Inner();
       // Outer.Innerj
    }
}

 

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值