封装:

1.目的:保证对象中的实例变量无法随意修改/访问,只能通过我们自己设定的入口,出口(set / get)来间接操作;屏蔽类中复杂的结构,使我们程序员在主方法中关联对象写代码时,思路/代码格式更加清晰;

2.操作:将某些属性私有化(private修饰),再声明相应的 set ,get 方法,这样我们就可以通过 set / get 方法来 修改 / 访问 相应的私有属性了;

嘴上说不如举栗子:

class tool{
private int a;
private String b;
private String c;
public tool() {
}
public tool(int a, String b, String c) {
this.a = a;
this.b = b;
this.c = c;
}
public int getA() {
return a;
}
public void setA(int a) {
this.a = a;
}
public String getB() {
return b;
}
public void setB(String b) {
this.b = b;
}
public String getC() {
return c;
}
public void setC(String c) {
this.c = c;
}
}
public class pra{
public static void main(String[] args) {
tool t1=new tool();
//创建tool类型引用t1,并调用无参构造方法为t1在堆内存指向的对象中的三个实例变量赋初始值
System.out.println(t1.getA()+t1.getB()+t1.getC()+"---第一次输出结果");
//利用get方法访问对象中的三个私有属性
t1.setA(100);
t1.setB("是");
t1.setC("100");
//利用set方法修改对象中的三个私有属性
System.out.println(t1.getA()+t1.getB()+t1.getC()+"---第二次输出结果");
tool t2=new tool(100,"是","100");
//创建tool类型引用t2,并调用有参构造方法为t2在堆内存指向的对象中的三个实例变量赋值
System.out.println(t1.getA()+t1.getB()+t1.getC()+"---第三次输出结果");
}
}

输出结果:

0nullnull---第一次输出结果
100是100---第二次输出结果
100是100---第三次输出结果 Process finished with exit code 0

静态变量的使用(static):

1.什么时候选择声明静态变量:

对于同一类型的所有对象来说,一直不变的属性就声明为静态变量,就 类 中国人 来说,它其中的国籍属性除了中国,还能是什么?所以当一个类型的对象中的一个属性始终不变,或者说对于所有同类型的对象来说,此变量中储存的数据 都应该是一样的,这个时候我们就选择声明静态变量;

2.为什么要在符合条件的前提下,尽量使用静态变量:

还拿100个中国人举例子吧,如果我们把国籍声明为实例变量,那么我们创建 n 个中国人对象,就要在堆内存中占用 n 块大小相同的空间来储存同样的数据 “ 中国  ”,在可以达到相同的效果的前提下,选择占用内存大的代码是程序员的大忌!而如果我们将国籍声明为静态变量,那么我们无论创建多少个中国人对象,都只会在方法区内存中占用一块固定大小的内存空间来储存“ 中国 ”,以此来节省内存,因为静态变量不像实例变量那样属于“对象级别的变量”,它属于类级别的变量,所以无论对象是否创建,都不影响用“ 类名 . ”的方式来访问它。

辅助理解内存图:

实例方法 / 静态方法 的选择:

easy,在已经知道什么时候声明实例变量什么时候声明静态变量的前提下,方法体中需要实例变量的方法就声明为实例方法,反之方法体中不需要访问实例变量的方法就声明为静态方法;

代码块:

1.用途:代码块分为静态代码块和实例代码块,静态代码块执行时机---类加载时(优先于类体中的所有代码);动态代码块执行时机---调用构造方法时(优先于方法体中的所有代码),并且静态代码块优先于实例代码块。所以我们可以通过输出结果来判断---什么时候哪个类体执行了 / 什么时候某个构造方法执行了;

2.格式及优先级顺序展示:

public class pra{
static {
System.out.println("静态代码块 a 执行了!");
}
{
System.out.println("实例代码块 a 执行了!");
}
public static void main(String[] args) {
pra t1=new pra();
}
public pra(){
System.out.println("无参构造方法 执行了!");
}
static {
System.out.println("静态代码块 b 执行了!");
}
{
System.out.println("实例代码块 b 执行了!");
}
}

运行结果1(将创建 pra 对象代码注释掉)与运行结果2(取消注释,还原为代码):

静态代码块 a 执行了!
静态代码块 b 执行了! Process finished with exit code 0 (结果一) 静态代码块 a 执行了!
静态代码块 b 执行了!
实例代码块 a 执行了!
实例代码块 b 执行了!
无参构造方法 执行了! Process finished with exit code 0 (结果二)

随笔:

1. public :啥都能访问 ;private 只有在声明它的类中可以访问 ;

2.空指针异常问题:这个问题我感觉没什么好说的,“ 引用 ”是一个储存对象地址的变量,如果它里面什么地址也没存(null),那在使用它时,就会出现空指针异常;


由于博主目前还没有将 Java-SE 的知识都学完,所以有些地方可能说的有些片面,若前辈们能够指点一二就更好了      (~ ̄(OO) ̄)ブ

【JAVA】笔记(3)---封装;如何选择声明静态变量还是实例变量;如何选择声明静态方法还是实例方法;静态代码块与实例代码块的执行顺序与用途;的更多相关文章

  1. Java的初始化块、静态初始化块、构造函数的执行顺序及用途探究

    Java与C++有一个不同之处在于,Java不但有构造函数,还有一个”初始化块“(Initialization Block)的概念.下面探究一下它的执行顺序与可能的用途. 执行顺序 首先定义A, B, ...

  2. 静态(static)代码块、构造代码块、构造函数、父类子类执行顺序

    静态代码块:static修饰的代码块. 在类加载-初始化的时候进行,主要目的是给变量赋予初始值 构造代码块:直接在类中定义且没有加static关键字的代码块称为构造代码块. java会把构造代码块放到 ...

  3. Java类成员变量、普通成员变量、初始化块、构造方法的初始化和执行顺序

    结论:执行的大致顺序如下, (1) 在一个不存在继承的类中:初始化static变量,执行static初始化块-->初始化普通成员变量(如果有赋值语句),执行普通初始化块-->构造方法 (2 ...

  4. JAVA代码中加了Try...Catch的执行顺序

    public static String getString(){ try { //return "a" + 1/0; return "a"; } catch ...

  5. java 子类、父类中静态代码块、字段,非静态代码块、字段以及构造函数的初始化顺序和次数

    一个类中的数据初始化顺序是面试官非常喜欢出的面试题之一,本文用一个实例来介绍java中子类.父类中静态代码块.字段,非静态代码块.字段以及构造函数的执行顺序和次数. 一.包结构

  6. 【转】java静态代码块和构造方法执行顺序

    先看看下面几个类,然后判断它们的输出public class A { static{System.out.print(1);}public A(){System.out.print(2);}} pub ...

  7. Java学习笔记 - 类方法与代码块的执行顺序

    类的初始化顺序 使用一个简单的父子类例子来做示范,代码执行顺序在代码后有标注. class Parent { public static String p_StaticField = "父类 ...

  8. Java Object 构造方法的执行顺序

    Java Object 构造方法的执行顺序 @author ixenos 为了使用类而做的准备工作包括三个步骤 1)加载:类加载器查找字节码(一般在classpath中找),从字节码创建一个Class ...

  9. Java内存的 静态方法和实例方法的区别及使用场景

    注意:变量指基本数据类型非对象,局部变量不能被静态修饰 1.(静态)成员变量存放在data segment区(数据区),字符串常量也存放在该区 2.非静态变量,new出来的对象存放在堆内存,所有局部变 ...

随机推荐

  1. ARC122C-Calculator【乱搞,构造】

    正题 题目链接:https://atcoder.jp/contests/arc122/tasks/arc122_c 题目大意 一个数对开始是\((0,0)\),每次可以选择一个数加一或者让一个数加上另 ...

  2. Javascript设计模式之原型模式、发布订阅模式

    原型模式 原型模式用于在创建对象时,通过共享某个对象原型的属性和方法,从而达到提高性能.降低内存占用.代码复用的效果. 示例一 function Person(name) { this.name = ...

  3. LINUX系统入侵排查

    当企业发生黑客入侵.系统崩溃或其它影响业务正常运行的安全事件时,急需第一时间进行处理,使企业的网络信息系统在最短时间内恢复正常工作,进一步查找入侵来源,还原入侵事故过程,同时给出解决方案与防范措施,为 ...

  4. mimikatz使用笔记

    一.获取密码# privilege::debug sekurlsa::logonpasswords mimikatz.exe "sekurlsa::debug" "sek ...

  5. Serverless 解惑——函数计算如何安装字体

    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数计算准 ...

  6. 题解 「HDU6403」卡片游戏

    link Description 桌面上摊开着一些卡牌,这是她平时很爱玩的一个游戏.如今卡牌还在,她却不在我身边.不知不觉,我翻开了卡牌,回忆起了当时一起玩卡牌的那段时间. 每张卡牌的正面与反面都各有 ...

  7. app定位工具介绍

     一.元素获取工具WEditor使用   1.安装WEditor:pip3 install weditor   2.启动WEditor:python3 -m weditor    Android : ...

  8. 配置pyenv环境

    git clone https://github.com/pyenv/pyenv.git ~/.pyenv echo 'export PYENV_ROOT="$HOME/.pyenv&quo ...

  9. eclipse javase版安装插件开发web项目

    最近学习开发javaweb,但是安装的却是java se版的eclipse,但其无法新建web项目,即找不到Dynamic Web.所以需要下载相应插件.以下为操作过程. 1. 在联网的情况下,打开e ...

  10. 莱特币(LTC)开发环境搭建

    Linux系统下搭建莱特币LTC开发环境 1.简介 2.LTC 客户端下载 3.解压到一个固定的目录中 4.启动客户端 4.1.参数解释: 4.2.更多详细的配置 5.执行命令测试一下 6.获取莱特币 ...