checkAwtEventQueueAccess()
方法checkAwtEventQueueAccess()方法在java.lang包中可用。
通过使用带有AWTPermission(“ accessEventQueue”)的checkPermission调用checkAwtEventQueueAccess()方法来访问AWT(抽象窗口工具包)事件队列。
checkAwtEventQueueAccess()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。
在访问AWT事件队列时,checkAwtEventQueueAccess()方法可能会引发异常。
SecurityException-当不允许调用线程访问AWT事件队列时,可能引发此异常。
语法:
public void checkAwtEventQueueAccess();
参数:
它不接受任何参数。
返回值:
此方法的返回类型为void,不返回任何内容。
示例
//Java程序演示示例 //虚无checkAwtEventQueueAccess()//SecurityManager的方法 public class CheckAwtEventQueueAccess { public static void main(String[] args) { //通过使用setProperty()方法是设置策略属性 //与安全经理 System.setProperty("java.security.policy", "file:/C:/java.policy"); //实例化SecurityManager对象 SecurityManager smgr = new SecurityManager(); //通过使用setSecurityManager()方法是设置 //安全经理 System.setSecurityManager(smgr); //通过使用CheckAwtEventQueueAccess()方法是检查 //是否访问awt事件队列 smgr.checkAwtEventQueueAccess(); //当需要排队时显示消息 System.out.println("Not Restricted.."); } }
输出结果
Exception in thread "main" java.security.AccessControlException: access denied ( java.awt.AWTPermission accessEventQueue) at java.security.AccessControlContext.checkPermission(AccessControlConte xt.java:264) at java.security.AccessController.checkPermission(AccessController.java: 427) at java.lang.SecurityManager.checkPermission(SecurityManager.java:532) at java.lang.SecurityManager.checkAwtEventQueueAccess(SecurityManager.ja va:1398) at CheckAwtEventQueueAccess.main(CheckAwtEventQueueAccess.java:18)