[正确]的使用Kotlin Flow进行搜索优化,flutter二维码扫描插件

本文分析了一篇关于Kotlin Flow在搜索优化中错误的使用示例,指出在文本输入框事件处理中错误地在每次回调时创建新的Flow。通过简化代码展示了正确的Flow逻辑,强调了限流的正确位置。同时提到了Flutter的二维码扫描插件,并分享了一套针对算法学习的资料,旨在帮助开发者提升面试通过率。
摘要由CSDN通过智能技术生成

错在了哪


我先把那篇文章中错误的代码贴上来:

// 错误代码🙅

binding.etSearch.doOnTextChanged { text, _, _, _ ->

searchFilter(text.toString())

}

private fun searchFilter(str:String){

flow { emit(str) }

.debounce(400)

.filter {

it.isNotEmpty()

}

.catch { LogUtils.d(it.message) }

.flowOn(Dispatchers.Default)

.onEach {

LogUtils.d(“输出:$it”)

binding.tvShow.text = it.toString()

}.flowOn(Dispatchers.Main)

.launchIn(lifecycleScope)

}

复制代码

仔细看上面的代码,你们自己想想错在了哪里?

文本输入框etSearch每次文本的变化都会回掉searchFilter()方法,而方法里面每次都去实例化了一个flow,然后又使用了debounce()限流,那么这个debounce()限流的意义何在?毫无意义啊,对吧。因为每次都是新创建的flow啊。

还不懂的话,那就看下面简化的代码:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您可以使用 ZXing 来实现 Kotlin 中的二维码扫描。以下是一个简单的示例代码: 1. 添加依赖 在您的项目的 build.gradle 文件中添加以下依赖: ``` dependencies { implementation 'com.google.zxing:core:3.4.0' implementation 'com.journeyapps:zxing-android-embedded:3.4.0' } ``` 2. 在布局文件中添加 SurfaceView 在您的布局文件中添加一个 SurfaceView 元素,用于显示相机预览: ```xml <SurfaceView android:id="@+id/surface_view" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 在 Kotlin 代码中实现扫描逻辑 在您的 Kotlin 代码中,使用 ZXing 来实现扫描逻辑。以下是一个简单的示例代码: ```kotlin import android.Manifest import android.content.pm.PackageManager import android.os.Bundle import android.util.Log import android.view.SurfaceHolder import android.view.SurfaceView import androidx.appcompat.app.AppCompatActivity import androidx.core.app.ActivityCompat import androidx.core.content.ContextCompat import com.google.zxing.BarcodeFormat import com.google.zxing.Result import com.google.zxing.client.android.BeepManager import com.google.zxing.client.android.camera.CameraManager import com.journeyapps.barcodescanner.BarcodeCallback import com.journeyapps.barcodescanner.BarcodeResult import com.journeyapps.barcodescanner.DecoratedBarcodeView import com.journeyapps.barcodescanner.DefaultDecoderFactory class MainActivity : AppCompatActivity(), SurfaceHolder.Callback { private lateinit var cameraManager: CameraManager private lateinit var beepManager: BeepManager private lateinit var surfaceView: SurfaceView private lateinit var barcodeView: DecoratedBarcodeView private lateinit var barcodeCallback: BarcodeCallback override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) surfaceView = findViewById(R.id.surface_view) barcodeView = findViewById(R.id.barcode_view) // Request camera permission if not granted if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, arrayOf(Manifest.permission.CAMERA), REQUEST_CAMERA_PERMISSION) } else { surfaceView.holder.addCallback(this) } cameraManager = CameraManager(this) beepManager = BeepManager(this) // Set decoder factory val formats = mutableListOf<BarcodeFormat>() formats.add(BarcodeFormat.QR_CODE) val decoderFactory = DefaultDecoderFactory(formats) barcodeView.decoderFactory = decoderFactory barcodeView.initializeFromIntent(intent) barcodeView.decodeContinuous(barcodeCallback) } override fun surfaceCreated(holder: SurfaceHolder) { try { cameraManager.openDriver(holder) } catch (e: Exception) { Log.e(TAG, "Failed to open camera", e) } } override fun surfaceChanged(holder: SurfaceHolder, format: Int, width: Int, height: Int) {} override fun surfaceDestroyed(holder: SurfaceHolder) { cameraManager.closeDriver() } override fun onResume() { super.onResume() barcodeView.resume() } override fun onPause() { super.onPause() barcodeView.pause() } override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<out String>, grantResults: IntArray) { if (requestCode == REQUEST_CAMERA_PERMISSION) { if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) { surfaceView.holder.addCallback(this) } } } companion object { private const val TAG = "MainActivity" private const val REQUEST_CAMERA_PERMISSION = 1 } } ``` 在上面的代码中,我们创建了一个 `BarcodeCallback` 对象,用于处理扫描结果。在 `onCreate` 方法中,我们设置了解码器工厂,并将 `BarcodeCallback` 对象传递给 `barcodeView.decodeContinuous` 方法,以启动连续扫描模式。 注意:这个示例代码仅供参考,具体的实现可能因应用需求而异。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值