Java学习笔记2

接下来我们来看看面向对象语言中的方法,在定义方法时,发现它与结构化程序设计语言中函数尤为相似,值得注意


的是,Java里的方法是不能独立存在的,所有的方法都定义在类里。


那我们口中所讲的方法与函数到底有什么区别呢?


在结构化编程语言中,整个软件是由一个个的函数组成;而在面向对象编程语言里,整个软件是由一个个的类来组


成。因此定义方法时,只能定义在类中,如果使用static来修饰,那这个方法就是属于这个类,否则这个方法就属于这


个类的实例。


平时我们在同一个类的一个方法调用另外一个方法时,如果被调方法是普通方法,默认使用this作为调用者,如果被


掉方法时静态方法,则默认使用类作为调用者。


如果在同一个类中定义了多个同名的方法,并且形参列表不同,那么我们可以称这个方法为重载。


方法重载的遵循两同一不同:同一个类中方法名相同,参数列表不同。


在Java语言中,根据定义变量位置的不同,可以将变量分成两大类:成员变量和局部变量。


成员变量被分为类Field和实例Field两种,定义Field时没有用static修饰的就是实例Field,用static修饰的就是类


Field,其中类Field是类本身的一个成员,而实例Field是实例的一个成员。


局部变量根据定义形式的不同,分为以下三种:


1、形参:在定义方法签名时定义的变量,形参的作用域在整个方法内有效。


2、方法局部变量:在方法体内定义的局部变量,作用域是从定义该变量的地方生效,到该方法结束时失效。


3、代码块局部变量:在代码块中定义的局部变量,这个局部变量的作用域从定义该变量的地方生效,到该代码块结


束时失效。


局部变量除了形参之外,方法局部变量和代码局部变量,都必须显式初始化。


封装是面向对象的三大特征之一。指的是将对象的状态信息隐藏在对象内部,不允许外部程序直接访问对象的内部信


息,而是通过该类所提供的方法来实现对内部信息的操作和访问。通过封装我们可以实现以下几个目的:


1、隐藏类的实现细节。


2、让使用者只能通过事先预定的方法来访问数据,从而在该方法中添加逻辑控制,限制对Field的不合理访问。


3、可以进行数据检查,保证对象信息的完整性。


4、便于修改,提高代码的可维护性。


因此实现良好的封装需要从以下两个方面考虑:


1、将对象的Field和实现细节隐藏起来,不允许外部直接访问。


2、把方法暴露出来,让方法来控制对这些Field进行安全的访问和操作。


以上两个方面都需要通过使用Java提供的访问控制符来实现。


从前面一节中我们知道Java提供了三个访问控制符:private、protected和public,分别代表3个访问控制级别,另外


还有一个不加任何访问控制符的访问控制级别。关于这几个访问控制符的控制级别如下图由上到下,分别代表访问控


制级别由小到大:

                                                                                                

以上四个访问控制级别的详细介绍如下:


private:如果类里的一个成员使用private访问控制符来修饰,则这个成员只能在当前类的内部访问。


default:如果类里的一个成员或者一个外部类不使用任何访问控制符修饰,就称它是包访问权限,default访问控制的成


员或外部类可以被相同包下的其他类访问。


protected:如果类里的一个成员使用protected访问控制符修饰,那么这个成员既可以被同一个包中的其他类访问,也


可以被不同包中的子类访问,如果使用protected来修饰一个方法,通常希望其子类来重写这个方法。


public:这个一个最宽松的访问控制级别,如果一个成员或者一个外部类使用public访问控制符修饰,那么这个成员或


外部类就可以被所有类访问,不管访问类和被访问类是否处于用一个包中,是否具有父子继承关系。                                         




转载请注明出处:http://blog.csdn.net/hai_qing_xu_kong/article/details/43852883    情绪控_ 








展开阅读全文

Git 实用技巧

11-24
这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。
©️2020 CSDN 皮肤主题: 猿与汪的秘密 设计师: 上身试试 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值