官术网_书友最值得收藏!

Understanding the Observable.create method

You can create your own Observable with the Observable.create method at any time. This method takes an instance of the ObservableEmitter<T> interface as a source to observe on. So, let's consider this following example:

    fun main(args: Array<String>) { 
 
      val observer: Observer<String> = object : Observer<String> { 
        override fun onComplete() { 
          println("All Completed") 
        } 
 
        override fun onNext(item: String) { 
          println("Next $item") 
        } 
 
        override fun onError(e: Throwable) { 
          println("Error Occured ${e.message}") 
        } 
 
        override fun onSubscribe(d: Disposable) { 
          println("New Subscription ") 
        } 
    }//Create Observer 
 
    val observable:Observable<String> = Observable.create<String> {//1 
      it.onNext("Emit 1") 
      it.onNext("Emit 2") 
      it.onNext("Emit 3") 
      it.onNext("Emit 4") 
      it.onComplete() 
    } 
 
    observable.subscribe(observer) 
 
    val observable2:Observable<String> = Observable.create<String> {//2 
      it.onNext("Emit 1") 
      it.onNext("Emit 2") 
      it.onNext("Emit 3") 
      it.onNext("Emit 4") 
      it.onError(Exception("My Custom Exception")) 
    } 
 
    observable2.subscribe(observer) 
   } 

First, we created an instance of the Observer interface as the previous example. I will not elaborate on observer, as we have already seen an overview in the previous example, and we will see it in detail later in this chapter.

On comment 1, we created Observable with the Observable.create method; we emitted four string from Observable with the help of the onNext method, and then notified it is complete with the onComplete method.

On comment 2, we did almost the same, except here instead of calling onComplete, we called onError with a custom Exception.

Here is the output of the program:

The Observable.create method is useful, especially when you are working with a custom data structure and want to have control over what values are getting emitted. You can also emit values to Observer from a different thread.

Note that the Observable contract (http://reactivex.io/documentation/contract.html) states that Observable must issue notifications to observers serially (not in parallel). They may issue these notifications from different threads, but there must be a formal happens—before relationship between the notifications.

主站蜘蛛池模板: 晋中市| 金平| 三河市| 邓州市| 商洛市| 浠水县| 通渭县| 陵川县| 滁州市| 嵊泗县| 邻水| 台东市| 东海县| 舞钢市| 东海县| 宝应县| 宁国市| 沈丘县| 漳平市| 如东县| 法库县| 新昌县| 肥城市| 长岭县| 兴安县| 荥经县| 根河市| 策勒县| 长沙县| 靖江市| 昆明市| 南京市| 旬阳县| 洛阳市| 留坝县| 孟州市| 宜川县| 昌图县| 濮阳市| 方城县| 德格县|