java枚举在android项目应用

本文介绍枚举在Android应用中的使用技巧,包括通过枚举控制应用行为、实现状态机逻辑以及请求提供商的选择,展示了枚举提高代码可维护性的实际案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天修复一个公司很早以前的android应用功能,里面的代码逻辑已经完全错乱,然后发现返回的数据完全不对了。然后修复了整整两天。然后我重新整理了一遍,重构就算不上了。然后就用上了枚举。

什么是枚举?我以前也不懂,当时我看见公司的项目中使用了枚举当做项目一个控制,比如修改已经写好的app然后为一些手机厂商做定制版。可能要去掉广告,还有跳转到商店url都不同,特别是国内基本都没有google play。我们为了避免以后的修改,就会写个枚举来控制它。

[java] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. public enum Market { 
  2.      
  3.     Default,Huawei(){ 
  4.         @Override 
  5.         public String getMarketUrl() { 
  6.             return "http://play.huawei.com";//huawei market url 
  7.         } 
  8.     },ZTE(){ 
  9.         @Override 
  10.         public boolean isShouldAd(){ 
  11.             return false
  12.         } 
  13.         @Override 
  14.         public String getMarketUrl() { 
  15.             return "http://play.zte.com";//ZTE market url 
  16.         } 
  17.     },OneTouch(){ 
  18.         @Override 
  19.         public String getMarketUrl() { 
  20.             return "http://play.huawei.com"
  21.         } 
  22.     }; 
  23.      
  24.      
  25.     public boolean isShouldAd(){ 
  26.         return true
  27.     } 
  28.      
  29.     public String getMarketUrl(){ 
  30.         return "http:\\googleplay....";//google play url 
  31.     } 
public enum Market {
	
	Default,Huawei(){
		@Override
		public String getMarketUrl() {
			return "http://play.huawei.com";//huawei market url
		}
	},ZTE(){
		@Override
		public boolean isShouldAd(){
			return false;
		}
		@Override
		public String getMarketUrl() {
			return "http://play.zte.com";//ZTE market url
		}
	},OneTouch(){
		@Override
		public String getMarketUrl() {
			return "http://play.huawei.com";
		}
	};
	
	
	public boolean isShouldAd(){
		return true;
	}
	
	public String getMarketUrl(){
		return "http:\\googleplay....";//google play url
	}
}

通过上面的例子就大概了解了一些java枚举在android的基本使用。为了了解java枚举的原理,我写了一个很常用的红绿灯例子。下面是用枚举的代码:

[java] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. public enum TrafficLight { 
  2.  
  3.     red(45) { 
  4.         @Override 
  5.         public TrafficLight nextLamp() { 
  6.             return green; 
  7.         } 
  8.     }, 
  9.     green(30) { 
  10.         @Override 
  11.         public TrafficLight nextLamp() { 
  12.             return yellow; 
  13.         } 
  14.     }, 
  15.     yellow(3) { 
  16.         @Override 
  17.         public TrafficLight nextLamp() { 
  18.             return red; 
  19.         } 
  20.     }; 
  21.  
  22.     private int time; 
  23.  
  24.     private TrafficLight(int time) { 
  25.         this.time = time; 
  26.     }; 
  27.  
  28.     public abstract TrafficLight nextLamp(); 
  29.  
  30.     public int getTime() { 
  31.         return this.time; 
  32.     } 
public enum TrafficLight {

	red(45) {
		@Override
		public TrafficLight nextLamp() {
			return green;
		}
	},
	green(30) {
		@Override
		public TrafficLight nextLamp() {
			return yellow;
		}
	},
	yellow(3) {
		@Override
		public TrafficLight nextLamp() {
			return red;
		}
	};

	private int time;

	private TrafficLight(int time) {
		this.time = time;
	};

	public abstract TrafficLight nextLamp();

	public int getTime() {
		return this.time;
	}
}
然后是普通class模拟enum的代码:

[java] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. public abstract class TrafficLight { 
  2.      
  3.  
  4.     public static final TrafficLight red  = new TrafficLight(45){ 
  5.         @Override 
  6.         public TrafficLight nextLamp() { 
  7.             return green; 
  8.         } 
  9.     }; 
  10.     public static final TrafficLight green  = new TrafficLight(30) { 
  11.         @Override 
  12.         public TrafficLight nextLamp() { 
  13.             return yellow; 
  14.         } 
  15.     }; 
  16.      
  17.     public static final TrafficLight yellow  = new TrafficLight(3) { 
  18.         @Override 
  19.         public TrafficLight nextLamp() { 
  20.             return red; 
  21.         } 
  22.     }; 
  23.  
  24.     private int time; 
  25.  
  26.     private TrafficLight(int time) { 
  27.         this.time = time; 
  28.     }; 
  29.  
  30.     public abstract TrafficLight nextLamp(); 
  31.  
  32.     public int getTime() { 
  33.         return this.time; 
  34.     } 
public abstract class TrafficLight {
	

	public static final TrafficLight red  = new TrafficLight(45){
		@Override
		public TrafficLight nextLamp() {
			return green;
		}
	};
	public static final TrafficLight green  = new TrafficLight(30) {
		@Override
		public TrafficLight nextLamp() {
			return yellow;
		}
	};
	
	public static final TrafficLight yellow  = new TrafficLight(3) {
		@Override
		public TrafficLight nextLamp() {
			return red;
		}
	};

	private int time;

	private TrafficLight(int time) {
		this.time = time;
	};

	public abstract TrafficLight nextLamp();

	public int getTime() {
		return this.time;
	}
}
  通过两个比较,就会发现,其实枚举就是普通的java类,只是私有了构造方法,然后提供了几个static final 的实例变量。当然enum还提供一些其他方法。比如:TrafficLight.green.name()还是非常好用的。

这些都是enum的一些基本应用。然后是我今天在项目如何应用用枚举的类型的。因为我们那个app有三个不同的请求数据的url。其实我们只有一个数据源,如果find不到,就会通过其他两个是读取其他网站html,然后解析,通过正则表达式匹配得到数据。每个数据源需要设置httpClient、httpGet、httpResponse等参数,然后使用了枚举。我这里贴出一点基本的。然后发现其实都是差不多的。

[java] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. import org.apache.http.HttpResponse; 
  2. import org.apache.http.client.ClientProtocolException; 
  3. import org.apache.http.client.HttpClient; 
  4. import org.apache.http.client.methods.HttpGet; 
  5. import org.apache.http.impl.client.DefaultHttpClient; 
  6.  
  7. public enum RequestedProvider { 
  8.  
  9.     mySelf() { 
  10.         @Override 
  11.         public String getUrl(String keyWord) { 
  12.             return "http://..." + keyWord + "..."
  13.         }... 
  14.     }, 
  15.     google() { 
  16.         @Override 
  17.         public String getUrl(String keyWord) { 
  18.             return "http://google..." + keyWord + "..."
  19.         }... 
  20.     }, 
  21.     amazon() { 
  22.         @Override 
  23.         public String getUrl(String keyWord) { 
  24.             return "http://amazon..." + keyWord + "..."
  25.         }... 
  26.     }; 
  27.  
  28.     public abstract String getUrl(String keyWord); 
  29.  
  30.     public HttpClient pickHttpClient() { 
  31.         return new DefaultHttpClient(); 
  32.     } 
  33.  
  34.     public HttpGet pickHttpGet(String url) { 
  35.         return new HttpGet(url); 
  36.     } 
  37.  
  38.     public HttpResponse pickHttpResponse(HttpClient client, HttpGet get) { 
  39.         HttpResponse res = null
  40.         try
  41.             res = client.execute(get); 
  42.         } catch (ClientProtocolException e) { 
  43.             // TODO Auto-generated catch block 
  44.             e.printStackTrace(); 
  45.         } catch (IOException e) { 
  46.             // TODO Auto-generated catch block 
  47.             e.printStackTrace(); 
  48.         } 
  49.         return res; 
  50.     }... 
  51.  
电动汽车数据集:2025年3K+记录 真实电动汽车数据:特斯拉、宝马、日产车型,含2025年电池规格和销售数据 关于数据集 电动汽车数据集 这个合成数据集包含许多品牌和年份的电动汽车和插电式车型的记录,捕捉技术规格、性能、定价、制造来源、销售和安全相关属性。每一行代表由vehicle_ID标识的唯一车辆列表。 关键特性 覆盖范围:全球制造商和车型组合,包括纯电动汽车和插电式混合动力汽车。 范围:电池化学成分、容量、续航里程、充电标准和速度、价格、产地、自主水平、排放、安全等级、销售和保修。 时间跨度:模型跨度多年(包括传统和即将推出的)。 数据质量说明: 某些行可能缺少某些字段(空白)。 几个分类字段包含不同的、特定于供应商的值(例如,Charging_Type、Battery_Type)。 各列中的单位混合在一起;注意kWh、km、hr、USD、g/km和额定值。 列 列类型描述示例 Vehicle_ID整数每个车辆记录的唯一标识符。1 制造商分类汽车品牌或OEM。特斯拉 型号类别特定型号名称/变体。型号Y 与记录关联的年份整数模型。2024 电池_类型分类使用的电池化学/技术。磷酸铁锂 Battery_Capacity_kWh浮充电池标称容量,单位为千瓦时。75.0 Range_km整数表示充满电后的行驶里程(公里)。505 充电类型主要充电接口或功能。CCS、NACS、CHAdeMO、DCFC、V2G、V2H、V2L Charge_Time_hr浮动充电的大致时间(小时),上下文因充电方法而异。7.5 价格_USD浮动参考车辆价格(美元).85000.00 颜色类别主要外观颜色或饰面。午夜黑 制造国_制造类别车辆制造/组装的国家。美国 Autonomous_Level浮点自动化能力级别(例如0-5),可能包括子级别的小
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值