Application设置全局变量以及传值

/**
* 重写Application,主要重写里面的onCreate方法,就是创建的时候,
* 我们让它初始化一些值,前段时间在javaeye里面看到过一个例子,与此相似,
* 我做了些改进。听说外国开发者习惯用此初始化一些全局变量,好像在Activity
* 一些类里面初始化全局变量的化,会遇到一些空指针的异常,当然,我没有遇到过。
* 如果用此方法初始化的话,那么就可以避免那些有可能出现的错误。

* 启动Application,他就会创建一个PID,就是进程ID,所有的Activity就会在此进程上运行。
* 那么我们在Application创建的时候初始化全局变量,那么是不是所有的Activity都可以拿到这些
* 全局变量,再进一步说,我们在某一个Activity中改变了这些全局变量的值,那么在别的Activity中
* 是不是值就改变了呢,这个算不算传值呢?
* OK,那么下面的例子我们测试下。。。
* @author yong.wang
*
*/
public class MyApplication extends Application {


        private String name;
        
        @Override
        public void onCreate() {
                super.onCreate();
                setName(NAME); //初始化全局变量
        }


        public String getName() {
                return name;
        }


        public void setName(String name) {
                this.name = name;
        }
        
        private static final String NAME = "MyApplication";
}
复制代码
//Ok,应用程序创建好了,不过我们应该在配置文件ApplicationManifest.xml中将要运行的应用程序MyApplication加进去,修改下:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.hisoft.app"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name"
                 android:name=".MyApplication">  就是这儿,将我们以前一直用的默认Application给他设置成我们自己做的MyApplication
        <activity android:name=".MyFirstActivity"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".MySecondActivity"></activity>
    </application>
    <uses-sdk android:minSdkVersion="8" />


</manifest>
复制代码
当xml配置文件运行完android:name=".MyApplication">,在此那么就分配好了进程ID,再下面,我们就要运行我们的Activity了
public class MyFirstActivity extends Activity {
    
        private MyApplication app;
        
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        app = (MyApplication) getApplication(); //获得我们的应用程序MyApplication
        Log.e("MyFirstActivityOriginal", app.getName());   //将我们放到进程中的全局变量拿出来,看是不是我们曾经设置的值
        app.setName("is cool");  //OK,现在我们开始修改了
        Log.e("MyFirstActivityChanged", app.getName()); //再看下,这个值改变了没有
        Intent intent = new Intent();  //更重要的是我们可以看在别的Activity中是拿到初始化的值,还是修改后的
        intent.setClass(this, MySecondActivity.class);
        startActivity(intent);
    }
}
复制代码
跳到这个Activity了
public class MySecondActivity extends Activity {


        private MyApplication app;
        
        @Override
        protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);
                app = (MyApplication) getApplication();  //获取应用程序
                Log.e("MySecondActivity", app.getName()); //获取全局值
        }        
}
复制代码
OK,看下值:当然我已经运行过了,
MyFirstActivityOriginal       MyApplication 
MyFirstActivityChanged     is cool
MySecondActivity             is cool
看看,是不是特别令人兴奋,当然有可能你退出之后再运行的时候,就第2、3。。。次,有可能会3个输出全是 is cool,那是你没杀掉进程的问题
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过在Spring中创建一个ThreadLocal来实现将userID设置全局变量。 以下是一个示例: 1. 创建一个用于存储当前用户的全局变量: ``` public class CurrentUser { private static final ThreadLocal<Long> threadLocal = new ThreadLocal<>(); public static void set(Long userId) { threadLocal.set(userId); } public static Long get() { return threadLocal.get(); } public static void remove() { threadLocal.remove(); } } ``` 2. 创建一个用于获取当前用户ID并将其存储在全局变量中的解析器: ``` public class CurrentUserHandlerMethodArgumentResolver implements HandlerMethodArgumentResolver { @Override public boolean supportsParameter(MethodParameter parameter) { return parameter.getParameterType().equals(Long.class) && parameter.hasParameterAnnotation(CurrentUserId.class); } @Override public Object resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer, NativeWebRequest webRequest, WebDataBinderFactory binderFactory) throws Exception { return CurrentUser.get(); } @EventListener public void handleAuthenticationSuccessEvent(AuthenticationSuccessEvent event) { CurrentUser.set(event.getUser().getId()); } @EventListener public void handleLogoutSuccessEvent(LogoutSuccessEvent event) { CurrentUser.remove(); } } ``` 3. 在Spring配置类中注册CurrentUserHandlerMethodArgumentResolver: ``` @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { // ... @Bean public CurrentUserHandlerMethodArgumentResolver currentUserHandlerMethodArgumentResolver() { return new CurrentUserHandlerMethodArgumentResolver(); } @Override public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) { argumentResolvers.add(currentUserHandlerMethodArgumentResolver()); } } ``` 4. 在application.properties中引用${user.id}: ``` my.queue=user.queue.${currentUser} ``` 这里使用了一个名为“currentUser”的变量,它的值是通过CurrentUserHandlerMethodArgumentResolver获取的当前用户ID。要使用该变量,也需要在MyMessageListener中添加一个参数: ``` @Component public class MyMessageListener { @RabbitListener(queues = "${my.queue}") public void handleMessage(String message, @Value("${currentUser}") Long userId) { System.out.println("Received message: " + message + " for user " + userId); } } ``` 这样,你就可以通过${user.id}设置当前用户的队列名称,并在MyMessageListener中获取当前用户的ID。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值