Android ffmpeg第二次运行失败

Android ffmpeg第二次运行失败,android,ffmpeg,android-ffmpeg,Android,Ffmpeg,Android Ffmpeg,我有一个问题。它是Android上ffmpeg的Java包装库,运行得非常好。但似乎不能连续运行两个视频编码。实际上,它一生只会对视频编码一次。每次你试图对视频进行编码时,它都会冻结。这是我在它冻结时得到的输出: Build.CPU_ABI : arm64-v8a Loading FFmpeg for armv7 CPU Running publishing updates method ffmpeg version n3.0.1 Copyright (c) 2000-2016 the FFmp

我有一个问题。它是Android上ffmpeg的Java包装库,运行得非常好。但似乎不能连续运行两个视频编码。实际上,它一生只会对视频编码一次。每次你试图对视频进行编码时,它都会冻结。这是我在它冻结时得到的输出:

Build.CPU_ABI : arm64-v8a
Loading FFmpeg for armv7 CPU
Running publishing updates method
ffmpeg version n3.0.1 Copyright (c) 2000-2016 the FFmpeg developers
  built with gcc 4.8 (GCC)
  configuration: --target-os=linux --cross-prefix=/home/vagrant/SourceCode/ffmpeg-android/toolchain-android/bin/arm-linux-androideabi- --arch=arm --cpu=cortex-a8 --enable-runtime-cpudetect --sysroot=/home/vagrant/SourceCode/ffmpeg-android/toolchain-android/sysroot --enable-pic --enable-libx264 --enable-libass --enable-libfreetype --enable-libfribidi --enable-libmp3lame --enable-fontconfig --enable-pthreads --disable-debug --disable-ffserver --enable-version3 --enable-hardcoded-tables --disable-ffplay --disable-ffprobe --enable-gpl --enable-yasm --disable-doc --disable-shared --enable-static --pkg-config=/home/vagrant/SourceCode/ffmpeg-android/ffmpeg-pkg-config --prefix=/home/vagrant/SourceCode/ffmpeg-android/build/armeabi-v7a --extra-cflags='-I/home/vagrant/SourceCode/ffmpeg-android/toolchain-android/include -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 -fno-strict-overflow -fstack-protector-all' --extra-ldflags='-L/home/vagrant/SourceCode/ffmpeg-android/toolchain-android/lib -Wl,-z,relro -Wl,-z,now -pie' --extra-libs='-lpng -lexpat -lm' --extra-cxxflags=
  libavutil      55. 17.103 / 55. 17.103
  libavcodec     57. 24.102 / 57. 24.102
  libavformat    57. 25.100 / 57. 25.100
  libavdevice    57.  0.101 / 57.  0.101
  libavfilter     6. 31.100 /  6. 31.100
  libswscale      4.  0.100 /  4.  0.100
  libswresample   2.  0.101 /  2.  0.101
  libpostproc    54.  0.100 / 54.  0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/storage/emulated/0/WhatsApp/Media/WhatsApp Video/VID-20160731-WA0005.mp4':
  Metadata:
    major_brand     : mp42
    minor_version   : 1
    compatible_brands: mp41mp42isom
    creation_time   : 2016-07-31 17:24:29
  Duration: 00:00:13.63, start: 0.000000, bitrate: 1641 kb/s
    Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709), 544x960, 1573 kb/s, 30 fps, 30 tbr, 600 tbn, 1200 tbc (default)
    Metadata:
      creation_time   : 2016-07-31 17:24:29
      handler_name    : Core Media Video
    Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 62 kb/s (default)
    Metadata:
      creation_time   : 2016-07-31 17:24:29
      handler_name    : Core Media Audio
我不知道发生了什么事。ffmpeg似乎在第一次编码之后留下了一些东西,为将来的编码锁定了它。只有卸载并重新安装应用程序,它才能工作

  • 如果您从后台杀死一个应用程序,这个问题仍然存在
  • 如果您杀死它并重新启动设备,问题仍然存在
  • 如果在设置中使用强制退出,问题仍然存在

只有重新安装才能使我对新视频编码一次。在那之后,一切都不起作用了。

其实很简单。我在两次尝试中都使用了相同的输出文件名。ffmpeg问我是否要覆盖现有的。问题是这个库没有记录这一行。onProgress listener将记录在此之前的最后一行,它看起来好像冻结了

解决方案是添加“-y”,这将导致