当前位置: 首页 > news >正文

咨询学校网站开发费用做外贸网站信息

咨询学校网站开发费用,做外贸网站信息,秦皇岛网站seo,怎么把自己的网站做自适应网站一、扩展函数与扩展属性:为系统类 “量身定制” 工具方法 Kotlin 的扩展机制允许为现有类(包括 Java 类)添加新功能,无需继承或修改原类。这在 Android 开发中尤其适合封装高频重复操作(如 View 操作、上下文获取&…

一、扩展函数与扩展属性:为系统类 “量身定制” 工具方法

Kotlin 的扩展机制允许为现有类(包括 Java 类)添加新功能,无需继承或修改原类。这在 Android 开发中尤其适合封装高频重复操作(如 View 操作、上下文获取)。

1.1 为 View 添加扩展函数:简化 UI 操作

Android 中操作 View 时,常需要处理可见性、点击事件等重复逻辑。通过扩展函数可以将这些逻辑封装,提升代码简洁性。

// 扩展函数:快速切换View可见性
fun View.setVisible(visible: Boolean) {visibility = if (visible) View.VISIBLE else View.GONE
}// 扩展函数:安全的点击事件(防重复点击)
fun View.setOnSingleClickListener(interval: Long = 500L, // 防重复点击间隔action: (View) -> Unit
) {var lastClickTime = 0LsetOnClickListener { view ->val currentTime = System.currentTimeMillis()if (currentTime - lastClickTime > interval) {lastClickTime = currentTimeaction(view)}}
}// 使用示例
val button = findViewById<Button>(R.id.btn_submit)
button.setVisible(true) // 替代 visibility = View.VISIBLE
button.setOnSingleClickListener { // 点击逻辑(500ms内仅触发一次)
}
1.2 为 Context 添加扩展属性:快速获取系统服务

Android 中获取系统服务(如LayoutInflaterSharedPreferences)需要调用getSystemService(),通过扩展属性可以简化这一过程。

// 扩展属性:获取LayoutInflater
val Context.layoutInflater: LayoutInflaterget() = getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater// 扩展属性:获取默认SharedPreferences
val Context.defaultSp: SharedPreferencesget() = getSharedPreferences("app_prefs", Context.MODE_PRIVATE)// 使用示例(在Activity/Fragment中)
val inflater = layoutInflater // 直接使用扩展属性
val sp = defaultSp.edit().putString("user", "douban").apply()

二、作用域函数:优雅处理对象作用域

Kotlin 提供letrunwithapplyalso等作用域函数,用于在特定作用域内操作对象。选择正确的函数可提升代码可读性。

1.1 作用域函数对比与最佳实践
函数适用场景返回值内部用this还是it
let对对象执行转换或操作,处理null安全最后一行表达式it(单个参数)
run对象配置 + 计算返回值(需同时处理配置和结果)最后一行表达式this(对象自身)
with对单个对象执行多个操作(类似run,但通过参数传递对象)最后一行表达式this(对象自身)
apply对象配置(无需返回值,仅需修改对象属性)对象自身this(对象自身)
also对对象执行副作用操作(如日志、统计,不影响对象本身)对象自身it(单个参数)

Android 开发中的典型用例

// apply:配置View属性(返回View自身,适合链式调用)
val textView = TextView(context).apply {text = "Hello Douban"textSize = 16fsetTextColor(ContextCompat.getColor(context, R.color.primary))layoutParams = LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT)
}// let:处理可能为null的值(安全调用链)
intent?.extras?.let { extras -> val userId = extras.getString("user_id")userId?.let { loadUser(it) } // 嵌套let处理多级null
}// also:记录对象状态(不修改对象)
user.also { Log.d("User", "Loaded user: ${it.name}") 
}.run { updateUI(this) // 继续对user执行操作
}

三、object 的核心用法

3.1 单例类(Singleton)

使用 object 关键字可以直接定义一个单例类,无需手动实现单例模式的样板代码。

// 定义单例类
object AppSettings {// 成员变量var theme: String = "light"var isDarkMode: Boolean = false// 成员函数fun saveSettings() {// 保存配置到本地}fun loadSettings() {// 从本地加载配置}
}// 使用单例(直接通过类名访问)
AppSettings.theme = "dark"
AppSettings.saveSettings()

特点

  • 全局唯一实例,由 Kotlin 编译器自动生成线程安全的单例实现。
  • 可继承类或实现接口,但不能有构造函数(因为无法实例化)。
3.2 对象表达式(匿名内部类)

object 可用于创建匿名类的实例,常用于实现接口或继承类的一次性对象。

// 示例1:实现接口
val listener = object : View.OnClickListener {override fun onClick(v: View) {// 处理点击事件}
}// 示例2:继承类并扩展
val customRunnable = object : Runnable {var counter = 0override fun run() {counter++println("Running $counter times")}
}

应用场景

  • 替代 Java 中的匿名内部类(如点击监听器、回调接口)。
  • 临时需要的对象(如单元测试中的 mock 对象)。

四、密封类与数据类:构建安全的状态模型

密封类(Sealed Class)定义受限的类层次结构,适合表示有限的状态类型(如加载状态、网络请求结果);数据类(Data Class)自动生成equals()hashCode()等方法,适合表示数据模型

4.1 密封类:实现状态机(State Machine)

在 MVVM 架构中,常用密封类表示 UI 状态(加载中、成功、失败),确保状态覆盖全面,避免遗漏。

// 密封类:定义网络请求状态
sealed class UserState {object Loading : UserState() // 加载中data class Success(val user: User) : UserState() // 成功(携带数据)data class Error(val exception: Throwable) : UserState() // 失败(携带异常)
}// ViewModel中更新状态
class UserViewModel : ViewModel() {private val _state = MutableLiveData<UserState>()val state: LiveData<UserState> = _statefun loadUser() {_state.value = UserState.Loading // 触发加载状态viewModelScope.launch {try {val user = fetchUser() // 异步获取数据_state.value = UserState.Success(user) // 更新为成功状态} catch (e: Exception) {_state.value = UserState.Error(e) // 更新为失败状态}}}
}// Activity中根据状态更新UI(配合when表达式,确保覆盖所有情况)
lifecycleScope.launch {viewModel.state.collect { state ->when (state) {is UserState.Loading -> showLoading()is UserState.Success -> showUser(state.user)is UserState.Error -> showError(state.exception)}}
}
4.2 数据类:简化数据模型与 Parcelable 集成

数据类默认生成copy()componentN()等方法,适合表示结构化数据。结合@Parcelize注解可快速实现Parcelable接口(用于Intent传参)。

// 数据类(自动生成equals、hashCode、toString)
@Parcelize // 需要添加kotlin-parcelize插件
data class User(val id: String,val name: String,val age: Int,val isVip: Boolean = false
) : Parcelable// 使用示例:通过Intent传递User对象
val user = User(id = "1", name = "Douban", age = 10)
val intent = Intent(context, DetailActivity::class.java).apply {putExtra("user", user) // 直接传递Parcelable对象
}
startActivity(intent)// 在DetailActivity中获取数据
val user = intent.getParcelableExtra<User>("user")

五、内联函数与具体化类型参数:突破泛型擦除限制

内联函数(inline)将函数体直接插入调用处,减少函数调用开销;具体化类型参数(reified)允许在运行时访问泛型类型,解决 Java 泛型擦除问题。

5.1 具体化类型参数:简化泛型类型检查

在 Android 中,常需要根据泛型类型动态创建对象或解析数据(如 JSON 反序列化),具体化类型参数可直接获取类型信息。

// 内联函数:通过反射获取泛型类型
inline fun <reified T> Gson.fromJson(json: String): T {return fromJson(json, T::class.java) // T::class.java 可获取具体类型
}// 使用示例(无需手动传递Type)
val user: User = gson.fromJson(jsonString) // 内联函数:启动Activity(泛型指定目标类)
inline fun <reified T : Activity> Context.startActivity() {startActivity(Intent(this, T::class.java))
}// 使用示例
startActivity<MainActivity>() // 替代 startActivity(Intent(this, MainActivity::class.java))

六、协程 (Coroutines):Android 异步编程的 “标准答案”

Android 异步编程中协程的完整实战示例-CSDN博客

七、lazy与lateinit语法对比

7.1 lazy 示例
// 单线程懒加载(Android 主线程)
val expensiveObject: ExpensiveObject by lazy(LazyThreadSafetyMode.NONE) {ExpensiveObject() // 首次访问时执行初始化
}// 多线程安全懒加载(默认模式)
val config: AppConfig by lazy {loadConfigFromDisk() // 自动加锁保证线程安全
}
7.2 lateinit 示例
// 在 Activity 中延迟初始化 ViewModel
lateinit var viewModel: MyViewModeloverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)viewModel = ViewModelProvider(this).get(MyViewModel::class.java)// 必须在使用 viewModel 前初始化
}
7.3 关键差异详解
  • lazy:只能用于 val(只读属性),因为其内部实现通过委托管理初始化值,初始化后不可修改。
  • lateinit:只能用于 var(可变属性),因为需要在后续代码中手动赋值。

http://www.dtcms.com/a/459200.html

相关文章:

  • wordpress发布文章提示失败厦门网站优化公司
  • 网站 系统设置如何做优化网站排名
  • 网站备案填了虚假座机能过吗上海制作公司
  • 毕业设计心理评测网站开发高密专业网站建设价格
  • 珠宝销售网站源码wordpress网站如何添加栏目
  • 深圳龙华网站开发手游代理平台哪个好
  • 江苏专业做网站的公司有哪些百度seo排名优化联系方式
  • 如何做网站搜索栏网站建设流程方案
  • 学校网站系统破解版中国企业网
  • 微信公众号自己微网站吗有哪些可以做兼职的翻译网站
  • 精品课程网站建设步骤培训网站开发需求说明书
  • 小型网站制作深圳wordpress前端新增头像上传
  • 优秀国外网站设计赏析网站怎样做全国地区推广
  • 淘宝网站那个做的营销型网站建立
  • 徐州祥云做网站网络营销公司如何建立
  • 公司网站首页模板网站改版专题页
  • 桂林市生活网官方网站普陀网页设计
  • 网站无障碍建设百度seo权重
  • 免费电商网站建设平台php做网站首页的代码
  • 免费域名做网站遵义在线新闻中心
  • 微网站开发平台免费wordpress 使用ip访问
  • 一_建设网站前的市场分析做外贸学习网站
  • 上饶网站建设公司国家职业证书查询网入口
  • 潜江建设网站用人名做网站域名
  • 第五步:解决跨域问题,返回 token,校验token, 并定义将接收的参数全局存储的方法
  • 福建城建设厅官方网站秦皇岛信息平台
  • 云主机做网站网页制作软件ai
  • 网站建设科目做网站维护价格
  • 猎头公司应坚持的原则有seo推广公司网站模板
  • 营销型网站用什么模版合适陈幼坚设计公司官网