【问题标题】:Android studio getSlotFromBufferLocked: unknown buffer errorAndroid Studio getSlotFromBufferLocked:未知缓冲区错误
【发布时间】:2015-12-10 06:12:31
【问题描述】:

我想做一个简单的登录和注册应用程序,这样用户就可以创建一个帐户。 (姓名、用户名、密码) 我使用 WAMP 和一个 MYSQL 数据库来存储帐户。

当我在注册表中填写用户信息并单击注册时,我收到以下错误:

09-14 09:30:39.864    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7115e0
09-14 09:30:48.632    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7125a0
09-14 09:30:51.940    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7125a0

当我去检查数据库时,它没有存储帐户。

MainActivity.java

import android.app.Activity;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    public void userReg(View v)
    {
        startActivity(new Intent(this, Register.class));
    }
    public void userLogin(View view)
    {


    }


}

Register.java

import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;

public class Register extends Activity {
    EditText ET_NAME,ET_USER_NAME,ET_USER_PASS;
    String name,user_name,user_pass;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.register_layout);
        ET_NAME = (EditText) findViewById(R.id.name);
        ET_USER_NAME = (EditText) findViewById(R.id.new_user_name);
        ET_USER_PASS = (EditText) findViewById(R.id.new_user_pass);
    }

    public void userReg(View view)
    {
        name = ET_NAME.getText().toString();
        user_name = ET_USER_NAME.getText().toString();
        user_pass = ET_USER_PASS.getText().toString();
        String method = "register";
        BackgroundTask backgroundTask = new BackgroundTask(Register.this);
        backgroundTask.execute(method,name,user_name,user_pass);
        finish();
    }
}

Backgroundtask.java

import android.app.AlertDialog;
import android.content.Context;
import android.os.AsyncTask;
import android.widget.Toast;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;

public class BackgroundTask extends AsyncTask<String, Void, String> {
    AlertDialog alertDialog;
    Context ctx;

    BackgroundTask(Context ctx) {
        this.ctx = ctx;

    }

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
    }

    @Override
    protected String doInBackground(String... params) {
        String reg_url = "http://10.0.2.2.2/webapp/register.php";
        String login_url = "http://10.0.2.2.2/webapp/login.php";
        String method = params[0];
        if (method.equals("register")) {
            String name = params[1];
            String user_name = params[2];
            String user_pass = params[3];
            try {
                URL url = new URL(reg_url);
                HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
                httpURLConnection.setRequestMethod("POST");
                httpURLConnection.setDoOutput(true);
                OutputStream OS = httpURLConnection.getOutputStream();
                BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(OS, "UTF-8"));
                String data = URLEncoder.encode("user", "UTF-8") + "=" + URLEncoder.encode(name, "UTF-8") + "&" +
                        URLEncoder.encode("user_name", "UTF-8") + "=" + URLEncoder.encode(user_name, "UTF-8") + "&" +
                        URLEncoder.encode("user_pass", "UTF-8") + "=" + URLEncoder.encode(user_pass, "UTF-8");
                bufferedWriter.write(data);
                bufferedWriter.flush();
                bufferedWriter.close();
                OS.close();
                InputStream IS = httpURLConnection.getInputStream();
                IS.close();
                return "Registration Success...";
            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

        return null;
    }

    @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
    }

    @Override
    protected void onPostExecute(String result) {
        Toast.makeText(ctx, result, Toast.LENGTH_LONG).show();
    }
}

注册.php

<?php
require "init.php";
$name = $_POST["user"];
$user_name = $_POST["user_name"];
$user_pass = $_POST["user_pass"];

$sql_query = "insert into user_info values('$name','$user_name','$user_pass');";

if(mysqli_query($con,$sql_query))
{
//echo"<h3> Data insertion success...</h3>";
}
else{
//echo "Data insertion error..".mysqli_error($con);
}



?>

init.php

<?php
$db_name="myDBname";
$mysql_user = "root";
$mysql_pass = "root";
$server_name="localhost";

$con = mysqli_connect($server_name,$mysql_user,$mysql_pass,$db_name);
if(!$con)
{
//echo"Connection Error".mysqli_connect_error();
}
else
{
//echo"<h3> Database connection success.....</h3>";
}


?>

【问题讨论】:

  • 谢谢,我检查了我的 php 文件,我认为问题不存在。
  • 好的,非常感谢,不胜感激。我只是添加了 PHP 脚本,以防万一。
  • 我正在运行“Android Programming 2ed”,但我反复遇到 E/Surface: getSlotFromBufferLocked: unknown buffer: 0xabe2d840 之类的错误。是什么原因造成的?
  • m 具有相同的概率,但我的注册数据将能够存储在数据库中,但是当我尝试登录时,它会导致此错误并且我无法登录。有人有解决方案吗??

标签: android mysql


【解决方案1】:

编辑:

这是 Android 中的一个错误,已在更高版本的 Marshmallow 中修复

原文:

我相信这是棉花糖特有的。您使用的是 Marshmallow 设备吗?

我注意到每次在应用程序之间切换(不管是哪个)或退出应用程序时,以及活动被破坏时,都会打印出此错误。

我尝试在两台 Nexus 5 上运行相同的应用程序 - 一个运行 Lollipop,另一个运行 Marshmallow,这些日志打印只出现在 Marshmallow 版本上 - 每个应用程序,而不仅仅是我正在构建的应用程序。

不知道为什么会这样,但我打开了一个报告here

【讨论】:

  • 是的。确认如@Itai Hanski 所说。这是棉花糖特有的。将您的 API 级别切换到其他级别。
  • @ShylendraMadda:他们在 Android 6.0.1 中修复了这个问题:code.google.com/p/android/issues/detail?id=192357#c18
  • 这不是棉花糖特有的,我有 5.1.1(棒棒糖),我也收到此错误。我认为这与在 SQLite 数据库上读写数据有关。实际上,缓冲区已锁定,您没有任何访问权限。试试github.com/DezQ/ContactManager ,这是一个与SQLite集成的完整示例。
【解决方案2】:

我认为您在 backgrounTask 完成之前完成了上下文,并且您传递的上下文不再存在。
你可以试试:

  • 使用 appContext : new BackgroundTask(Register.this.getApplicationContext());

  • 或者,等待 BackgroundTask 完成:在 .execute(...) 之后删除 finish() 并添加 finish() onPostExecute

【讨论】:

    【解决方案3】:

    我没有具体问题的解决方案。但我有类似的问题。 遇到此类问题的任何人请确保您有以下代码。

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.<YOUR_XML_FILE_NAME>);
    

    通过使用智能,您可能会选择以下代码:

    @Override
    public void onCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
        super.onCreate(savedInstanceState, persistentState);
        setContentView(R.layout.<YOUR_XML_FILE_NAME>);
    }
    

    这对我有用

    For more info on PersistentState

    编码愉快:)

    【讨论】:

      【解决方案4】:

      将您的安卓操作系统更新到 6.0.1。

      这是here 发现的一个未解决问题。该问题已在最近公开发布的 Android 6.0.1 中得到修复。

      【讨论】:

        【解决方案5】:

        这很奇怪,但在我的情况下,我在尝试加载联系人而不添加时遇到了这个错误

        &lt;uses-permission android:name="android.permission.READ_CONTACTS" /&gt;

        进入清单。我刚刚完成它就消失了。

        所以我猜这可能是 Marshmallow 中具有新权限的东西。

        在我的 Nexus 5 上使用 Android 6.0 和 build.gradle 中的 targetSdkVersion 23 测试

        【讨论】:

          【解决方案6】:

          由于 android 更改了权限请求(某些权限,如 android.permission.READ_PHONE_STATEandroid.permission.READ_CONTACTS),当您在运行时请求这些权限并且不在manifest中添加权限标签(),会报错.

          所以只需像旧版本一样使用标签权限,并在运行时在新版本中添加请求权限。

          【讨论】:

            猜你喜欢
            • 2016-11-29
            • 2016-02-16
            • 1970-01-01
            • 2014-03-01
            • 1970-01-01
            • 2023-03-08
            • 2016-07-17
            • 1970-01-01
            • 1970-01-01
            相关资源
            最近更新 更多