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)