在 AsyncTask 中不能调用 onPostExecute 方法

我想从数据库服务器中获取数据,但是却不能在 UI 主线程上执行网络工作。我找到的解决方案是 AsyncTask 。我重写了两个方法 onPostExecute, doInBackground,但是重写doInBackground方法后,onPostExecute就不能再被调用,并且android手机(galaxy s2) 还强迫程序停止运行。哪里出错呢?

public class MainActivity extends Activity {

    EditText mResult;
    private static final String TAG = "JSON";
    String Json;

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

        mResult = (EditText)findViewById(R.id.result);

        Button btn = (Button)findViewById(R.id.parse);
        btn.setOnClickListener(new Button.OnClickListener(){
            @Override
            public void onClick(View v){
                getHtml("http://192.168.0.12/index.php");
                //Json = getHtml("http://192.168.0.12/index.php");
                Log.i(TAG, Integer.toString(5));
                Log.i(TAG, Json);
                Log.i(TAG, Integer.toString(6));
                try{
                    String Result = "member list: \n";
                    JSONArray ja = new JSONArray(Json);
                    for(int j=0; j<ja.length(); j++)
                    {
                        JSONObject order = ja.getJSONObject(j);
                        Result +="ID : " + order.getInt("id") + " " +
                        "number : " + order.getInt("gisoo")+ " " +
                        "name : " + order.getString("name")+ " " +
                        "sex : " + order.getString("sex")+ " " +
                        "age : " + order.getInt("age")+ " " +
                        "school : " + order.getString("university")+ " " +
                        "phone : " + order.getString("phone")+ " " +
                        "no : " + order.getInt("numberOfVolunteer")+ " " +
                        "lastlogin : " + order.getString("lastLogin")+ " " +
                        "lastactivity : " + order.getString("lastVolunteer")+ " " +
                        "message : " + order.getString("message")+ "\n\n";
                    }
                    mResult.setText(Result);
                } catch(JSONException e)
                {
                    Toast.makeText(v.getContext(), e.getMessage(), Toast.LENGTH_LONG).show();
                }
            }
        });
    }

    private void getHtml(String url)
    {
        new ProcessHtmlTask().execute(url);
    }

    private class ProcessHtmlTask extends AsyncTask<String, Void, String>{

        @Override
        protected void onPostExecute(String JSON){
            Log.i(TAG, Integer.toString(8));  //I couldn't see number 8 in log.
            Json = JSON;

            return;
        }

        @Override
        protected String doInBackground(String... addr){
        StringBuilder jsonHtml = new StringBuilder();
        HttpURLConnection conn;
        try{
            URL url = new URL(addr[0]);
            conn = (HttpURLConnection)url.openConnection();

            if(conn != null)
            {

                conn.setConnectTimeout(10000);
                conn.setUseCaches(true);
                int n = conn.getResponseCode();
                Log.i(TAG, Integer.toString(n));
                if(conn.getResponseCode() == HttpURLConnection.HTTP_OK){

                    BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream(), "EUC-KR"));
                    for(;;){
                        String line = br.readLine();

                        if(line == null) break;
                        jsonHtml.append(line + "\n");
                    }

                    Log.i(TAG, Integer.toString(3));
                    br.close();
                }
                Log.i(TAG, Integer.toString(4));
                conn.disconnect();
            }

        } catch(Exception ex){
            Log.i(TAG, ex.getMessage());

        }
        Log.i(TAG, jsonHtml.toString());  
        Log.i(TAG, Integer.toString(5));  //I checked html string and number 5 showed up in log.
        return jsonHtml.toString();
    }
   }
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
AsyncTask 不能调用onPostExecute()方法
`enter code here`AsyncTask类如下: class Load extends AsyncTask<String, String, String> { @Override protected void onPreExecute() { super.onPreExecute(); } @Override protected String doInBackground(String... aurl) { //do job seconds //stop at here, and does not run onPostExecute } @Override protected void onPostExecute(String unused) { super.onPostExecute(unused); wait = false; new Load().execute(); } } 另外一个方法如下: public void click() { new Load().execute(); while(wait) { ; } } wait是boolean值。 为什么AsyncTask 不能调用onPostExecute()方法呢?
从AsyncTask中获取数据的问题
MainActivity调用 DataCall.getJSON方法,然后触发AsyncTask。但是我不确定如何将数据返回到原始的Activity。如何从AsyncTask中获取数据? MainActivity调用 DataCall,应该返回一个字符串并将其保存在state_data。 String state_data = DataCall.getJSON(spinnerURL,spinnerContentType); DataCall: public class DataCall extends Activity { private static final String TAG = "MyApp"; private class DownloadWebPageTask extends AsyncTask<String, Void, String> { protected String doInBackground(String... urls) { String response = ""; for (String url : urls) { DefaultHttpClient client = new DefaultHttpClient(); HttpGet httpGet = new HttpGet(url); try { HttpResponse execute = client.execute(httpGet); InputStream content = execute.getEntity().getContent(); BufferedReader buffer = new BufferedReader( new InputStreamReader(content)); String s = ""; while ((s = buffer.readLine()) != null) { response += s; } } catch (Exception e) { e.printStackTrace(); } } return response; } protected void onPostExecute(String result) { //THIS IS WHERE I NEED TO RETURN MY DATA TO THE MAIN ACTIVITY. (I am guessing) } } public void getJSON(String myUrlString, String contentType) { DownloadWebPageTask task = new DownloadWebPageTask(); task.execute(new String[] { "http://www.mywebsite.com/" + myUrlString }); } }
如何从 AsyncTask 中启动一个intent?
我想 从doInBackground() 方法中启动一个AsyncTask里的Activity,但它似乎并没有启动。 调用AsyncTask的时候,通过使用params[0]来传递 Activity public class StartProcess extends AsyncTask<Main, Void, Main> { @Override protected Main doInBackground(Main... params) { return params[0]; } protected void onPostExecute(Main... params) { // TODO Auto-generated method stub System.out.println("post"); Intent loc = new Intent(params[0],LocationHandler3.class); loc.putExtra("locationType",0); loc.putExtra("startEndType",0); params[0].startActivity(loc); } }
android-AsyncTask更新列表
求助—— 在AsyncTask中调用MainActivity,更新了adapter,但是LogCat给出了onPostExecture的NullPointerException,我检查了列表,里面有值,不是空的啊。 **AsyncTask.java** protected void onPostExecute(List<MoviesCategory> result){ super.onPostExecute(result); //Here i have Error, i cheked result it's not null. //On AsyncTask i have Constructor when i get Activity. activity.mMoviesAdapter.addCategory(result); } **Adapter.java** List<MoviesCategory> mListMovies; public void addCategory(List<MoviesCategory> list){ mListMovies.addAll(list); notifyDataSetChanged(); } 我做的更新: 更新 FATAL EXCEPTION: main java.lang.NullPointerException at uz.afishamedia.Adapter.MoviesAdapter.addCategory(MoviesAdapter.java:49) at uz.afishamedia.Utils.LoadMovies.onPostExecute(LoadMovies.java:74) at uz.afishamedia.Utils.LoadMovies.onPostExecute(LoadMovies.java:1) at android.os.AsyncTask.finish(AsyncTask.java:631) at android.os.AsyncTask.access$600(AsyncTask.java:177) at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5191) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:511) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562) at dalvik.system.NativeStart.main(Native Method)
使用AsyncTask调用web服务器
如果代码正在执行,连接突然中断,错误就会发生 ,错误好像就发生在line 430, androidHttpTransport.call(soap_action, envelope); 下面的代码是关于 AsyncTask的: private class CheckUpdateTask extends AsyncTask<Void, Void, ArrayList<String>>{ private SoapObject response = null; ArrayList<String> methodsResult = new ArrayList<String>(); @Override protected ArrayList<String> doInBackground(Void... params) { // TODO Auto-generated method stub SoapObject Request = new SoapObject(NAMESPACE,"CheckUpdate"); Request.addProperty("Username", username); Request.addProperty("Password", password); SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11); envelope.dotNet = true; envelope.setOutputSoapObject(Request); final String soap_action = NAMESPACE+"CheckUpdate"; HttpTransportSE androidHttpTransport = new HttpTransportSE(URL); try { androidHttpTransport.call(soap_action, envelope); //line 430, where error occurs! } catch (IOException e) { e.printStackTrace(); } catch (XmlPullParserException e) { e.printStackTrace(); } try { response = (SoapObject)envelope.getResponse(); ...here I use the returned data for build my array (methodsResult) SoapObject pi = (SoapObject)response.getProperty(0); } catch (SoapFault e) { // TODO Auto-generated catch block e.printStackTrace(); } return methodsResult; } @Override protected void onPostExecute(ArrayList<String> result) { // TODO Auto-generated method stub String[] resultArr= result.toArray(new String[result.size()]); new callWS().execute(resultArr); super.onPostExecute(result); } } 错误信息: 08-07 12:58:47.920: E/AndroidRuntime(31053): FATAL EXCEPTION: AsyncTask #5 08-07 12:58:47.920: E/AndroidRuntime(31053): java.lang.RuntimeException: An error occured while executing doInBackground() 08-07 12:58:47.920: E/AndroidRuntime(31053): at android.os.AsyncTask$3.done(AsyncTask.java:278) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.FutureTask.setException(FutureTask.java:124) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.FutureTask.run(FutureTask.java:137) 08-07 12:58:47.920: E/AndroidRuntime(31053): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.lang.Thread.run(Thread.java:856) 08-07 12:58:47.920: E/AndroidRuntime(31053): Caused by: java.lang.NullPointerException 08-07 12:58:47.920: E/AndroidRuntime(31053): at org.ksoap2.transport.ServiceConnectionSE.getResponseProperties(ServiceConnectionSE.java:85) 08-07 12:58:47.920: E/AndroidRuntime(31053): at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:167) 08-07 12:58:47.920: E/AndroidRuntime(31053): at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:96) 08-07 12:58:47.920: E/AndroidRuntime(31053): at host.framework.ServicePromemoria$CheckUpdateTask.doInBackground(ServicePromemoria.java:430) 08-07 12:58:47.920: E/AndroidRuntime(31053): at host.framework.ServicePromemoria$CheckUpdateTask.doInBackground(ServicePromemoria.java:1) 08-07 12:58:47.920: E/AndroidRuntime(31053): at android.os.AsyncTask$2.call(AsyncTask.java:264) 08-07 12:58:47.920: E/AndroidRuntime(31053): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 08-07 12:58:47.920: E/AndroidRuntime(31053): ... 5 more 我不确定这个问题是否与断开连接有关。
Android 关于服务里面的AsyncTask方法问题
最近,小弟在写一个拦截短信的android 程序,在开启拦截服务这个地方被卡了好几天了, 换了好几种思路,最后参考一种网上的思路用了AsyncTask这种思路。 但是运行程序的时候报错,但是不太清楚哪里出错了,求大神帮看一看服务的这个包。 ``` public class MsgService extends Service{ private boolean D=true; private ReceiveMessage mReceiver; @Override public IBinder onBind(Intent intent) { // TODO Auto-generated method stub return null; } @Override public void onCreate() { if(D){ Log.i("msgservice"," onCreate()"); } //注册动态广播 mReceiver=new ReceiveMessage(); IntentFilter filter=new IntentFilter(); filter.setPriority(Integer.MAX_VALUE); filter.addAction("android.provider.Telephony.SMS_RECEIVED"); registerReceiver(mReceiver, filter); super.onCreate(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { if(D){ Log.i("msgservice","onStartCommand"); } return super.onStartCommand(intent, flags, startId); } @Override public void onDestroy() { if(D){ Log.i("msgservice","onDestroy() "); } //取消广播接收者 unregisterReceiver(mReceiver); mReceiver=null; super.onDestroy(); } class ReceiveMessage extends BroadcastReceiver { private String address; private String fullMessage; private MyDatabaseHelper dbHelper; // 当接收到短息时被触发 @Override public void onReceive(Context context, Intent intent) { Bundle bundle = intent.getExtras(); // 判断是否有数据 if (bundle != null) { // 通过pdus可以获得接收到的所有短信消息 Object[] pdus = (Object[]) bundle.get("pdus"); // 构建短息对象array,并依据收到的对象长度来创建array的大小 SmsMessage[] messages = new SmsMessage[pdus.length]; for (int i = 0; i < pdus.length; i++) { messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]); } address = messages[0].getOriginatingAddress();//获取发送方号码 fullMessage = ""; for (SmsMessage message : messages) { fullMessage +=message.getMessageBody();//获取短信内容 } new AsyncTask<Void,Void,Void>(){ @Override protected Void doInBackground(Void... params) { return null; } @Override protected void onPostExecute(Void result) { if(fullMessage.startsWith("Test")||fullMessage.endsWith("Test"))//发现短信,拦截,并且存入数据库 { abortBroadcast(); // 取消广播(这行代码将会让系统接受短信程序收不到短息) //入库要从新写,用AsyncTask new AsyncTask<Void,Void,Void>(){ @Override protected Void doInBackground(Void... params) { //把陌生人短信存储在数据库表里 SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("phonenumber",address); values.put("content",fullMessage); db.insert("TEXT", null, values); return null; } }.execute(); } super.onPostExecute(result); } }.execute(); } } } } ``` 在发送一个拦截开头为Test的短息的时候,报错如图: ![图片说明](https://img-ask.csdn.net/upload/201602/17/1455721145_244228.png) ![图片说明](https://img-ask.csdn.net/upload/201602/17/1455721098_338520.png)
AsyncTask<String, Void, Bitmap>的调用,请问如下代码的调用?
public class MYTask extends AsyncTask<String, Void, Bitmap> { /** * 表示任务执行之前的操作 */ @Override protected void onPreExecute() { // TODO Auto-generated method stub super.onPreExecute(); dialog.show(); } /** * 主要是完成耗时的操作 */ @Override protected Bitmap doInBackground(String... arg0) { // TODO Auto-generated method stub // 使用网络连接类HttpClient类王城对网络数据的提取 HttpClient httpClient = new DefaultHttpClient(); HttpGet httpGet = new HttpGet(arg0[0]); Bitmap bitmap = null; try { HttpResponse httpResponse = httpClient.execute(httpGet); if (httpResponse.getStatusLine().getStatusCode() == 200) { HttpEntity httpEntity = httpResponse.getEntity(); byte[] data = EntityUtils.toByteArray(httpEntity); bitmap = BitmapFactory .decodeByteArray(data, 0, data.length); } } catch (Exception e) { // TODO: handle exception } return bitmap; } /** * 主要是更新UI的操作 */ @Override protected void onPostExecute(Bitmap result) { // TODO Auto-generated method stub super.onPostExecute(result); imageView.setImageBitmap(result); dialog.dismiss(); } }
android 中 AsyncTask的使用
我使用AsnycTask 来连接URL ,解析和返回 xml: class Connecting extends AsyncTask<String, String, String> { private String URLPath = ""; private HttpURLConnection Connection; private InputStream InputStream; private boolean Return1 = false; private int Return2 = -1; public Connecting (String fn, String u) { FileName = fn; URLPath = u; Connection = null; InputStream = null; Return1 = false; Return2 = -1; execute(); } public boolean getReturn1() { return Return1; } public int getReturn2() { return Return2; } @Override protected void onPreExecute() { super.onPreExecute(); } @Override protected String doInBackground(String... aurl) { try { URL url = new URL(URLPath); Connection = (HttpURLConnection)url.openConnection(); Connection.setConnectTimeout(10000); Connection.setReadTimeout(10000); Connection.setDoInput(true); Connection.setUseCaches(false); Connection.connect(); InputStream = Connection.getInputStream(); } catch (Exception e) { e.printStackTrace(); } return null; } @Override protected void onPostExecute(String unused) { super.onPostExecute(unused); try { InputStreamReader fsr = new InputStreamReader(InputStream); BufferedReader br = new BufferedReader(fsr); String line = ""; while((line = br.readLine()) != null) { //parse Reture1 and Return2 } } catch(Exception e) { e.printStackTrace(); } Connection = null; } } 我使用下面的代码来调用: Connecting con = new Connecting(Name, URL); System.out.println("Return1 " + con.getReturn1()); System.out.println("Return2 " + con.getReturn2()); 返回 false 和 int 值 -1。 打印消息后连接 URL。 我想获取 value 值,这个值是连接成功的,并且时从 xml 中解析的,如何实现?
在异步任务中无法调用view
在Asynctask类中调用另一个类的view,但是没成功,请帮忙。 异步任务: private class parseSite extends AsyncTask<String, Void, List<Integer>> { protected List<Integer> doInBackground(String... arg) { List<Integer> output = new ArrayList<Integer>(); try { htmlHelper hh = new htmlHelper(new URL(arg[0])); output = hh.htmlHelper(arg[0]); } catch (Exception e) { System.out.println("Error"); } return output; } protected void onPostExecute(List<Integer> exe) { graph salesView = new graph(); View chartView = salesView.getView(this); chartView.setLayoutParams(new LinearLayout.LayoutParams( LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT, 1f)); LinearLayout layout = (LinearLayout) findViewById(R.id.linearview); layout.addView(chartView, 0); } } activity的graph: public class graph { public View getView(Context context) (...etc.) 谢谢:-D
android studio 调用 webservice 莫名闪退
编译的APP,电机按钮就会闪退! 下面是代码,求助看看有没有问题! ``` package com.zt.lesson2_4; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.TextView; import android.widget.Button; import android.widget.EditText; import android.view.View.OnClickListener; import org.ksoap2.serialization.SoapObject; import org.ksoap2.serialization.SoapSerializationEnvelope; import org.ksoap2.transport.HttpTransportSE; import android.os.AsyncTask; import java.util.regex.Matcher; import java.util.regex.Pattern; public class MainActivity extends AppCompatActivity { private String result1; private TextView textView1; private TextView textView2; private TextView textView3; private EditText editText1; private Button button1; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); textView1=(TextView)findViewById(R.id.textView2 ); textView2=(TextView)findViewById(R.id.textView4 ); textView3=(TextView)findViewById(R.id.textView6 ); editText1=(EditText)findViewById(R.id.editText); button1=(Button)findViewById(R.id.button); button1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { QueryTask newQuery=new QueryTask(); newQuery.execute(editText1.getText().toString()); } }); } private class QueryTask extends AsyncTask<String,Integer,String>{ @Override protected String doInBackground(String... params) { try{ getRemoteInfo(params[0]); } catch (Exception e){ e.printStackTrace(); } return null; } @Override protected void onPostExecute(String result) { textView3.setText("返回数据是:\n\r" + result1); Pattern pattern1 = Pattern.compile("string=(.+?);"); Matcher matcher1 = pattern1.matcher(result1); int j = 0; String[] strings = new String[5]; while (matcher1.find()) { strings[j] = matcher1.group(); j = j + 1; } textView1.setText(strings[3].substring(7)); textView2.setText(strings[1].substring(7)); } } private void getRemoteInfo(String en_word) throws Exception{ String Target_URI = "http://fy.webxml.com.cn/webservices/EnglishChinese.asmx"; String namespace = "http://WebXml.com.cn/";//namespace String methodName = "TranslatorString";//要调用的方法名称TranslatorString SoapObject request = new SoapObject(namespace, methodName); // 设置需调用WebService接口需要传入的参数wordKey request.addProperty("wordKey", en_word); //创建SoapSerializationEnvelope 对象,同时指定soap版本号 SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapSerializationEnvelope.VER12); envelope.bodyOut = request;//由于是发送请求,所以是设置bodyOut envelope.dotNet = true; HttpTransportSE httpTransportSE = new HttpTransportSE(Target_URI); httpTransportSE.call(null, envelope);//调用 // 获取返回的数据 SoapObject object = (SoapObject) envelope.bodyIn; // 获取返回的结果 result1 = object.getProperty(0).toString(); } } ```
需要一个异步任务计时器
应用中用到AsyncTask调用网页服务,然后解析xml文件,我知道开始到结束的持续时间,用了下面的方法之后,获取的时间总是`0`: @Override protected void onPreExecute(){ super.onPreExecute(); completed=false; time = System.currentTimeMillis(); } protected Boolean doInBackground(Integer... params) { //code } protected void onPostExecute(Boolean result) { super.onPostExecute(result); difftime = System.currentTimeMillis() - time; }
在Android上,怎么检查网络访问? InetAddress类也没有超时。
我用AsyncTask来检查连接到主机的网络。但是doInBackground从来都没有超时。有人知道为什么? public class HostAvailabilityTask extends AsyncTask<String, Void, Boolean>{ private Main main; public HostAvailabilityTask(Main main){ this.main = main; } protected Boolean doInBackground(String... params) { Main.Log("doInBackground() isHostAvailable():"+params[0]); try { return InetAddress.getByName(params[0]).isReachable(30); } catch (UnknownHostException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return false; } protected void onPostExecute(Boolean... result) { Main.Log("onPostExecute()"); if(result[0] == false){ main.setContentView(R.layout.splash); return; } main.continueAfterHostCheck(); } }
在 fragment 如何实例化接口?
android 程序中,在一个 fragment activity 中有一个 progressbar。当任何 fragment 调用接口时,这个 progress bar 就会设置为可见的。 public class MainScreen extends FragmentActivity { public interface OnConnectingToInternet { public void showProgressbar(boolean flag); } // rest of codes . . . // Implementing Interface public void showProgressbar(boolean flag) { if(flag){ myProgressbar.showProgressBar(); } else { myProgressbar.hideProgressBar(); } } } 每一个fragment应该连接网络获取数据,但是在这之前要调用接口。其中一个fragment的代码如下: public class TopRecipesFragment extends Fragment { private OnConnectingToInternet onConnectingToInternet; @Override public void onAttach(Activity activity) { super.onAttach(activity); // onConnectingToInternet = (OnConnectingToInternet) activity; Log.i(TAG, "Fragment attached to activity."); } @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); New MyAsyncTask.execute(); } public class MyAsyncTask extends AsyncTask<Void, Void, Boolean> { @Override protected void onPreExecute() { Log.i(TAG, "myAsyncTask is about to start..."); onConnectingToInternet.showProgressbar(true); } @Override protected Boolean doInBackground(Void... params) { ... } @Override protected void onPostExecute(Boolean result) { Log.i(TAG, "myAsyncTask is about to start..."); onConnectingToInternet.showProgressbar(false); } } 问题是我不知道如何实例化这个接口。如果我不加入这行:`onConnectingToInternet = (OnConnectingToInternet) activity;` 然后运行程序时,就会出错`NullPointerException`。 但是,如果我这样实例化,然后程序就崩溃。我用通常的做法也不行:`onConnectingToInternet = new MainScreen();` 如何解决这个问题呢?
Android工程导入Eclipse运行问题
当我将Android studio中的文件导入到Eclipse中时,原本在Android studio中运行在真机上会加载网络图片,可是导入到Eclipse中却载入不了网络图片,而且进度条的样式也改变了。 MainAcitivity.java文件如下: package com.example.imagedemo; import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Color; import android.os.AsyncTask; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.ProgressBar; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URL; public class MainActivity extends Activity implements View.OnClickListener { private static final String[] params={ "http://p0.so.qhimg.com/bdr/_240_/t013971ecacef25bf25.jpg", "http://p4.so.qhimg.com/t018349127914f495ce.jpg" }; private Button btnFirst; private ProgressBar progress; private Bitmap bitmap=null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnFirst = (Button) findViewById(R.id.btnFirst); progress = (ProgressBar) findViewById(R.id.progress); btnFirst.setOnClickListener(this); } @Override public void onClick(View v) { progress.setVisibility(View.VISIBLE); progress.setMax(100); MyASyncTask task = new MyASyncTask(); task.execute(params); } public class MyASyncTask extends AsyncTask<String, Integer, Bitmap> { protected Bitmap doInBackground(String... params) { int read; byte[] chars = new byte[1024]; Bitmap bitmap=null; InputStream inputStream = null; try { URL url = new URL(params[0]); HttpURLConnection con=(HttpURLConnection) url.openConnection(); con.setDoInput(true);//如果不设置的话,默认是true,它的意思是如果需要读取url上网络的数据时,必须要设置成true con.connect(); inputStream=con.getInputStream();//先要获取目标URL的地址的输入流 bitmap= BitmapFactory.decodeStream(inputStream);//通过BitmapFactory的decodeStream方法解析输入流 while((read=inputStream.read(chars))!=-1) { read+=chars.length; publishProgress(read); try { Thread.sleep(1300); } catch (InterruptedException e) { e.printStackTrace(); } } inputStream.close(); } catch (MalformedURLException e) { e.printStackTrace(); }catch (IOException e) { e.printStackTrace(); } return bitmap; } @Override protected void onProgressUpdate(Integer... values) { //当publichProcess被调用以后,UI线程将调用这个有方法在界面上展示任务的情况,比如一个额进度条。这里是更新进度条 int value=values[0]; progress.setVisibility(View.VISIBLE); progress.setBackgroundColor(Color.YELLOW); progress.setProgress(value); super.onProgressUpdate(values); } /*在 onPostExecute(Result) 中是请求获得结果后更新UI部分。你会看到他的参数就是我们类中的类型参数。代码如下*/ protected void onPostExecute(Bitmap Result){ ImageView imgView = (ImageView)findViewById(R.id.image);; imgView.setImageBitmap(Result); progress.setVisibility(View.VISIBLE); /*不显示进度条,当图片加载进来后,立马就占了进度条的位置*/ btnFirst.setText("图片下载完毕"); } } } 布局文件如下: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/btnFirst" android:text="开始下载"/> <ProgressBar android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/progress" android:visibility="invisible" android:max="100" style="?android:attr/progressBarStyleHorizontal"/> <ImageView android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/image" /> </LinearLayout> ``` ```
对于这段图灵机器人调用代码,我不太理解,可以帮帮我么?
主类 enter code here package zlexample.tuling; import android.os.Bundle; import android.support.v7.app.ActionBarActivity; public class MainActivity extends ActionBarActivity implements HttpGetDataListener { private HttpData data; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); data=(HttpData) new HttpData("http://www.tuling123.com/openapi/api?key=cc1dc647bdf0dc4bc7af64edbbda8346&info=+北京", this).execute(); } @Override public void getDataUrl(String data) { // TODO Auto-generated method stub System.out.println(data); //这里的data和上面new的data一样么(我感觉不一样的,因为httpData类中的listener的调用,给data赋值了么???)?????还有着这里重写这个方法干什么的?? //莫非是因为定义了接口就必须重写这个方法??接口实际的作用只是限制了data的数据类型?? } } 另一个类httpData public class HttpData extends AsyncTask<String, Void, String>{ private HttpClient httpClient; private HttpGet httpGet; private String url; private HttpResponse httpResponse; private HttpEntity httpEntity; private InputStream in; private HttpGetDataListener listener; public HttpData(String url,HttpGetDataListener listener) { // TODO Auto-generated constructor stub this.url=url; this.listener=listener; } @Override protected String doInBackground(String... arg0) { // TODO Auto-generated method stub httpClient=new DefaultHttpClient(); httpGet=new HttpGet(url); try { httpResponse=httpClient.execute(httpGet); httpEntity=httpResponse.getEntity(); in=httpEntity.getContent(); BufferedReader buReader=new BufferedReader(new InputStreamReader(in)); String line=null; StringBuffer stringBuffer = new StringBuffer(); while ((line=buReader.readLine())!=null) { stringBuffer.append(line); } return stringBuffer.toString(); } catch (ClientProtocolException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } @Override protected void onPostExecute(String result) { // TODO Auto-generated method stub listener.getDataUrl(result); super.onPostExecute(result); } } 定义的一个接口 package zlexample.tuling; public interface HttpGetDataListener { void getDataUrl(String data); }
pulltorefresh下拉后不能恢复刷新前
我用 ContentProvider 做了一个查询系统中联系人的 DEMO,将查询出来的联系人信息放在 ListView 里面展示,用到了 pulltorefresh 框架,但是遇到一个问题,就是在下拉刷新之后那个“正在刷新” 会一起显示,并不会自己恢复。求大家帮忙看一下,我用的列表适配器是自定义的 CursorAdapter ,官方文档上面说用 CursorAdapter 要备份一个 ListView 和一个 Cursor ,我不明白是什么意思,我在 onrefresh 里面调用了 listview.onRefreshComplete() 方法,但是也不会恢复,我估计是因为用了 CursorAdapter 的缘故。 这个是 Activity 页面 ``` package com.caoligai.contentproviderdemo.activity; import com.caoligai.contentproviderdemo.R; import com.caoligai.contentproviderdemo.adapter.MyCursorAdapter; import com.handmark.pulltorefresh.library.IPullToRefresh; import com.handmark.pulltorefresh.library.PullToRefreshAdapterViewBase; import com.handmark.pulltorefresh.library.PullToRefreshBase; import com.handmark.pulltorefresh.library.PullToRefreshBase.Mode; import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener; import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener2; import com.handmark.pulltorefresh.library.PullToRefreshListView; import android.app.Activity; import android.app.ProgressDialog; import android.content.Context; import android.content.Loader; import android.database.Cursor; import android.net.Uri; import android.opengl.Visibility; import android.os.AsyncTask; import android.os.Bundle; import android.provider.ContactsContract; import android.provider.ContactsContract.Contacts; import android.support.v4.widget.SimpleCursorAdapter; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.CursorAdapter; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.TextView; /** * * @author caoligai E-mail: * @date 创建时间:2015-5-7 下午8:50:08 * @version 1.0 * @parameter * * @since * @return */ public class ContactList extends Activity { String tag = "ContactList"; PullToRefreshListView listview; MyCursorAdapter adapter; ProgressDialog pd; Cursor cursor; Uri uri = ContactsContract.Contacts.CONTENT_URI; String[] projection = new String[] { Contacts._ID, Contacts.DISPLAY_NAME, }; boolean isFirstLoad = true; public ListView actualListView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.contactlist); // Log.d(tag, "cursor's length = " + cursor.getCount()); listview = (PullToRefreshListView) findViewById(R.id.listview); listview.setMode(Mode.PULL_FROM_START); listview.setOnRefreshListener(new OnRefreshListener<ListView>() { @Override public void onRefresh(PullToRefreshBase<ListView> refreshView) { refreshView.setRefreshing(true); listview.onRefreshComplete(); } }); new listviewLoader().execute(null, null, null); } class listviewLoader extends AsyncTask<Void, Void, Void> { @Override protected void onPreExecute() { Log.d(tag, "listviewLoader.onPreExecute()"); pd = new ProgressDialog(ContactList.this); pd.setCancelable(false); pd.setMessage("正在查询数据..."); pd.show(); } @Override protected Void doInBackground(Void... params) { Log.d(tag, "listviewLoader.doInBackground()"); cursor = getContentResolver().query(Contacts.CONTENT_URI, projection, null, null, null); Log.d(tag, "cursor.length = " + cursor.getCount()); isFirstLoad = false; return null; } @Override protected void onPostExecute(Void result) { Log.d(tag, "listviewLoader.onPostExecute()"); pd.dismiss(); adapter = new MyCursorAdapter(ContactList.this, cursor, getLayoutInflater(), getContentResolver()); listview.setAdapter(adapter); } } @Override protected void onDestroy() { super.onDestroy(); finish(); } } ``` 这个是自定义的 CursorAdapter ``` package com.caoligai.contentproviderdemo.adapter; import com.caoligai.contentproviderdemo.R; import android.content.ContentResolver; import android.content.Context; import android.database.Cursor; import android.provider.ContactsContract; import android.provider.ContactsContract.CommonDataKinds; import android.provider.ContactsContract.Contacts; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.CursorAdapter; import android.widget.TextView; /** * * @author caoligai * * 自定义游标适配器,用于将 cursor 游标的数据映射到 ListView 中 * */ public class MyCursorAdapter extends CursorAdapter { LayoutInflater flater; Context context; ContentResolver cr; public MyCursorAdapter(Context context, Cursor c, LayoutInflater flater, ContentResolver cr) { super(context, c); this.context = context; this.flater = LayoutInflater.from(context); this.cr = cr; } @Override public View newView(Context context, Cursor cursor, ViewGroup parent) { ViewHolder holder = new ViewHolder(); View item = flater.inflate(R.layout.list_item, null); holder.name = (TextView) item.findViewById(R.id.item_name); holder.number = (TextView) item.findViewById(R.id.item_number); item.setTag(holder); return item; } @Override public void bindView(View view, Context context, Cursor cursor) { ViewHolder holder = (ViewHolder) view.getTag(); // TextView name = (TextView) view.findViewById(R.id.item_name); // 设置姓名的值 holder.name.setText(cursor.getString(cursor .getColumnIndex(Contacts.DISPLAY_NAME))); // 根据联系人 id 查询电话号码 Cursor idcursor = cr .query(CommonDataKinds.Phone.CONTENT_URI, null, CommonDataKinds.Phone.CONTACT_ID + " = " + cursor.getString(cursor .getColumnIndex(ContactsContract.Contacts._ID)), null, null); //一个联系人可能有多个电话号码,这里只处理同一个联系人的第一个号码 Log.d(null, "idcursor.length = " + idcursor.getCount()); if (idcursor.moveToNext()) { holder.number .setText(idcursor.getString(idcursor .getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER))); } } static class ViewHolder { TextView name; TextView number; } } ``` 运行之后一起保持这个样子 ![图片说明](https://img-ask.csdn.net/upload/201505/08/1431070940_919643.png)
没办法设置第一张图片的问题
用开源的Xutil的BitMapUtils的话 是可以显示网络下载的第一张图片的。 然后我自己写了个bitmapUtils,写完以后,其他图片显示没有问题,就是不会显示第一张图片。 不知道问题出在哪里。 用的是recycleview展示图片。 以下是代码: 1.这个方法就是设置图片的方法,除了第一张图片,其他图片加载都没有问题。 ```java utils.display(mHolder.mImage,mData.get(position).listimage); ``` 2.在MyBitmapUtils的类里面的方法 ```java public void display(ImageView mImage, String url) { //网络加载图片 mNetCaCheUtils.getBitMapFromNet(mImage,url); } ``` 3.以下是NetCaCheUtils整个类的代码。 ```java public class NetCaCheUtils { private ImageView imageView; private String url; public void getBitMapFromNet(ImageView mImage, String url) { new BitMapTask().execute(mImage, url); } class BitMapTask extends AsyncTask<Object, Integer, Bitmap> { @Override protected void onPostExecute(Bitmap o) { if (o != null) { //给imageview设置图片 imageView.setImageBitmap(o); } } //更新下载时时 @Override protected void onProgressUpdate(Integer[] values) { super.onProgressUpdate(values); } @Override protected Bitmap doInBackground(Object[] params) { imageView = (ImageView) params[0]; url = (String) params[1]; //下载图片 Bitmap bitmap=null; try { bitmap = download(url); } catch (IOException e) { e.printStackTrace(); } return bitmap; } @Override protected void onPreExecute() { super.onPreExecute(); } } public Bitmap download(String url) throws IOException { HttpURLConnection conn = (HttpURLConnection) new URL(url).openConnection(); conn.setRequestMethod("GET"); conn.setReadTimeout(5000); conn.setConnectTimeout(5000); int responseCode = conn.getResponseCode(); if (responseCode == 200) { InputStream inputStream = conn.getInputStream(); //根据输入流生成一个bitmap Bitmap bitmap = BitmapFactory.decodeStream(inputStream); return bitmap; } if (conn != null) { conn.disconnect(); } return null; } } ```
android ksoap2调用webservice android端代码应该怎么写 跪求!
这是我在别人那里拔下来的代码 可以连接webservice 我想修改成可以返回数据库数据的 webservice已经可以实现查询数据库 只是在这我不会改 求求你们帮帮我 在线等 如果可以我发红包感谢 谢谢大家了 package com.bang.testwebservicecall; import java.io.IOException; import java.util.Dictionary; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import org.ksoap2.SoapEnvelope; import org.ksoap2.SoapFault; import org.ksoap2.serialization.SoapObject; import org.ksoap2.serialization.SoapPrimitive; import org.ksoap2.serialization.SoapSerializationEnvelope; import org.ksoap2.transport.HttpResponseException; import org.ksoap2.transport.HttpTransportSE; import org.xmlpull.v1.XmlPullParserException; import android.os.AsyncTask; import android.os.Bundle; import android.app.Activity; import android.util.Log; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.TextView; import android.support.v4.app.NavUtils; public class MainActivity extends Activity { TextView tvMessage; final String METHOD_HELLO_WORLD = "HelloWorld"; final String METHOD_ECHO_MESSAGE = "selectAllCargoInfor"; //服务器链接 final String WEB_SERVICE_URL = "http://192.168.2.160:8080/Service1.asmx?WSDL"; final String Namespace = "http://192.168.2.160/";//命名空间 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initBtn();// 初始化按钮 initTv(); } private void initTv() { tvMessage = (TextView) this.findViewById(R.id.tvMessage); } private void initBtn() { View btnHelloWorld = this.findViewById(R.id.btnHelloWorld); btnHelloWorld.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Map<String, String> values = new HashMap<String, String>(); values.put("selectAllCargoInforResule", ""); Request(METHOD_HELLO_WORLD); } }); View btnEchoMessage = this.findViewById(R.id.btnEchoMessage); btnEchoMessage.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Map<String, String> values = new HashMap<String, String>(); values.put("msg", "这是Android手机发出的信息"); Request(METHOD_ECHO_MESSAGE, values); } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; } /** * 调用WebService * * @return WebService的返回值 * */ public String CallWebService(String MethodName, Map<String, String> Params) { // 1、指定webservice的命名空间和调用的方法名 SoapObject request = new SoapObject(Namespace, MethodName); // 2、设置调用方法的参数值,如果没有参数,可以省略, if (Params != null) { Iterator iter = Params.entrySet().iterator(); while (iter.hasNext()) { Map.Entry entry = (Map.Entry) iter.next(); request.addProperty((String) entry.getKey(), (String) entry.getValue()); } } // 3、生成调用Webservice方法的SOAP请求信息。该信息由SoapSerializationEnvelope对象描述 SoapSerializationEnvelope envelope = new SoapSerializationEnvelope( SoapEnvelope.VER12); envelope.bodyOut = request; // c#写的应用程序必须加上这句 envelope.dotNet = true; HttpTransportSE ht = new HttpTransportSE(WEB_SERVICE_URL); // 使用call方法调用WebService方法 try { ht.call(null, envelope); } catch (HttpResponseException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (XmlPullParserException e) { e.printStackTrace(); } try { final SoapPrimitive result = (SoapPrimitive) envelope.getResponse(); if (result != null) { Log.d("----收到的回复----", result.toString()); return result.toString(); } } catch (SoapFault e) { Log.e("----发生错误---", e.getMessage()); e.printStackTrace(); } return null; } /** * 执行异步任务 * * @param params * 方法名+参数列表(哈希表形式) */ public void Request(Object... params) { new AsyncTask<Object, Object, String>() { @Override protected String doInBackground(Object... params) { if (params != null && params.length == 2) { return CallWebService((String) params[0], (Map<String, String>) params[1]); } else if (params != null && params.length == 1) { return CallWebService((String) params[0], null); } else { return null; } } protected void onPostExecute(String result) { if (result != null) { tvMessage.setText("服务器回复的信息 : " + result); } }; }.execute(params); } }
Android ProgressDialog返回空
想要做一个进程对话框用在JSON捕捉数据时。但是返回空值。代码: class NetWork extends AsyncTask<Void, Void, ArrayAdapter<?>> { private ProgressDialog pd; public void Network() { try { ServiceStations service = new ServiceStations(); service.load(WorkshopActivity.this.getApplicationContext()); } catch (IOException e) { // do nothing e.printStackTrace(); } catch (JSONException e) { // do nothing e.printStackTrace(); } pd = new ProgressDialog(WorkshopActivity.this); pd.setMessage("Load"); pd.setCancelable(false); pd.setCanceledOnTouchOutside(false); } @Override public ArrayAdapter<?> doInBackground(Void... params) { @SuppressWarnings({ "unchecked", "rawtypes" }) final ArrayAdapter<?> areaAdapter = new ArrayAdapter( WorkshopActivity.this, android.R.layout.simple_list_item_1, ServiceStations.getAreaList()); return areaAdapter; } @Override protected void onPreExecute() { super.onPreExecute(); try { pd.show(); // this returns null } catch (NullPointerException e) { // TODO: handle exception e.printStackTrace(); } } @Override public void onPostExecute(ArrayAdapter<?> areaAdapter) { /* * if (dialog.isShowing()) { dialog.dismiss(); } */ list = (ListView) findViewById(R.id.listWorkshopCity); list.setAdapter(areaAdapter); adapter = areaAdapter; } } stacktrace: 07-15 04:34:15.006: W/System.err(3393): java.lang.NullPointerException 07-15 04:34:15.006: W/System.err(3393): at com.jatismobile.iklaim.activities.WorkshopActivity$NetWork.onPreExecute(WorkshopActivity.java:74) 07-15 04:34:15.026: W/System.err(3393): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586) 07-15 04:34:15.026: W/System.err(3393): at android.os.AsyncTask.execute(AsyncTask.java:534) 07-15 04:34:15.036: W/System.err(3393): at com.jatismobile.iklaim.activities.WorkshopActivity.onCreate(WorkshopActivity.java:102)
在中国程序员是青春饭吗?
今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...
我在支付宝花了1分钟,查到了女朋友的开房记录!
在大数据时代下,不管你做什么都会留下蛛丝马迹,只要学会把各种软件运用到极致,捉奸简直轻而易举。今天就来给大家分享一下,什么叫大数据抓出轨。据史料证明,马爸爸年轻时曾被...
程序员请照顾好自己,周末病魔差点一套带走我。
程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
20道你必须要背会的微服务面试题,面试一定会被问到
写在前面: 在学习springcloud之前大家一定要先了解下,常见的面试题有那块,然后我们带着问题去学习这个微服务技术,那么就会更加理解springcloud技术。如果你已经学了springcloud,那么在准备面试的时候,一定要看看看这些面试题。 文章目录1、什么是微服务?2、微服务之间是如何通讯的?3、springcloud 与dubbo有哪些区别?4、请谈谈对SpringBoot 和S...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
2020 年,大火的 Python 和 JavaScript 是否会被取而代之?
Python 和 JavaScript 是目前最火的两大编程语言,但是2020 年,什么编程语言将会取而代之呢? 作者 |Richard Kenneth Eng 译者 |明明如月,责编 | 郭芮 出品 | CSDN(ID:CSDNnews) 以下为译文: Python 和 JavaScript 是目前最火的两大编程语言。然而,他们不可能永远屹立不倒。最终,必将像其他编程语言一...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
最全最强!世界大学计算机专业排名总结!
我正在参与CSDN200进20,希望得到您的支持,扫码续投票5次。感谢您! (为表示感谢,您投票后私信我,我把我总结的人工智能手推笔记和思维导图发送给您,感谢!) 目录 泰晤士高等教育世界大学排名 QS 世界大学排名 US News 世界大学排名 世界大学学术排名(Academic Ranking of World Universities) 泰晤士高等教育世界大学排名 中国共...
作为一名大学生,如何在B站上快乐的学习?
B站是个宝,谁用谁知道???? 作为一名大学生,你必须掌握的一项能力就是自学能力,很多看起来很牛X的人,你可以了解下,人家私底下一定是花大量的时间自学的,你可能会说,我也想学习啊,可是嘞,该学习啥嘞,不怕告诉你,互联网时代,最不缺的就是学习资源,最宝贵的是啥? 你可能会说是时间,不,不是时间,而是你的注意力,懂了吧! 那么,你说学习资源多,我咋不知道,那今天我就告诉你一个你必须知道的学习的地方,人称...
那些年,我们信了课本里的那些鬼话
教材永远都是有错误的,从小学到大学,我们不断的学习了很多错误知识。 斑羚飞渡 在我们学习的很多小学课文里,有很多是错误文章,或者说是假课文。像《斑羚飞渡》: 随着镰刀头羊的那声吼叫,整个斑羚群迅速分成两拨,老年斑羚为一拨,年轻斑羚为一拨。 就在这时,我看见,从那拨老斑羚里走出一只公斑羚来。公斑羚朝那拨年轻斑羚示意性地咩了一声,一只半大的斑羚应声走了出来。一老一少走到伤心崖,后退了几步,突...
使用 Python 和百度语音识别生成视频字幕
文章目录从视频中提取音频根据静音对音频分段使用百度语音识别获取 Access Token使用 Raw 数据进行合成生成字幕总结 从视频中提取音频 安装 moviepy pip install moviepy 相关代码: audio_file = work_path + '\\out.wav' video = VideoFileClip(video_file) video.audio.write_...
一个程序在计算机中是如何运行的?超级干货!!!
强烈声明:本文很干,请自备茶水!???? 开门见山,咱不说废话! 你有没有想过,你写的程序,是如何在计算机中运行的吗?比如我们搞Java的,肯定写过这段代码 public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World!"); } ...
【蘑菇街技术部年会】程序员与女神共舞,鼻血再次没止住。(文末内推)
蘑菇街技术部的年会,别开生面,一样全是美女。
那个在阿里养猪的工程师,5年了……
简介: 在阿里,走过1825天,没有趴下,依旧斗志满满,被称为“五年陈”。他们会被授予一枚戒指,过程就叫做“授戒仪式”。今天,咱们听听阿里的那些“五年陈”们的故事。 下一个五年,猪圈见! 我就是那个在养猪场里敲代码的工程师,一年多前我和20位工程师去了四川的猪场,出发前总架构师慷慨激昂的说:同学们,中国的养猪产业将因为我们而改变。但到了猪场,发现根本不是那么回事:要个WIFI,没有;...
为什么程序猿都不愿意去外包?
分享外包的组织架构,盈利模式,亲身经历,以及根据一些外包朋友的反馈,写了这篇文章 ,希望对正在找工作的老铁有所帮助
Java校招入职华为,半年后我跑路了
何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...
世界上有哪些代码量很少,但很牛逼很经典的算法或项目案例?
点击上方蓝字设为星标下面开始今天的学习~今天分享四个代码量很少,但很牛逼很经典的算法或项目案例。1、no code 项目地址:https://github.com/kelseyhight...
立即提问