think in java第六章笔记

本文探讨了Java中protected关键字的应用,如何通过它实现对派生类的特定访问控制,并讨论了final关键字的作用及注意事项。此外,还介绍了类继承的概念及其图形表示方法。

1.在实际应用中,经常想把某些东西深深地隐藏起来,但同时允许访问衍生类的成员。protected关键字可帮助我们做得到。它的意思是:它本身是私有的,但可由这个类继承的任何东西或者同一个包内的其他任何东西访问。

2.

class Instrument {
	public void play() {
		
	}
	static void tune(Instrument i) {
		i.play();
	}
}
public class Wind extends Instrument{

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Wind flute = new Wind();
		Instrument.tune(flute);
	}

}
在tune中,代码适用于Instrument以及从Instrument衍生出来的任何东西。

3.类继承图的画法是根位于最顶部,再逐渐向下扩展。

4.为判断自己到底应该选用合成还是继承,一个最简单的方法就是考虑是否需要从新类上溯造型回基础类。若必须上溯,就需要继承。但如果不需要上溯造型,就应该提醒自己防止继承的滥用。


5.

<pre name="code" class="java">class Value {
	int i = 1;
}

public class FinalData {

	final int i1=9;
	static final int i2 = 99;
	public static final int i3=39;
	
	final int i4=(int)(Math.random()*20);
	static final int i5=(int)(Math.random()*20);
	
	Value v1=new Value();
	final Value v2 = new Value();
	static final Value v3 = new Value();
	
	final int[] a={1,2,3,4,5,6};
	
	public void print(String id) {
		System.out.println(id+":"+"i4="+i4+",i5="+i5);
	}
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		FinalData  fd1 = new FinalData();
		//fd1.i1++; cant't change value
		fd1.v2.i++;
		fd1.v1 = new Value();
		
		for(int i = 0; i <fd1.a.length; i++) {
			fd1.a[i]++;
		}
		
		//fd1.v2 = new Value();
		//fd1.v3 = new Value();
		//fd1.a = new int[3];
		
		fd1.print("fd1");
		System.out.println("Creating new FinalData");
		FinalData fd2 = new FinalData();
		fd1.print("fd1");
		fd2.print("fd2");
	}

}



不能由于某样东西的属性是final,就认定它的值能在编译期知道。i4和i5在运行期间随即生成数字。例子的这一部分也向大家揭示出将final值设为static和非static之间的差异。只有当值在运行期间初始化的前提下,这种差异才会揭示出来。对于fd1和fd2来说,i4的值是唯一的,但i5的值不会由于创建了另一个FinalData对象而发生改变。因为它的属性是static,而且在载入时初始化,而非创建一个对象时初始化。


6.将类定义为final后,结果只是禁止进行继承——没有更多限制。然而,由于它禁止了继承,所以一个final类中的所有方法都默认为final。

7.

class Insect {
	int i = 9;
	int j;
	Insect() {
		prt("i="+i+", j="+j);
		j=39;
	}
	static int x1=prt("static Insect.x1 initialized");
	static int prt(String s) {
		System.out.println(s);
		return 47;
	}
}
public class Beetle extends Insect{
	int k = prt("Beetle.k initialized");
	Beetle() {
		prt("k = "+k);
		prt("j = "+j);
	}
	static int x2=prt("static Beetle.x2 initialized");
	static int prt(String s) {
		System.out.println(s);
		return 63;
	}
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		prt("Beetle constructor");
		Beetle b = new Beetle();
	}

}

对Beetle运行时,发生的第一件事情是装载程序到外面找到那个类。在转载的过程中,装载程序注意它有一个基础类(即extends关键字要表达的意思),所以随之将其装入。无论是否准备生成那个基础类的一个对象,这个过程都会发生。若基础类含有另一个基础类,则另一个基础类随即也会装入。接下来,会在根基础类执行static初始化,再下一个衍生类执行。保证这个顺序非常关键,因为衍生类的初始化可能要依赖对基础类成员的正确初始化。

此时,必要的类已全部装载完毕,所以能够创建对象。首先,这个对象中的所有基本数据类型都会设成它们的默认值,而将对象句柄设为null。随后调用基础类构建器。

基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现扩展应用。; 适合人群:具备电力系统基础知识Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
<think>我们正在生成一份关于Java基础语法的Markdown格式笔记。根据要求,笔记需要符合Markdown语法,并且按照用户提供的引用示例(如引用[1]引用[2])来组织内容。同时,我们还需要在行内数学表达式(如果有的话)使用$...$,独立公式使用$$...$$,但Java基础语法中数学公式较少,所以主要关注代码块文本格式。 根据引用[1][2],我们可以知道笔记应该包含Java的基本概念、语法、常用库等,并且以实例辅助说明。另外,引用[3]提到Markdown基础语法,我们需要注意换行等格式。 我们将按照以下结构组织笔记(根据常见的Java基础语法内容): 1. Java程序结构 2. 基本数据类型 3. 变量与常量 4. 运算符 5. 控制语句(条件、循环) 6. 方法 7. 数组 8. 注释 每个部分将包含简要说明代码示例。 注意:由于用户要求生成Markdown格式的笔记,我们将使用Markdown的标题、代码块等语法。 另外,根据指令,我们需要在最后生成相关问题。 开始编写:</think>以下是一份关于Java基础语法的Markdown格式笔记,结合了基础语法要点代码示例: # Java基础语法笔记 ## 1. 程序结构 ```java public class HelloWorld { // 类声明 public static void main(String[] args) { // 主方法 System.out.println("Hello, World!"); // 输出语句 } } ``` - `public class`:类访问修饰符 - `main`方法:程序入口点 - 语句以分号`;`结束 ## 2. 基本数据类型 | 类型 | 大小 | 示例 | 默认 | |-----------|----------|-----------------|----------| | `byte` | 8位 | `10` | `0` | | `int` | 32位 | `100` | `0` | | `double` | 64位 | `3.14` | `0.0` | | `char` | 16位 | `'A'` | `\u0000` | | `boolean` | 1位 | `true`/`false` | `false` | ## 3. 变量声明 ```java int count = 5; // 整型变量 final double PI = 3.14159; // 常量(final) String message = "Welcome!"; // 字符串对象 ``` ## 4. 运算符 ```java int a = 10, b = 3; System.out.println(a + b); // 13 加法 System.out.println(a % b); // 1 取模 System.out.println(a == b); // false 相等比较 System.out.println(a > b && a < 20); // true 逻辑与 ``` ## 5. 控制结构 ### 条件语句 ```java int score = 85; if (score >= 90) { System.out.println("A"); } else if (score >= 80) { System.out.println("B"); // 输出B } else { System.out.println("C"); } ``` ### 循环语句 ```java // for循环 for (int i = 0; i < 5; i++) { System.out.print(i + " "); // 输出: 0 1 2 3 4 } // while循环 int j = 3; while (j > 0) { System.out.print(j-- + " "); // 输出: 3 2 1 } ``` ## 6. 数组 ```java // 声明初始化 int[] numbers = {2, 4, 6, 8}; // 访问元素 System.out.println(numbers[0]); // 输出2 // 遍历数组 for (int num : numbers) { System.out.print(num + " "); // 输出: 2 4 6 8 } ``` ## 7. 方法 ```java // 方法定义 public static int add(int a, int b) { return a + b; } // 方法调用 int result = add(7, 3); // result = 10 ``` ## 8. 注释 ```java // 单行注释 /* 多行注释 第二行 */ /** * Javadoc文档注释 * @param a 第一个加数 * @param b 第二个加数 * @return 两数之 */ ``` ## 9. 输入输出 ```java import java.util.Scanner; // 导入扫描器 Scanner scanner = new Scanner(System.in); System.out.print("请输入姓名: "); String name = scanner.nextLine(); // 读取字符串输入 System.out.println("你好, " + name); ``` > 提示:Java严格区分大小写,`main``Main`是不同的标识符[^1]。所有代码块需放在类中执行[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值