Java从零单排Round1----包(Package)

本文通过《TheCompleteReference》中的经典例子,详细解释了Java包中类成员的访问权限问题,包括访问修饰符的使用及不同包间类成员的访问限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引用《The Complete Reference》中的经典例子来说明Java包中类成员的访问权限问题



下面的例子显示了访问修饰符的所有组合。该例有两个包和五个类。记住这两个不同包中的类需要被存储在以它们的包p1、p2命名的目录下。

第一个包定义了三个类:ProtectionDerived 和 SamePackage:

Protection类以合法的保护模式定义了四个int变量,变量n默认权限,变量n_pri是private权限,变量n_pro是protected权限,变量n_pub是public权限。Derived类作为Protection同一个包中的子类出现。

SamePackage类作为Protection同一个包中的非子类出现。

第二个包定义了两个类:Protection2 和 OtherPackage。Protection2类作为Protection的其他包中的子类出现。

OtherPackage类作为Protection的其他包中的非子类出现。这些类都试图访问Protection中的所有成员,访问受限的语句被注释掉,并加以注明。


下面是Protection.java文件:

package p1;

public class Protection
{
	int n = 1;
	private int n_pri = 2;
	protected int n_pro = 3;
	public int n_pub = 4;

	public Protection()
	{
		System.out.println("base constructor");
		System.out.println("n = "+n);
		System.out.println("n_pri = "+n_pri);
		System.out.println("n_pro = "+n_pro);
		System.out.println("n_pub = "+n_pub);
	}
}

下面是Derived.java文件:

package p1;


class Derived extends Protection
{
	Derived()
	{
		System.out.println("derived constructor");
		System.out.println("n = "+n);

		//class only
		//System.out.println("n_pri = "+n_pri);

		System.out.println("n_pro = "+n_pro);
		System.out.println("n_pub = "+n_pub);
	}
}

下面是SamePackage.java文件:

package p1;

class SamePackage
{
	SamePackage()
	{
		Protection p = new Protection();
		System.out.println("same package constructor");
		System.out.println("n = "+p.n);

		//class only
		//System.out.println("n_pri = "+p.n_pri);

		System.out.println("n_pro = "+p.n_pro);
		System.out.println("n_pub = "+p.n_pub);
	}
}

下面是Protection2.java文件:

package p2;

class Protection2 extends p1.Protection
{
	Protection2()
	{
		System.out.println("derived other package constructor");

		//class or package only
		//System.out.println("n = "+n);

		//class only
		//System.out.println("n_pri = "+n_pri);

		System.out.println("n_pro = "+n_pro);
		System.out.println("n_pub = "+n_pub);
	}
}

下面是OtherPackage.java文件:

package p2;

class OtherPackage
{
	OtherPackage()
	{
		p1.Protection p = new p1.Protection();
		System.out.println("other pacage constructor");

		//class or package only
		//System.out.println("n = "+p.n);

		//class only
		//System.out.println("n_pri = "+p.n_pri);

		//class,subclass or package only
		//System.out.println("n_pro = "+p.n_pro);
	
		System.out.println("n_pub = "+p.n_pub);
	}
}

下面试试这两个包,通过以下两个测试文件

包p1的测试文件:

/*
Demo package p1.
*/

package p1;


public class Demo
{
	public static void main(String[] args) 
	{
		Protection ob1 = new Protection();
		Derived ob2 = new Derived();
		SamePackage ob3 = new SamePackage();
	}
}

包p2的测试文件:

/*
Demo package p1.
*/

package p1;


public class Demo
{
	public static void main(String[] args) 
	{
		Protection ob1 = new Protection();
		Derived ob2 = new Derived();
		SamePackage ob3 = new SamePackage();
	}
}

编译:

运行Demo1:


运行Demo2:



由此我们可以得到以下结论:



内容概要:《中文大模型基准测评2025年上半年报告》由SuperCLUE团队发布,详细评估了2025年上半年中文大模型的发展状况。报告涵盖了大模型的关键进展、国内外大模型全景图及差距、专项测评基准介绍等。通过SuperCLUE基准,对45个国内外代表性大模型进行了六大任务(数学推理、科学推理、代码生成、智能体Agent、精确指令遵循、幻觉控制)的综合测评。结果显示,海外模型如o3、o4-mini(high)在推理任务上表现突出,而国内模型如Doubao-Seed-1.6-thinking-250715在智能体Agent和幻觉控制任务上表现出色。此外,报告还分析了模型性价比、效能区间分布,并对代表性模型如Doubao-Seed-1.6-thinking-250715、DeepSeek-R1-0528、GLM-4.5等进行了详细介绍。整体来看,国内大模型在特定任务上已接近国际顶尖水平,但在综合推理能力上仍有提升空间。 适用人群:对大模型技术感兴趣的科研人员、工程师、产品经理及投资者。 使用场景及目标:①了解2025年上半年中文大模型的发展现状与趋势;②评估国内外大模型在不同任务上的表现差异;③为技术选型和性能优化提供参考依据。 其他说明:报告提供了详细的测评方法、评分标准及结果分析,确保评估的科学性和公正性。此外,SuperCLUE团队还发布了多个专项测评基准,涵盖多模态、文本、推理等多个领域,为业界提供全面的测评服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值