完成后不可见异步方法的副作用

问题描述

以下类具有一个AudioContext,该音频上下文已在start方法中初始化,但在调用stop方法时始终未定义。

export class PitchDetector {
  private audioCtx?: AudioContext;

  public async start(onPitchDetected: (frequency: Frequency) => void): Promise<void> {
    this.audioCtx = new AudioContext();
    const stream = await navigator.mediaDevices.getUserMedia({
      audio: { sampleRate: sampleRate },});
    const streamSource = this.audioCtx.createmediastreamsource(stream);
    const scriptprocessor = this.audioCtx.createscriptprocessor(bufferSize);
    scriptprocessor.onaudioprocess = onAudioProcess.bind(undefined,onPitchDetected);
    streamSource.connect(scriptprocessor);
    scriptprocessor.connect(this.audioCtx.destination);
  }

  public async stop() {
    await this.audioCtx!.close();
  }
}

在这样的React组件中调用它。

export const Something: React.FC<Props> = (props) => {
// ...

  let pitchDetector = new PitchDetector();

// ...

  async function keyboardOnClick(octave: number,key: Key) {
    await pitchDetector.start(setFrequency);
// ...
  }

  async function onFrequencyInput(freq: Frequency) {
    await pitchDetector.stop();  // <- Here it fails.
// ...
  }

  return <SomeComponents/>
}

我无法共享完整的代码,但是要点是keyboardOnClick一个onclick处理程序,如果检测到某些频率,则会调用onFrequencyInput。它始终以TypeErrorCannot read property 'close' of undefined失败。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...