package think_in_java_access_contorl;

 import think_in_java_access_contorl.access.Cookie;

 /**
* 1.在Java编程思想中有一段很经典的话,明白就会解决很多问题:
* --当编写一个Java源代码文件时,此文件通常被成为编译单元(有时也被称为转义单元)。每个
* 个编译单元都必须有一个后缀名为.java,而在编译单元内则可以有一个public类,该类的名称必须
* 与文件的名称相同(包括大小写,但不包括文件的后缀名.java)。每个编译单元只能有一个public类,否则编译器就不会接受。如果
* 该编译单元之中还有额外的类的话,那么在包之外世界是无法看见这些类的,这是因为他们不是public类,而且他们主要为主public类提供
* 支持。
*
*
* 这就解释了为什么,在同一个包下面,主类必须是public或者是默认的。但是我们可以定义别的类,但是这些类的权限是
* 默认的,为什么?因为他们在同一个包下面,必须使用默认的权限,而默认的权限就是在同一个包可见。
*
* 2.Java如何将可执行的字节码 文件加载进去
* Java可运行程序是一组可以打包并压缩为一个Java文档文件(jar,使用Java的jar文档生成器)的.class文件。Java解析器负责这些
* 文件的查找,装载和解释。
*
* 3.Java中为什么要使用域名的倒叙的形式命名包?
* 在编程思想中,为了让自己的包名独一无二,那么最有效的方法就是ip地址,就是独一无二的,而Java有主要进行的是企业级的开发,所以使用公司域名的倒叙来区分
* 包名。目的就在于此。
* */
public class Demo1 { public static void main(String[] args) {
Cookie c=new Cookie();
//c.bite();由于访问权限,所以无法进行访问
}
}
 package think_in_java_access_contorl;
/**
* 私有构造器获得实例的方法:
* 如果有一个私有的构造器,并且它的权限设置成为一个私用的权限;如果通过方法获得它的实例。
* 因为它是私有的,所以权限只在它的类中。在程序的外部是不能进行new操作的,因为无法找到构造器。但是我们可以使用静态方法的形式,通过类名调用方法
* 进行间接获得,它的实例。
*
* */
public class Demo2_privateDemo_test { public static void main(String[] args) {
Demo2_privateDemo pri= Demo2_privateDemo.make_Demo2_privateDemo();
pri.smile();
}
}
 package think_in_java_access_contorl;

 public class Demo2_privateDemo {

     private Demo2_privateDemo(){
System.out.println("private 构造器,其他类不能访问!");
} public static Demo2_privateDemo make_Demo2_privateDemo(){
return new Demo2_privateDemo();
} public void smile(){
System.out.println("smile....");
}
}
 package think_in_java_access_contorl;

 public class Demo3_protectedDemo_test extends Demo3_protectedDemo {

     public static void main(String[] args) {
Demo3_protectedDemo_test pro=new Demo3_protectedDemo_test();
//这就是在外面的包下面只能是子类进行访问
pro.protected_Demo();
//为什么要这样设计?
//如果我们不设置protected_Demo()的权限,让他默认权限,那么我们在另外一个包中无法访问到这个方法
//我们可以修改权限为public 但是所有人都可以访问到了。我们就向让子类进行访问,其他的包下面无法访问,
//所以Java使用了关键字protected
//访问权限的控制这就是一种封装
}
}
 package think_in_java_access_contorl;
/*
* 注意这个protected其实就是为了继承而生的,他就是子类继承父类,父类给的专门的权限
* 同一包下面的类当然可以访问他。
* */
public class Demo3_protectedDemo {
protected void protected_Demo(){
System.out.println("我是protected访问权限!");
}
}
 package think_in_java_access_contorl;

  class Example{

 }
class Ha{
public static void haha(){
System.out.println("你好啊");
}
}
//注意这里是没有public 并且上面的类只能是默认的权限
class Demo4_Object_access_control_2{
public static void main(String[] args) {
System.out.println("amazing");
new Ha().haha();
} }
 package think_in_java_access_contorl;
/*
* 单例设计模式(其实就是基于方法的访问权限和类的访问权限设计的模式)
* */ class singleDemo1{
private singleDemo1(){ }
//为什么这样设计之后,调用静态方法就可以获得同一个对象:首先,程序调用静态方法,类加载器就会把这个类的class文件加载到方法去并且
//创建一个Class对象,静态代码块,开辟一个有类相关信息的空间,指向的是singleDemo1的实例。
//而调用静态的single_example方法相当与指向了同一个singleDemo1的实例。
private static singleDemo1 single=new singleDemo1();
public static singleDemo1 single_example(){
return single;
} public void method(){
System.out.println("我是单例设计模式哈哈哈!");
}
} public class Demo4_Object_access_control_single_design_pattern { public static void main(String[] args) {
//创建了一个单例子,最好理解访问权限的例子
singleDemo1 single=singleDemo1.single_example();
System.out.println(single);
single.method();
singleDemo1 single2=singleDemo1.single_example();
System.out.println(single2);
single2.method();
// think_in_java_access_contorl.singleDemo1@6bbc4459
// 我是单例设计模式哈哈哈!
// think_in_java_access_contorl.singleDemo1@6bbc4459
//注意这2个对象的地址一样的,说明都是这2个都是同一个都对象的引用,也就是说我们
//不管怎么样调用静态方法,它都是同一个对象
}
}
 package think_in_java_access_contorl;

 public class Demo4_Object_access_control {
//既然方法有访问权限,那么类也可以有访问权限:
//设计者为什么设计一个类的访问权限只有2中,一个是public,一个是默认的权限?
//--如果是public 那么都可以访问(本类,同一个包下,外面的包,继承的类),如果是默认的,那么就是
//--只能在同一个包下面访问,但是类是不可以设置成为私有的,如果设置成为私有的,那么他将失去任何意义。就就是说
//--你创建的这个类,本类外面没有一人能看见。也就无法进行获得具体存在的事物,--对象。(Java使用了另外的一个方式,就是让构造方法私有,通过静态方法创建对象)
//--protected也是不能作用类的访问权限。protected只是针对一个子类中的方法而进行的权限设定。
//Java规定,在一个类中只能有一个public ,不能有多个public,并且规定文件名字和类的名字一样,也是基于这种考虑。
//但是并不是说必须有一个public,可以有另外的方式,那就是默认的类权限。程序也可以执行。
//所以说Java的每一个规定都是有道理的。
}
 package think_in_java_access_contorl;

 class single{
private single(){ } private static single singleDemo=new single();
static single single_method(){
return singleDemo;
} void method(){
System.out.println("haha!!!单例设计模式");
}
}
public class safsadf { public static void main(String[] args) {
single singleDemo=single.single_method();
singleDemo.method();
}
}

Java中权限设置的更多相关文章

  1. 对于Java中权限修饰符的理解

    老是把Java中权限修饰符给忘记,写一个博客加深印象吧 权限分为四个作用域:当前类,同一个包,其他包的子类,其他包的类. 首先要知道包的概念,Java中一个包是指一个package下的所有文件. pr ...

  2. Transform数据权限浅析2之利用Java完成权限设置

    一:项目背景 1.1:cognos的两种建模工具 为了更好的满足客户的需求,提升报表展现的效率,一种建模工具已经不能满足报表开发和展现的需要.Cognos除了给我们提供了一种基于关系型数据库的建模工具 ...

  3. (转) JAVA中如何设置图片(图标)自适应Jlable等组件的大小

    一.问题: 一个程序,组件上设置某个图片作为图标,因为的label(应该说是组件)已经设定了固定大小, 所以再打开一些大图片时,超过组件大小的部分没显示出来,而小图片又没填充完整个组件 二.解决这个问 ...

  4. java中权限修饰符protected的使用注意事项

    java中四种权限修饰符, 平时编码中最常用的其实public和private, 虽然对protected的概念一直都知道, 但真正使用时才发现有些偏差. protected表示被其修饰的成员可以被本 ...

  5. java中如何设置下载文件

    如果想要设置某一url为下载文件的方法如下 需要设置文件响应类型,使用response.setContentType,比如jpeg格式的图片.如果想要访问该页面时出现下载保存的窗口,使用respons ...

  6. java中网络设置代理

    三种方式: 1.JVM启动时加参数设置代理 在系统启动时,使用-D项来设置代理. 例如: java -Dhttp.ProxyHost="proxyUrl" -Dhttp.Proxy ...

  7. Java中权限修饰符public、private、protected和default的区别

    1.public 可以修饰类.成员变量和成员函数,没有任何限制,同一个包中,或者不同包中的类都可以自由访问 2.private 可以修饰成员变量和成员函数,只能在本类中使用 3.default (不写 ...

  8. java 中 SVN 设置所有文件及子目录 needs-lock, svn 提交时自动设置 needs-lock, 及版本不一致问题

    摘自: http://my.oschina.net/zhangzhihao/blog/72177 设置后的效果:文件会自动带上svn:needs-lock属性,默认是只读的要签出才能修改以防止修改完后 ...

  9. JAVA中BufferedReader设置编码的必要性

    实验环境 Myeclipse 默认编码 UTF-8 先看两种读文件的方式: 方式一: InputStreamReader fReader = new InputStreamReader(new Fil ...

随机推荐

  1. 雷林鹏分享:Ruby JSON

    Ruby JSON 本章节我们将为大家介绍如何使用 Ruby 语言来编码和解码 JSON 对象. 环境配置 在使用 Ruby 编码或解码 JSON 数据前,我们需要先安装 Ruby JSON 模块.在 ...

  2. gruntjs开发实例

    Grunt是基于Node.js的项目构建工具.它可以自动运行你所设定的任务,如编译less,sass,压缩js,合拼文件等等. (一)安装nodejs环境,Grunt 0.4.x要求Node.js的版 ...

  3. IIS上部署DotNet Core程序

    1.安装托管捆绑包 https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/iis/index?view=aspnetcore-2.1 ...

  4. idea里面Java文件显示一个x

    idea里面Java文件显示一个x,编译时过滤了,setting->builder->compiler->excludes

  5. C++ 4 种具有更 为准确语义的新强制转换类型

    1. static_cast<T>() 可用于把指向A 的指针强制转换为指向B 的指针,其约束条件是类B必须是类A的子类.例如:A *obj = new B;B *b = static_c ...

  6. HTML学习3---排版标记

    上节,我们学习了boda常用的属性以及HTML的一些标记,但是图显示的效果却不是那么的好看. 原因就是没有排版好,我们这次使用居中来使这个页面更好看一点,顺便多加入几个别的标记. HTML排版标记 ( ...

  7. 汉诺塔的c++实现

    void hanNuoTa(int n,int a,int b,int c) { ) return; hanNuoTa(n - , a, c, b); cout << n << ...

  8. 小谈python装饰器及numba的基本使用

    1. 预热知识 要理解python中的装饰器,就要明白在python中,函数是一种特殊类型的变量,可以作为参数传递给函数,也可以作为返回值返回.比如下面的代码,就是 str_1 作为参数传递给 str ...

  9. ajax向后台请求数据,后台接收到数据并进行了处理,但前台就是调用error方法

    如果你的前台页面书写正确的情况下,并且运行情况和本文题目类似,那不妨试试这个: 在ajax方法中加上:async:false,让ajax同步执行. 因为ajax默认是异步的,至于为什么会不执行succ ...

  10. os、os.path、shutil操作文件和文件路径的常用方法总结

    os模块是python标准库中的一个用于访问操作系统功能的模块,下面简要介绍一下常用的命令 1.os.name().    判断现在正在使用的平台,windows返回’nt’,Linux返回‘posi ...