彻底填平Static坑(细节决定成败)
static
学习的过程就是填坑的过程,可不要偷懒想着跳过去,你现在跳过去,就相当于给自己挖了一个坑,你迟早会掉进去的,为了避免不掉坑,所以,努力填坑吧!
一.如果没有static会怎样?
需求:
1:定义Student类
1:姓名、国籍,说话行为
2:多个构造,重载形式体现
2:学生的国籍都是确定的
1:国籍可以进行显示初始化
public class Student {
String name;//姓名
String country;//国籍
public Student(String name, String country) {
this.name = name;
this.country = country;
}
public void speak(){
System.out.println("姓名:"+this.name+" "+"国籍:"+this.country);
}
}
class Test{
public static void main(String[] args) {
Student student = new Student("何道昌","中国");
Student student1 = new Student("孙双双","中国");
student.speak();
student1.speak();
}
}
运行结果: 姓名:何道昌 国籍:中国
姓名:孙双双 国籍:中国
目前存在的问题:
现在我们已知学生都是中国人,现在我们每创建一个学生对象,就要给所有学生的国籍属性赋相同的值,这样造成堆内存空间资源浪费
目前方案:
把“中国”这个数据移动到数据共享区中,共享这个数据给所有的Student对象使用即可
疑问:如何才能把这个数据移动到数据共享区中共享呢?
解决方案:
只需要用static修饰该数据即可
静态的成员变量只会在数据共享区中维护一份,而非静态成员变量的数据会在每个对象中都维护一份
public class Student {
String name;//姓名
//使用了static修饰country,那么这时候country就是一个共享的数据
static String country = "中国";//国籍
//构造函数
public Student(String name) {
this.name = name;
}
//说话行为
public void speak(){
System.out.println("姓名:"+this.name+" "+"国籍:"+country);
}
}
class Test{
public static void main(String[] args) {
Student student = new Student("何道昌");
Student student1 = new Student("孙双双");
student.speak();
student1.speak();
}
}
运行结果: 姓名:何道昌 国籍:中国
姓名:孙双双 国籍:中国
下面我来详细解说static
static(静态修饰符)
1.static修饰静态变量
如果有数据需要被共享给所有对象使用时,那么就可以使用static修饰
静态成员变量的访问方式:
方式一: 可以使用对象进行访问
格式:对象.变量名
方式二:可以使用类名进行访问
格式:类名.变量名
注意:
1.非静态的成员变量只能使用对象进行访问,不能使用类命进行访问
public class Student {
String name;//姓名 非静态成员变量
//使用了static修饰country,那么这时候country就是一个共享的数据
static String country = "中国";//国籍 静态成员变量
//构造函数
public Student(String name) {
this.name = name;
}
//说话行为
public void speak(){
System.out.println("姓名:"+this.name+" "+"国籍:"+country);
}
}
class Test{
public static void main(String[] args) {
Student student = new Student("何道昌");
System.out.println(student.name);//用对象访问非静态变量
Systen.out.println(student.country);//用对象访问静态变量
System.out.println(Student.country);//用类命访问静态变量
}
}
运行结果: 何道昌
中国
中国
2.千万不要为了方便访问数据而使用static修饰成员变量,只有成员变量的数据真正需要被共享的时候,才使用static修饰
static修饰成员变量的应用场景:如果一个数据需要被所有对象共享使用的时候,用static修饰
2.static修饰成员函数(静态的成员方法)
静态成员函数的访问方式:
方式一: 可以使用对象进行访问
格式:对象.静态的函数名
方式二:可以使用类名进行访问
格式:类名.静态的函数名
推荐使用类名直接访问静态的成员
原因:
1.方便
2.节省内存
静态函数要注意的事项:
1.静态函数是可以调用类名或者对象进行调用的,而非静态函数只能使用对象进行调用
2.静态的函数可以访问静态的成员,但是不能直接访问非静态的成员
3.非静态的函数是可以直接访问静态与非静态的成员
4.静态函数不能出现this或者super关键字
public class Student {
String name;//姓名 非静态成员变量
//使用了static修饰country,那么这时候country就是一个共享的数据
static String country = "中国";//国籍 静态成员变量
//构造函数
public Student(String name) {
this.name = name;
}
//说话行为
//静态成员方法
public static void speak(){
System.out.println("国籍:"+country);
}
//学习行为
//非静态成员方法
public void study(){
System.out.println(name+"好好学习");
}
}
class Test{
public static void main(String[] args) {
Student student = new Student("何道昌");
System.out.println(student.name);//用对象访问非静态变量
System.out.println(student.country);//用对象访问静态变量
System.out.println(Student.country);//用类命访问静态变量
student.study();//用对象访问非静态方法
student.speak();//用对象访问静态方法
Student.speak();//用类名访问静态方法
}
}
运行结果: 何道昌
中国
中国
何道昌好好学习
国籍:中国
国籍:中国
静态的成员变量与非静态的成员变量的区别:
1.作用上的区别:
1、静态的成员变量的作用是共享一个数据给所有的对象使用
2、非静态的成员变量的作用是描述一类事物的公共属性
2.数量和存储位置上的区别:
1、静态成员变量是在存储方法区内存中,而且只会存在一份数据
2、非静态的成员变量是存储在堆内存中,有n个对象就有n份数据
3、生命周期的区别:
1、静态的成员变量数据是随着类的加载而存在,随着类文件的消失而消失
2、非静态的成员变量数据是随着对象的创建而存在,随着对象被垃圾回收器回收而消失
静态函数不能访问非静态的成员?
静态函数只要存在有对象,那么也可以访问非静态的数据,只是不能直接访问。
最后,继续用这个例子穿插一下静态代码块的知识
静态代码块是在Student.class文件加载到内存的时候就马上执行的
public class Student {
String name;//姓名 非静态成员变量
//使用了static修饰country,那么这时候country就是一个共享的数据
static String country = "中国";//国籍 静态成员变量
//静态代码块
static{
System.out.println("静态代码块执行了!!");
}
//构造函数
public Student(String name) {
this.name = name;
}
//说话行为
//静态成员方法
public static void speak(){
System.out.println("国籍:"+country);
}
//学习行为
//非静态成员方法
public void study(){
System.out.println(name+"好好学习");
}
}
class Test{
public static void main(String[] args) {
Student.speak();
}
}
运行结果: 静态代码块执行了!!
国籍:中国
理解到这,你再看看下面的分析图,应该还会有所收获

最后再跟大家分享一句话:
一个人若想改变自己的命运,最重要的是要改变自己,改变心态,改变环境,这样命运也会随之改变
读完此篇,如若对你有用,记得推荐,如若有误,欢迎指正!
此篇为本人原创,转载请说明出处
本文已独家授权给脚本之家(jb51net)公众号独家发布
彻底填平Static坑(细节决定成败)的更多相关文章
- atitit.细节决定成败的适合情形与缺点
atitit.细节决定成败的适合情形与缺点 1. 在理论界有两种观点:一种是"细节决定成败",另一种是"战略决定成败".1 1.1. 格局决定成败,方向决定成败 ...
- C++中cin、cin.get()、cin.getline()、getline()、gets()等函数的用法----细节决定成败 (sort用法)
C++中cin.cin.get().cin.getline().getline().gets()等函数的用法 学C++的时候,这几个输入函数弄的有点迷糊:这里做个小结,为了自己复习,也希望对后来者能有 ...
- 记一次AngularJs 路由 $stateChangeStart不起作用(细节决定成败)
var app= angular .module('app', [ 'ngAnimate', 'ngCookies', 'ngResource', 'ngSanitize', 'ngTouch', ' ...
- 初涉node.js做微信测试公众号一路填坑顺便发现个有趣的其他漏洞
[微信测试公众号] 半年前耍着玩搭起来的“微信简历”,是LAMP版的,很皮毛. 微信的官方文档在这 http://mp.weixin.qq.com/wiki/index.php 1.获取access ...
- 发一份shiro标准配置,特此记录
主要还是整合了本地ehcache,集群session管理过段时间放出 <?xml version="1.0" encoding="UTF-8"?> ...
- jdk1.6,jdk1.7共存
当然可以,安装的时候记得选择不同的安装目录,安装好以后,可以在开发工具(如eclipse)中切换不同的编译环境和运行环境.其实只要安装eclipse就自带了jdk1.3-1.6的编译环境了. Mac下 ...
- 蓝桥网试题 java 入门训练 A+B问题
---------------------------------------------------------------------------------------------------- ...
- Android性能优化典例(一)
在Android开发过程中,很多时候往往因为代码的不规范.api使用不恰当.控件的使用场景考虑不全面和用户不恰当的操作等都能引发一系列性能问题的,下面就是我目前整理的一些Android开发过程中需要注 ...
- 面试 5:手写 Java 的 pow() 实现
我们在处理一道编程面试题的时候,通常除了注意代码规范以外,千万要记得自己心中模拟一个单元测试.主要通过三方面来处理. 功能性测试 边界值测试 负面性测试 不管如何,一定要保证自己代码考虑的全面,而不要 ...
随机推荐
- 使用QML绘制界面
1 使用QML设计登录界面 https://www.cnblogs.com/bhlsheji/p/5324871.html 2 使用QML实现下拉列表框 https://blog.csdn.net/ ...
- 201771010134杨其菊《面向对象程序设计java》第十周学习总结
第8章泛型程序设计学习总结 第一部分:理论知识 主要内容: 什么是泛型程序设计 泛型类的声明及实例化的方法 泛型方法的定义 ...
- nginx集成环境下载
https://visual-nmp.en.softonic.com/download
- 数据统计 任务的一点感想 , sql 使用中的坑。
需求: 多张表(个数不定,需求不是非常明确,只有一个大致需求)根据业务需求统计出一些数据 (按天统计,数据有多条校验规则)进行上传. 注意: 校验数据是否正确是需要第三放来反馈的,而且第三方的测试环境 ...
- Spring Beans和依赖注入
您可以自由地使用任何标准的Spring框架技术来定义您的bean及其注入的依赖项.为简单起见,我们经常发现使用@ComponentScan(找到您的bean)和使用@Autowired(做构造函数注入 ...
- 基于grafana+telegraf的服务器监控方案
准备工作:安装InfluxDb 1 Windows 1.1 下载agent https://dl.influxdata.com/telegraf/releases/telegraf-1.10 ...
- 201771010142 张燕& 杨蓉庆 实验十一 集合
实验十一 集合 实验时间 2018-11-8 一 理论知识 一般将数据结构分为两大类:线性数据结构和非线性数据结构.线性数据结构:线性表.栈.队列.串.数组和文件.非线性数据结构:树和图. 线性 ...
- qq通讯录
- 20155312 张竞予 Exp2 后门原理与实践
Exp2 后门原理与实践 目录 基础问题回答 (1)例举你能想到的一个后门进入到你系统中的可能方式? (2)例举你知道的后门如何启动起来(win及linux)的方式? (3)Meterpreter有哪 ...
- Struts2内建拦截器
params拦截器 负责将请求参数设置为Action属性 staticParams拦截器 将配置文件中action元素的子元素param参数设置为Action属性 servletConfig拦截器 将 ...