4

デバッグに役立つようにプログラムにログインしようとしていますが、ログステートメント自体でエラーが発生しています。このようにログメッセージを書きました

import android.util.Log;
public static final String TAG = "MyActivity";
Log.e(TAG,"I shouldn't be here");

これは私が公開授業で出した声明です。エラーが発生します:

1. Syntax error on token "(", delete this token.
2. Syntax error on token, Variable Declarator Expected instead.

私は Android SDK の開発と Java が初めてなので、助けていただければ幸いです。

ありがとう。

私はここに私の正確なコードを入れています:

package com.android.record;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import android.app.Activity;
import android.media.AudioFormat;
import android.media.AudioRecord;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.widget.Button;
import android.util.Log;
//import com.android.record.R;


public class AudioRecordTest extends Activity {
private static final int RECORDER_SAMPLERATE = 8000;

private static final int RECORDER_CHANNELS = AudioFormat.CHANNEL_IN_MONO;

private static final int RECORDER_AUDIO_ENCODING = AudioFormat.ENCODING_PCM_16BIT;

private AudioRecord recorder = null;
 private Thread recordingThread = null;
 private boolean isRecording = false;
 public static final String TAG = "MyActivity";

 @Override
 Log.e(TAG,"I shouldn't be here");  
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);

  setContentView(R.layout.activity_audio_record_test);

  setButtonHandlers();
  enableButtons(false);

  int bufferSize = AudioRecord.getMinBufferSize(RECORDER_SAMPLERATE,
    RECORDER_CHANNELS, RECORDER_AUDIO_ENCODING);
 }

 private void setButtonHandlers() {
  ((Button) findViewById(R.id.btnStart)).setOnClickListener(btnClick);
  ((Button) findViewById(R.id.btnStop)).setOnClickListener(btnClick);
 }

 private void enableButton(int id, boolean isEnable) {
  ((Button) findViewById(id)).setEnabled(isEnable);
 }

 private void enableButtons(boolean isRecording) {
  enableButton(R.id.btnStart, !isRecording);
  enableButton(R.id.btnStop, isRecording);
 }

 int BufferElements2Rec = 1024; // want to play 2048 (2K) since 2 bytes we use only 1024
 int BytesPerElement = 2; // 2 bytes in 16bit format

 private void startRecording() {

  recorder = new AudioRecord(MediaRecorder.AudioSource.MIC,
    RECORDER_SAMPLERATE, RECORDER_CHANNELS,
    RECORDER_AUDIO_ENCODING, BufferElements2Rec * BytesPerElement);

  recorder.startRecording();

  isRecording = true;

  recordingThread = new Thread(new Runnable() {

   public void run() {

    writeAudioDataToFile();

   }
  }, "AudioRecorder Thread");
  recordingThread.start();
 }

        //Conversion of short to byte
 private byte[] short2byte(short[] sData) {
  int shortArrsize = sData.length;
  byte[] bytes = new byte[shortArrsize * 2];

  for (int i = 0; i < shortArrsize; i++) {
   bytes[i * 2] = (byte) (sData[i] & 0x00FF);
   bytes[(i * 2) + 1] = (byte) (sData[i] >> 8);
   sData[i] = 0;
  }
  return bytes;
 }

 private void writeAudioDataToFile() {
  // Write the output audio in byte
  String filePath = "/sdcard/MyApp/8k16bitMono.pcm";

                short sData[] = new short[BufferElements2Rec];

  FileOutputStream os = null;
  try {
   os = new FileOutputStream(filePath);
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  }

  while (isRecording) {
   // gets the voice output from microphone to byte format
   recorder.read(sData, 0, BufferElements2Rec);
   System.out.println("Short writing to file" + sData.toString());
   try {
    // writes the data to file from buffer stores the voice buffer
    byte bData[] = short2byte(sData);
    Log.v(TAG,"Am I here??");                // Here is my log!!
    os.write(bData, 0, BufferElements2Rec * BytesPerElement);

   } catch (IOException e) {
    e.printStackTrace();
   }
  }

  try {
   os.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
 }

 private void stopRecording() {
  // stops the recording activity
  if (null != recorder) {
   isRecording = false; 
   recorder.stop();
   recorder.release();

   recorder = null;
   recordingThread = null;
  }
 }

 private View.OnClickListener btnClick = new View.OnClickListener() {
  public void onClick(View v) {

   switch (v.getId()) {
   case R.id.btnStart: {
    enableButtons(true);
    startRecording();
    break;
   }
   case R.id.btnStop: {
    enableButtons(false);
    stopRecording();
    break;
   }
   }
  }
 };

        // onClick of backbutton finishes the activity.
 @Override
 public boolean onKeyDown(int keyCode, KeyEvent event) {
  if (keyCode == KeyEvent.KEYCODE_BACK) {
   finish();
  }
  return super.onKeyDown(keyCode, event);
 }
}
4

9 に答える 9

9
@Override
Log.e(TAG,"I shouldn't be here");  
public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);

などのメソッド呼び出しLog.e()は、メソッド本体にある必要があります。クラス本体に直接配置することはできません。したがって、次のように変更します。

@Override
public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  Log.e(TAG,"I shouldn't be here");  
于 2013-10-02T12:49:56.680 に答える
5

まず、ログをインポートします(クラスの上(クラス内ではありません))=>

import android.util.Log;

あなたのタグを作成して、ログインデバッグウィンドウ(クラスのフィールド)を見つけます=>

public static final String LOG_TAG = "myLogs";

そして、タグと文字列の2つのパラメーターが必要です(メソッドに入れます)=>

Log.d(LOG_TAG, "I shouldn't be here");

Log.v();// 詳細 Log.d();// デバッグ Log.i();// 情報 Log.w();// 警告 Log.e();// エラー

于 2013-10-02T12:11:09.490 に答える
1

Log クラス Pageが表示された場合、Log.eパラメーターが 1 つあるものはありますか? 機能させるには、別のパラメーターを追加する必要があります。

Log.e("SOMETAG","I shouldn't be here");
于 2013-10-02T12:11:18.820 に答える
0

次のように使用します。Log.e("YOUR LOG TAG", "YOUR LOG MESSAGE");

于 2013-10-02T12:09:43.800 に答える
0

最初に、このログ エラーを参照する文字列を追加する必要があります。

たとえば、TAG という名前の文字列を作成し、それをステートメントに追加します。

private static final String TAG = "Your Tag";
Log.e(TAG, "I shouldn't be here"); 
于 2013-10-02T12:13:17.237 に答える
0

Log.e の元の形式は、次のコードのようなものです。

Log.e(String tag,String msg)

したがってString、パラメーターとして 2 つを渡す必要があります。何かをエラーとして表示したい場合は、次のように記述できます。

Log.e("TAG","I shouldn't be here");

うまくいくことを願っています。この方法でエラーのグローバルタグを追加することもできます

public static final String TAG = "MY_TAG";
Log.e(TAG, "I shouldn't be here");
于 2013-10-02T12:13:22.537 に答える
0

Log.e("TAG", "Msg")または使用できますLog.d("TAG", "Msg");

TAGStringLogCat の TID に表示されるものです。仮定するLog.e("UserID", userId);

インポートすることを忘れないでください: import android.util.Log;

于 2013-10-02T12:14:04.650 に答える