android读取手机联系人并在textview中显示名字时中文乱码怎么解决?

android读取手机联系人并在textview中显示名字时中文乱码怎么解决?从数据库里来的中文的全变成"?"了,其他的正常。

2个回答

new String(lCursor.getBlob(indexName), "UTF-8").replace("\0", "").replace("\r", "");
  1. 数据库连接以后,先执行一下“set names 'utf8';”或者gb2312
  2. 替换读取出来内容的“\r”。如str.replace("\r", "");
  3. java源文件编码不正确。通常情况是要修改一下源文件的编码。识别方法:在源文件点右键,properties,找到Resource,在右侧找Text file encoding,选择另一个,如果正常了,说明文件编码与工程编码不一致,需要使用其他软件修改编码格式,如notepad++、UltreEdit32
Eiseno
Eiseno 查询的数据要和你显示需要的编码匹配
大约 7 年之前 回复
usniyo
usniyo 感谢您的回答!但是在android中,联系人查询是使用内容提供器向外提供一些接口以实现信息共享的,它所提供的接口有限,除了查询、更新、删除联系人信息我无法做其他的操作。因此我无法查询它是用什么样的字符集,虽然sqlite默认是使用utf-8,但我读出的信息确实是乱码了,不知何故。另,出现这种情况只是出现在某些机子上。
大约 7 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android textview内容消失问题
我做了一个简单的fragment界面,主要是输入ID,然后向服务器查询内容后赋值回原来的界面上的textview,但是在运行的时候发生了一个奇怪的问题,一部分的textview消失了,具体很难描述,以下是整个过程的描述 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463197893_214757.jpg) 这是个原始界面,在最上方输入编号,然后查询。 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463197987_723570.jpg) 点击查询后,可以看见,背景内容已经加载,textview的内容已经进去了,但是加载完成后,textview ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198182_802396.jpg) 如上图,加载完成后,下面的Textview不见了,而且,连那些实现写好的静态的textview也不见了 然后,我通过弹出输入法,用输入法覆盖部分内容 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198282_9279.jpg) 像上图这样,在搜索框中点击之后,输入法会自动弹出,覆盖掉下面的内容,然后再取消 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198349_994971.jpg) 然后内容就出来了。。。 每次都是这个样子。。我觉得很奇怪,不知道什么原因导致的,谁能帮忙看看吗?谢谢 整个框架大框架是fragment+viewpage,查询用的AsyncTask查询后赋值。 上代码了,布局文件,是一个fragment_content,xml ``` <?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <EditText android:layout_width="270dip" android:layout_height="52dip" android:id="@+id/searchText" android:hint="请输入客户编号ID或扫二维码" android:background="@android:drawable/editbox_background_normal"/> <ImageButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@android:drawable/ic_menu_search" android:id="@+id/search_button"/> <ImageButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@android:drawable/ic_menu_camera" android:id="@+id/search_QRcode"/> </LinearLayout> <LinearLayout android:layout_marginTop="5dip" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:background="#F2F3EB"> <TextView android:layout_width="360dip" android:layout_height="35dip" android:text="业主信息" android:gravity="center" android:layout_gravity="center" android:layout_marginTop="8dip" android:background="@android:drawable/btn_default" /> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="业主名称"/> <TextView android:id="@+id/CustomerNAME" android:layout_width="300dip" android:layout_height="wrap_content" android:text="请输入客户ID" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="行业性质"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:gravity="center" android:id="@+id/CustomerSegment"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系地址"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerAddress" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系人"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerContactor" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" > <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系电话"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerPhone" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginLeft="4dip" android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="5dip"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="保养合约到期时间"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/Customercontactdate" android:gravity="center"/> </LinearLayout> //下面开始就是出问题的部分布局 </LinearLayout> <LinearLayout android:layout_marginTop="10dip" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:background="#F2F3EB"> <TextView android:layout_width="360dip" android:layout_height="35dip" android:text="维护人员信息" android:gravity="center" android:layout_gravity="center" android:layout_marginTop="8dip" android:background="@android:drawable/btn_default" /> <TextView android:layout_width="400dip" android:layout_height="30dip" android:text="专属客户代表" android:gravity="center" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="10dip"> <ImageView android:layout_width="120dip" android:layout_height="100dip" android:src="@drawable/unknownpic" android:id="@+id/SRPIC"/> <TableLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="姓名" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/ServiceRepresentive" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="职位" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRP" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="联系方式" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRN" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="工作年限" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRY" android:gravity="center"/> </TableRow> </TableLayout> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="400dip" android:layout_height="30dip" android:text="专属服务技师" android:gravity="center" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="10dip"> <ImageView android:layout_width="120dip" android:layout_height="100dip" android:src="@drawable/unknownpic" android:id="@+id/STPIC"/> <TableLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="姓名" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/ServiceTechnician" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="职位" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STN" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="工作年限" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STY" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="专业技能" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STS" android:gravity="center"/> </TableRow> </TableLayout> </LinearLayout> </LinearLayout> </LinearLayout> </LinearLayout> </ScrollView> ``` fragment的文件,里面除了查询,还有一个二维码扫描 ``` public class CustomerInf extends Fragment { ImageButton search,search_QRcode; EditText editText; String searchID; TextView CustomerName,CustomerSegment,CustomerAddress,CustomerContactor,CustomerPhone; TextView Customercontactdate,ServiceRepresentive,SRP,SRN,SRY,ServiceTechnician,STN,STY,STS; ImageView SRPIC,STPIC; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_content, container, false); bind(view); return view; } //对各内容进行绑定 public void bind(View view) { search = (ImageButton) view.findViewById(R.id.search_button); editText = (EditText) view.findViewById(R.id.searchText); CustomerName=(TextView)view.findViewById(R.id.CustomerNAME); CustomerSegment=(TextView)view.findViewById(R.id.CustomerSegment); CustomerAddress=(TextView)view.findViewById(R.id.CustomerAddress); CustomerContactor=(TextView)view.findViewById(R.id.CustomerContactor); CustomerPhone=(TextView)view.findViewById(R.id.CustomerPhone); Customercontactdate=(TextView)view.findViewById(R.id.Customercontactdate); ServiceRepresentive=(TextView)view.findViewById(R.id.ServiceRepresentive); SRP=(TextView)view.findViewById(R.id.SRP); SRN=(TextView)view.findViewById(R.id.SRN); SRY=(TextView)view.findViewById(R.id.SRY); ServiceTechnician=(TextView)view.findViewById(R.id.ServiceTechnician); STN=(TextView)view.findViewById(R.id.STN); STY=(TextView)view.findViewById(R.id.STY); STS=(TextView)view.findViewById(R.id.STS); SRPIC=(ImageView) view.findViewById(R.id.SRPIC); STPIC=(ImageView) view.findViewById(R.id.STPIC); search.setOnClickListener(new Click()); search_QRcode=(ImageButton)view.findViewById(R.id.search_QRcode); search_QRcode.setOnClickListener(new QRsearch()); } //此处是一个引用外部二维码扫描的程序 public class QRsearch implements View.OnClickListener{ @Override public void onClick(View v){ if (ContextCompat.checkSelfPermission(getContext(), Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { if (ActivityCompat.shouldShowRequestPermissionRationale(getActivity(), Manifest.permission.CAMERA)) { } else { requestPermissions( new String[]{Manifest.permission.CAMERA}, 123); } } else { Toast.makeText(getContext(),"开始扫描",Toast.LENGTH_SHORT).show(); Intent startScan=new Intent(getContext(), CaptureActivity.class); startActivityForResult(startScan, Activity.RESULT_FIRST_USER); } } } //二维码的返回 @Override public void onActivityResult(int requestCode,int resultCode,Intent data){ super.onActivityResult(requestCode,resultCode,data); if(resultCode==Activity.RESULT_OK){ Bundle bundle = data.getExtras(); String scanResult = bundle.getString("result"); editText.setText(scanResult); searchID = editText.getText().toString().trim(); if (TextUtils.isEmpty(searchID)) { Toast.makeText(getActivity(), "请输入客户ID"+searchID, Toast.LENGTH_LONG).show(); } else { SearchTask searchTask = new SearchTask(); String[] array=new String[]{"http://www.klmt001.com/CustomerINF.php",searchID}; searchTask.execute(array); } } } //这里是查询按钮的监听器 public class Click implements View.OnClickListener { @Override public void onClick(View v) { searchID = editText.getText().toString().trim(); if (TextUtils.isEmpty(searchID)) { Toast.makeText(getActivity(), "请输入客户ID"+searchID, Toast.LENGTH_LONG).show(); } else { SearchTask searchTask = new SearchTask(); String[] array=new String[]{"http://www.klmt001.com/CustomerINF.php",searchID}; searchTask.execute(array); } } } //监听按钮的AsyncTask class SearchTask extends AsyncTask<String, Integer, JSONObject> { ProgressDialog p1; @Override protected void onPreExecute() { p1=new ProgressDialog(getActivity()); p1.setTitle("请等待"); p1.setMessage("等待中........"); p1.setCancelable(false); p1.show(); new Handler().postDelayed(new Runnable(){ public void run() { p1.dismiss(); } }, 1000); } protected JSONObject doInBackground(String... inf) { HttpClient httpclient = new DefaultHttpClient(); HttpEntity entity = null; StringBuilder builder = new StringBuilder(); JSONObject jsonObject=null; try { HttpPost httpPost = new HttpPost(inf[0]); List<NameValuePair> list = new ArrayList<>(); list.add(new BasicNameValuePair("CustomerID", inf[1])); httpPost.setEntity(new UrlEncodedFormEntity(list, HTTP.UTF_8)); HttpResponse response = httpclient.execute(httpPost); entity = response.getEntity(); if (response.getEntity() != null) { if (response.getEntity().toString().equals("0")) { jsonObject=null; Log.v("msg",""+"没有收到信息"); } else { BufferedReader reader = new BufferedReader(new InputStreamReader(response.getEntity().getContent())); String s = reader.readLine(); for (; s != null; s = reader.readLine()) { builder.append(s); } Log.v("msg",""+"成功获取信息"); jsonObject = new JSONObject(builder.toString()); } } } catch (Exception E) { Log.e("msg", E.getMessage()); Log.v("msg", "没有成功 "); } finally { try { if (entity != null) { // entity.consumeContent();//强制释放资源 httpclient.getConnectionManager().shutdown();//关闭连接 //这两种释放连接的方法都可以 } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } return jsonObject; } //获取值之后开始对原来的textview进行赋值 protected void onPostExecute(JSONObject webcontent){ String cn,cs,ca,cc,cp,cd,sr,srd,srn,sry,st,stn,sty,sts,pic1,pic2; if(webcontent==null){ Toast.makeText(getActivity(),"没有对应的客户信息",Toast.LENGTH_LONG).show(); }else { try { cn=webcontent.getString("CustomerName"); CustomerName.setText(cn); cs=webcontent.getString("CustomerSegment"); CustomerSegment.setText(cs); ca=webcontent.getString("CustomerAddress"); CustomerAddress.setText(ca); cc=webcontent.getString("CustomerContactor"); CustomerContactor.setText(cc); cp=webcontent.getString("CustomerPhone"); CustomerPhone.setText(cp); cd=webcontent.getString("Customercontactdate"); Customercontactdate.setText(cd); sr=webcontent.getString("ServiceRepresentive"); ServiceRepresentive.setText(sr); srd=webcontent.getString("SRP"); SRP.setText(srd); srn=webcontent.getString("SRN"); SRN.setText(srn); sry=webcontent.getString("SRY"); SRY.setText(sry); st=webcontent.getString("ServiceTechnician"); ServiceTechnician.setText(st); stn=webcontent.getString("STN"); STN.setText(stn); sty=webcontent.getString("STY"); STY.setText(sty); sts=webcontent.getString("STS"); STS.setText(sts); pic1=webcontent.getString("SRPIC"); pic2=webcontent.getString("STPIC"); String[] pics=new String[]{pic1,pic2}; Loadpics loadpics=new Loadpics(); loadpics.execute(pics); }catch (Exception E){ E.printStackTrace(); } } } } //这里是用来获取图片的 class Loadpics extends AsyncTask<String, Integer, Bitmap[]>{ protected Bitmap[] doInBackground(String... inf) { Bitmap[] bitmaps=new Bitmap[2]; Bitmap bitmap1,bitmap2; try{ URL url1=new URL(inf[0]); URLConnection conn1=url1.openConnection(); conn1.connect(); InputStream inputStream = conn1.getInputStream(); bitmap1 = BitmapFactory.decodeStream(inputStream); URL url2=new URL(inf[1]); URLConnection conn2=url2.openConnection(); conn2.connect(); InputStream inputStream2 = conn2.getInputStream(); bitmap2 = BitmapFactory.decodeStream(inputStream2); bitmaps[0]=bitmap1; bitmaps[1]=bitmap2; }catch (Exception E){ Log.e("msg", E.getMessage()); }return bitmaps; } protected void onPostExecute(Bitmap[] bitmap){ try{ SRPIC.setImageBitmap(bitmap[0]); STPIC.setImageBitmap(bitmap[1]); }catch (Exception E){ Log.e("msg", E.getMessage()); } } }} ```
使用 AutoComplete TextView 从 Contacts 中获取 Email
在程序中有一个`AutoComplete TextView` 和 `EditText`。在`AutoComplete TextView`中提供了`Contacts`中所有的`contact names` 。 我想获取联系人的主要电子邮件的`id`,这个联系人是在 `AutoComplete Textview` 中选择的,放到 `editText` 中。如何实现这个功能?
关于android获取手机联系人信息的问题,求大神帮帮忙?谢谢。
下面是我写的代码,最后真机运行布局上只出现了一条数据。 1、实体类 public class ContactsBean { private int contactId; private int icon; private String contactsName; private String company; private String phoneNumber; private String remark; private String job; private String email; public String getJob() { return job; } public void setJob(String job) { this.job = job; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public int getContactId() { return contactId; } public void setContactId(int contactId) { this.contactId = contactId; } public int getIcon() { return icon; } public void setIcon(int icon) { this.icon = icon; } public String getContactsName() { return contactsName; } public void setContactsName(String contactsName) { this.contactsName = contactsName; } public String getCompany() { return company; } public void setCompany(String company) { this.company = company; } public String getPhoneNumber() { return phoneNumber; } public void setPhoneNumber(String phoneNumber) { this.phoneNumber = phoneNumber; } public String getRemark() { return remark; } public void setRemark(String remark) { this.remark = remark; } 2 2、主代码 package com.kag.activity; import android.content.ContentResolver; import android.database.Cursor; import android.net.Uri; import android.provider.ContactsContract; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.widget.ListView; import com.addresslist.R; import java.security.Provider; import java.util.ArrayList; import java.util.List; import FragmentAdapter.AddContactFromAddressAdapter; import bean.ContactsBean; public class AddContactFromAddressList extends AppCompatActivity { ContactsBean contactsBean; private ListView lv; ArrayList contacts; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_add_contact_from_address_list); lv=findViewById(R.id.lv_contacts_list); contactsBean=new ContactsBean(); contacts=new ArrayList(); reaContacts(contacts); AddContactFromAddressAdapter adapter=new AddContactFromAddressAdapter(this,contacts); lv.setAdapter(adapter); } //从手机通讯录中读取数据 public void reaContacts(ArrayList contacts){ Uri uri=Uri.parse("content://com.android.contacts/contacts"); ContentResolver resolver=this.getContentResolver(); Cursor cursor=resolver.query(uri,null,null,null,ContactsContract.Contacts.SORT_KEY_PRIMARY); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex(ContactsContract.Contacts._ID)); String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME)); String sort_key = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.SORT_KEY_PRIMARY)); contactsBean.setContactsName(name); contactsBean.setContactId(id); Cursor phone = resolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, ContactsContract.CommonDataKinds.Phone.CONTACT_ID+"="+id, null, null); ArrayList phoneNumber=new ArrayList(); while (phone.moveToNext()) { String number = phone.getString(phone.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER)); phoneNumber.add(number); System.out.println(name+":"+number); } contactsBean.setPhoneNumber(String.valueOf(phoneNumber)); contacts.add(contactsBean); System.out.println(contactsBean.getContactsName()+":"+contactsBean.getPhoneNumber()); } } } 3、适配器 public class AddContactFromAddressAdapter extends BaseAdapter { private List<ContactsBean> contacts; LayoutInflater inflater; public AddContactFromAddressAdapter(Context context,List<ContactsBean> contacts){ this.contacts=contacts; inflater=LayoutInflater.from(context); } @Override public int getCount() { return contacts.size(); } @Override public Object getItem(int position) { return contacts.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder=null; if (convertView==null){ convertView=inflater.inflate(R.layout.contacts_cell,null); holder=new ViewHolder(); holder.sort_key=convertView.findViewById(R.id.tv_sort_key); holder.mPhones=convertView.findViewById(R.id.tv_phones); convertView.setTag(holder); }else { holder= (ViewHolder) convertView.getTag(); } holder.sort_key.setText(contacts.get(position).getContactsName()); holder.mPhones.setText(contacts.get(position).getPhoneNumber()); return convertView; } private final class ViewHolder{ public TextView sort_key; public TextView mPhones; } } 4运行结果 ![图片说明](https://img-ask.csdn.net/upload/201801/11/1515667064_810395.jpg)
Android的ListView如何实现长点击后出现隐藏的按钮按钮
我现在有个小程序,功能实现为打电话。现在已经获取了联系人列表,联系人列表放在ListView中,使用了BaseAdapter。我现在想实现这样的一个功能,长按ListView里一个联系人Item,然后此Item右边出现拨打电话的按钮,如果按钮出现几秒后用户还不点击,按钮则隐藏。目前我BaseAdapter里getView方法是这样写的 ``` @Override public View getView(int position, View convertView, ViewGroup parent) { LinearLayout ll=null; if (convertView!=null) { ll=(LinearLayout)convertView; }else{ ll=(LinearLayout) LayoutInflater.from(context).inflate(R.layout.call_name_num, null); } TextView userName=(TextView) ll.findViewById(R.id.textName); TextView userNumber=(TextView) ll.findViewById(R.id.textNumber); Button callBtn =(Button)ll.findViewById(R.id.btnCall); callBtn.setVisibility(1); callBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { System.out.println(">>>>>CallBtn Click"); } }); userName.setText(phoneUserList.get(position).getName()); userNumber.setText(phoneUserList.get(position).getNumber()); return ll; } ``` 现在就没思路了,而且我这样写有个问题,添加一个可点击的按钮后,ListView里的联系人就无法点击了,长摁联系人Item也没有反应,这是怎么回事?求大神
Android ListView重复加载的问题
我建立一个 ListViewView,并重写了自己的 adapter(继承BaseAdapter),数据源是一个ArrayList. ,ArrayList里的数据是 1,2,3。当我初始化 ListView时,显示的是 1,2,3。 以上看起来非常正常,但当我按 后退键,然后重新 进入 ListView的时候,诡异的事情就发生了。。 当我第二次进入 ListView的时候,屏幕上显示的 数据 成了 1,2,3, 1,2,3 . 然后我按下 后退键,再进入 ListView, 屏幕上的 数据 成了 1,2,3, 1,2,3 ,1,2,3 如此循环往复。。总之,每次进入ListView,都得重新读取ArrayList的数据。请问是什么原因导致的呢? 以下是adapter源码 public class chatListAdapter extends BaseAdapter{ private Context context; //运行上下文 private List<Map<String, Object>> listItems; //联系人信息集合 private LayoutInflater listContainer; //视图容器 private boolean[] hasChecked; //记录联系人选中状态 public final class ListItemView{ //自定义控件集合 public TextView RemoteAudio; public TextView LocalAudio; public TextView RemoteId; public TextView LocalId; public TextView MessageType; public ImageView RemoteImage; public ImageView LocalImage; public TextView RemoteSay; public TextView LocalSay; } public chatListAdapter(Context context, List<Map<String, Object>> listItems) { Log.v("construtor", "constructor11"); this.context = context; listContainer = LayoutInflater.from(context); //创建视图容器并设置上下文 this.listItems = listItems; hasChecked = new boolean[getCount()]; } @Override public int getCount() { // TODO Auto-generated method stub return listItems.size(); } @Override public Object getItem(int arg0) { // TODO Auto-generated method stub return null; } @Override public long getItemId(int arg0) { // TODO Auto-generated method stub return 0; } @Override public View getView(int position, View convertView, ViewGroup viewGroup) { // TODO Auto-generated method stub Log.v("getview","getview11"); final int selectID = position; ListItemView listItemView = null; listItemView = new ListItemView(); if (convertView == null) { //获取list_item布局文件的视图 convertView = listContainer.inflate(R.layout.chat_list_item, null); //获取控件对象 listItemView.RemoteAudio = (TextView)convertView.findViewById(R.id.RemoteAudio); listItemView.LocalAudio = (TextView)convertView.findViewById(R.id.LocalAudio); listItemView.RemoteId = (TextView)convertView.findViewById(R.id.RemoteId); listItemView.LocalId = (TextView)convertView.findViewById(R.id.LocalId); listItemView.MessageType= (TextView)convertView.findViewById(R.id.MessageType); listItemView.RemoteImage = (ImageView)convertView.findViewById(R.id.RemoteImage); listItemView.LocalImage=(ImageView)convertView.findViewById(R.id.RemoteImage); listItemView.RemoteSay=(TextView)convertView.findViewById(R.id.RemoteSay); listItemView.LocalSay=(TextView)convertView.findViewById(R.id.LocalSay); //设置控件集到convertView convertView.setTag(listItemView); }else{listItemView=(ListItemView)convertView.getTag();} //set rma,lca,mst,rid,lid into invisible //put data from list into view String strPosition=""+position; int RR=0; RR++; Log.v("11aa21","RR"+RR); listItemView.RemoteId.setText((String)listItems.get(position).get("RemoteId")); // String idd=Regist.generateId(); // listItemView.RemoteId.setText(" "+idd+" "); Log.v("11aa21","PositionI"+strPosition); Log.v("RemoteID","Remote+"+(String)listItems.get(position).get("RemoteId")); listItemView.LocalId.setText((String) listItems.get(position).get("LocalId")); Log.v("11aa21","PositionI"+strPosition); Log.v("RemoteID","LocalID+"+(String)listItems.get(position).get("LocalId")); //// listItemView.RemoteAudio.setText((String)listItems.get(position).get("RemoteAudio")); listItemView.LocalAudio.setText((String)listItems.get(position).get("LocalAudio")); //// listItemView.MessageType.setText((String)listItems.get(position).get("MessageType")); /// listItemView.RemoteImage.setBackgroundResource(R.drawable.ic_launcher); listItemView.LocalImage.setBackgroundResource(R.drawable.ic_launcher); /// listItemView.RemoteSay.setText((String)listItems.get(position).get("RemoteSay")); listItemView.LocalSay.setText((String)listItems.get(position).get("LocalSay")); // String idd=Regist.generateId(); // listItemView.LocalSay.setText(idd); // listItemView.RemoteSay.setText("rms"+position); Log.i("tttt","ttttt"+listItemView.LocalSay.getText().toString()); //decide wether Ls,LI,RS,RI invisible //if msgtype=??,then set..invisible,set XX onclick method=?? String MsgType=listItemView.MessageType.getText().toString(); Log.i("msgt",MsgType); if (MsgType.equals("9d")){ Log.v("MsgType", "Text"); listItemView.LocalSay.setVisibility(View.INVISIBLE); listItemView.LocalImage.setVisibility(View.INVISIBLE); listItemView.RemoteSay.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.v("1ab",((TextView) v).getText().toString()); Toast.makeText(null, "111",Toast.LENGTH_LONG).show(); } }); } return convertView; } }
通过resolver删除指定的联系人
resolver查询或者删除通讯录指定姓名联系人时候,为什么姓名必须要设置成常量的 形式,变量就不行呢?我的代码中如果name="shanshan"常量的形式,就能够删除 成功,name如果是从textview中输入的姓名的值获取而来的删除就不成功呢? 代码如下: name = tv_name.getText().toString(); // 设置你的操作事项 //删除通讯录中的联系人 //delete(i,name); ContentResolver resolver = getContentResolver(); Uri uri = Uri.parse("content://com.android.contacts/contacts"); Cursor cursor = resolver.query(uri,new String[]{"display_name"},ContactsContract.Data.DISPLAY_NAME+"= ?",new String[]{name},null); //Cursor cursor=resolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME+"="+name, null, null); int b = cursor.getCount(); System.out.println(b); if (cursor.moveToFirst()) { int id = cursor.getInt(0); // 根据id删除data中的相应数据 resolver.delete(RawContacts.CONTENT_URI, "display_name=?",new String[]{name}); uri = Uri.parse("content://com.android.contacts/data"); resolver.delete(Contacts.CONTENT_URI, "display_name=?",new String[] {name }); } 这样子不会成功,name换成通讯录里面有的联系人的名字,即可删除成功,为什么?
expandablelistview和checkbox结合使用,复用问题,头疼好几天,大神帮帮忙啊
了viewholder复用了,当子项滑出范围,选中的checkbox变为未选中,不过选中的删除时删除是正确的,只是这样重复选择(不知道怎么说),体验不好,头疼好几天了 expandablelistviewadapter代码如下: 关键代码: ``` /* * 解决复用问题的关键代码,那里好像出错了。导致自动让滑出屏幕的checkbox不选,这里 */ if (checkposition!=null) { itemHolder.cb.setChecked(checkposition.contains(itemHolder.cb.getText().toString())?true:false); } else{ itemHolder.cb.setChecked(false); } itemHolder.cb.setOnCheckedChangeListener(new OnCheckedChangeListener() { String i = itemHolder.cb.getText().toString(); @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (isChecked) { if (!checkposition.contains(i)) { idlists.add(i); checkposition.add(i); } Fragment1.tv.setText("您已选中"+idlists.size()+"个联系人"); } else{ if (checkposition.contains(i)) { idlists.remove(i); checkposition.remove(i); } Fragment1.tv.setText("您已选中"+idlists.size()+"个联系人"); } } }); ``` 适配器完整代码: ``` package com.daisy.work.adapter; import java.util.ArrayList; import java.util.List; import android.content.Context; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.net.Uri; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseExpandableListAdapter; import android.widget.CheckBox; import android.widget.CompoundButton; import android.widget.CompoundButton.OnCheckedChangeListener; import android.widget.ImageButton; import android.widget.ImageView; import android.widget.TextView; import com.daisy.work.R; import com.daisy.work.atys.fragments.Fragment1; import com.daisy.work.db.ContactDB; public class MyExpandableListViewAdapter extends BaseExpandableListAdapter { private Context context; private Cursor cursor; private ArrayList<String> group_list; private ArrayList<List<Integer>> gr_list2; private ContactDB ctDB; private SQLiteDatabase dbRead; private ItemHolder itemHolder; public ArrayList<String> idlists; public List<String> checkposition; public MyExpandableListViewAdapter(Context context, Cursor cursor) { this.context = context; this.cursor = cursor;//cursor用来获取填充childview的数据 ctDB = new ContactDB(context); dbRead = ctDB.getReadableDatabase(); idlists = new ArrayList<String>();//用来记录checkboxbox的值,和数据库的name一列的值相同,便于删除 checkposition = new ArrayList<String>();//用来解决复用滑动错乱问题 group_list = new ArrayList<String>();//填充组 group_list.add("默认"); group_list.add("亲人"); group_list.add("同事"); group_list.add("同学"); group_list.add("客户"); List<Integer> gr_list = new ArrayList<Integer>(); gr_list.add(R.drawable.tree_ec); gr_list.add(R.drawable.tree_ec); gr_list.add(R.drawable.tree_ec); gr_list.add(R.drawable.tree_ec); gr_list.add(R.drawable.tree_ec); gr_list2 = new ArrayList<List<Integer>>();//{{1,2,3,4,5},{1,2,3,4,5}...} gr_list2.add(gr_list); gr_list2.add(gr_list); gr_list2.add(gr_list); gr_list2.add(gr_list); gr_list2.add(gr_list); } @Override public int getGroupCount() { return group_list.size(); } @Override public int getChildrenCount(int groupPosition) { String belong = group_list.get(groupPosition);//将特定的数据填充到分组中,用belong标识。 Cursor c = dbRead.query(ContactDB.CONTACT_TABLE_NAME, null, "belong like ?", new String[] { "%" + belong + "%" }, null, null, null); if (!c.moveToFirst()) { return 0; } else { return c.getCount(); } } @Override public Object getGroup(int groupPosition) { return group_list.get(groupPosition); } //多考虑一下 @Override public Object getChild(int groupPosition, int childPosition) { return getCombinedChildId(getGroupId(groupPosition),childPosition);//这个没搞太明白,填什么都不会出错 } @Override public long getGroupId(int groupPosition) { return groupPosition; } @Override public long getChildId(int groupPosition, int childPosition) { return childPosition; } @Override public boolean hasStableIds() { return true; } @Override public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) { GroupHolder groupHolder = null; if (convertView == null) { convertView = LayoutInflater.from(context).inflate( R.layout.expendlist_group, null); groupHolder = new GroupHolder(); groupHolder.txt = (TextView) convertView.findViewById(R.id.txt); groupHolder.txt2 = (TextView) convertView.findViewById(R.id.txt2); groupHolder.img = (ImageView) convertView.findViewById(R.id.img); convertView.setTag(groupHolder); } else { groupHolder = (GroupHolder) convertView.getTag(); } if (!isExpanded) { groupHolder.img.setBackgroundResource(R.drawable.tree_ec); } else { groupHolder.img.setBackgroundResource(R.drawable.tree_ex); } String belong = group_list.get(groupPosition); cursor = dbRead.query(ContactDB.CONTACT_TABLE_NAME, null, "belong like ?", new String[] { "%" + belong + "%" }, null, null, null); int nm = cursor.getCount();//获取特定组中子项的数目。 groupHolder.txt.setText(group_list.get(groupPosition)); groupHolder.txt2.setText(nm + "");//显示组中子项的数目。 return convertView; } @Override public View getChildView(final int groupPosition,final int childPosition, boolean isLastChild, View convertView, ViewGroup parent) { itemHolder = null; if (convertView == null) { convertView = LayoutInflater.from(context).inflate( R.layout.expendlist_item,null); itemHolder = new ItemHolder(); itemHolder.ct_name = (TextView) convertView .findViewById(R.id.ct_name); itemHolder.ct_qq = (TextView) convertView.findViewById(R.id.ct_qq); itemHolder.iv = (ImageView) convertView.findViewById(R.id.iv); itemHolder.dial = (ImageButton) convertView.findViewById(R.id.dial); itemHolder.cb = (CheckBox) convertView.findViewById(R.id.cb); itemHolder.cb.setTag(itemHolder.cb.getText().toString());//child_item布局里的checkbox控件 convertView.setTag(itemHolder); } else { itemHolder = (ItemHolder) convertView.getTag(); } String belong = group_list.get(groupPosition); cursor = dbRead.query(ContactDB.CONTACT_TABLE_NAME, null, "belong like ?", new String[] { "%" + belong + "%" }, null, null, null); if (!cursor.moveToFirst()) { return null; } else { cursor.moveToPosition(childPosition); if (Fragment1.xs_bs.isShown()) {//按多选时将checkbox展现出啦,取消则隐藏xs_bs在adapter中无法获取,把它设为了public static itemHolder.cb.setChecked(false); itemHolder.cb.setVisibility(CheckBox.GONE); } else { itemHolder.cb.setVisibility(CheckBox.VISIBLE); itemHolder.dial.setOnClickListener(null); } if(Fragment1.qx.isPressed()){ //取消则隐藏 itemHolder.cb.setChecked(false); } //显示子项中的数据 itemHolder.ct_name.setText(cursor.getString(cursor .getColumnIndex("name"))); itemHolder.cb.setText(cursor.getString(cursor .getColumnIndex("name"))); itemHolder.ct_qq.setText(cursor.getString(cursor .getColumnIndex("qq"))); itemHolder.iv.setBackgroundResource(R.drawable.ic_ct); //按钮,由于其特殊性(在expandablelistview子项中的控件,在adapter中设置监听) itemHolder.dial.setOnClickListener(new View.OnClickListener() { String phone = cursor.getString(cursor.getColumnIndex("phone")); @Override public void onClick(View v) { context.startActivity(new Intent(Intent.ACTION_DIAL, Uri .parse("tel:" +phone))); } }); /* * 解决复用问题的关键代码,那里好像出错了。导致自动让滑出屏幕的checkbox不选,这里 */ if (checkposition!=null) { itemHolder.cb.setChecked(checkposition.contains(itemHolder.cb.getText().toString())?true:false); } else{ itemHolder.cb.setChecked(false); } itemHolder.cb.setOnCheckedChangeListener(new OnCheckedChangeListener() { String i = itemHolder.cb.getText().toString(); @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (isChecked) { if (!checkposition.contains(i)) { idlists.add(i); checkposition.add(i); } Fragment1.tv.setText("您已选中"+idlists.size()+"个联系人"); } else{ if (checkposition.contains(i)) { idlists.remove(i); checkposition.remove(i); } Fragment1.tv.setText("您已选中"+idlists.size()+"个联系人"); } } }); return convertView; } } @Override public boolean isChildSelectable(int groupPosition, int childPosition) { return true; } class GroupHolder { public TextView txt; public TextView txt2; public ImageView img; } class ItemHolder { public ImageView iv; public TextView ct_name; public TextView ct_qq; public ImageButton dial; public CheckBox cb; } } ``` ![图片说明](https://img-ask.csdn.net/upload/201605/16/1463356167_782724.png)
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
小白学 Python 爬虫(25):爬取股票信息
人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Linux基础入门 小白学 Python 爬虫(4):前置准备(三)Docker基础入门 小白学 Python 爬虫(5):前置准备(四)数据库基础 小白学 Python 爬虫(6):前置准备(...
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
世界上最牛的网络设备,价格低廉,其貌不扬......
夜深人静,电视和电脑都已经关机休息,但是我还在默默工作,我安静地趴在你家中的某个地方,7*24小时不眠不休,任劳任怨,目的只有一个,能让你舒服地躺在床上,畅快地刷手机!没错,这就是我,...
《面试宝典》2019年springmvc面试高频题(java)
前言 2019即将过去,伴随我们即将迎来的又是新的一年,过完春节,马上又要迎来新的金三银四面试季。那么,作为程序猿的你,是否真的有所准备的呢,亦或是安于本职工作,继续做好手头上的事情。 当然,不论选择如何,假如你真的准备在之后的金三银四跳槽的话,那么作为一个Java工程师,就不可不看了。如何在几个月的时间里,快速的为即将到来的面试进行充分的准备呢? 1、什么是Spring MVC ?简单...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
python爬取百部电影数据,我分析出了一个残酷的真相
2019年就这么匆匆过去了,就在前几天国家电影局发布了2019年中国电影市场数据,数据显示去年总票房为642.66亿元,同比增长5.4%;国产电影总票房411.75亿元,同比增长8.65%,市场占比 64.07%;城市院线观影人次17.27亿,同比增长0.64%。 看上去似乎是一片大好对不对?不过作为一名严谨求实的数据分析师,我从官方数据中看出了一点端倪:国产票房增幅都已经高达8.65%了,为什...
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试一个ArrayList我都能跟面试官扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
2020年1月中国编程语言排行榜,python是2019增长最快编程语言
编程语言比例 排名 编程语言 最低工资 工资中位数 最低工资 最高工资 人头 人头百分比 1 rust 20713 17500 5042 46250 480 0.14% 2 typescript 18503 22500 6000 30000 1821 0.52% 3 lua 18150 17500 5250 35000 2956 0.84% 4 go 17989 16...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
工作十年的数据分析师被炒,没有方向,你根本躲不过中年危机
2020年刚刚开始,就意味着离职潮高峰的到来,我身边就有不少人拿着年终奖离职了,而最让我感到意外的,是一位工作十年的数据分析师也离职了,不同于别人的主动辞职,他是被公司炒掉的。 很多人都说数据分析是个好饭碗,工作不累薪资高、入门简单又好学。然而今年34的他,却真正尝到了中年危机的滋味,平时也有不少人都会私信问我: 数据分析师也有中年危机吗?跟程序员一样是吃青春饭的吗?该怎么保证自己不被公司淘汰...
作为一名大学生,如何在B站上快乐的学习?
B站是个宝,谁用谁知道???? 作为一名大学生,你必须掌握的一项能力就是自学能力,很多看起来很牛X的人,你可以了解下,人家私底下一定是花大量的时间自学的,你可能会说,我也想学习啊,可是嘞,该学习啥嘞,不怕告诉你,互联网时代,最不缺的就是学习资源,最宝贵的是啥? 你可能会说是时间,不,不是时间,而是你的注意力,懂了吧! 那么,你说学习资源多,我咋不知道,那今天我就告诉你一个你必须知道的学习的地方,人称...
那些年,我们信了课本里的那些鬼话
教材永远都是有错误的,从小学到大学,我们不断的学习了很多错误知识。 斑羚飞渡 在我们学习的很多小学课文里,有很多是错误文章,或者说是假课文。像《斑羚飞渡》: 随着镰刀头羊的那声吼叫,整个斑羚群迅速分成两拨,老年斑羚为一拨,年轻斑羚为一拨。 就在这时,我看见,从那拨老斑羚里走出一只公斑羚来。公斑羚朝那拨年轻斑羚示意性地咩了一声,一只半大的斑羚应声走了出来。一老一少走到伤心崖,后退了几步,突...
一文带你看清 HTTP 所有概念
上一篇文章我们大致讲解了一下 HTTP 的基本特征和使用,大家反响很不错,那么本篇文章我们就来深究一下 HTTP 的特性。我们接着上篇文章没有说完的 HTTP 标头继续来介绍(此篇文章会介绍所有标头的概念,但没有深入底层) HTTP 标头 先来回顾一下 HTTP1.1 标头都有哪几种 HTTP 1.1 的标头主要分为四种,通用标头、实体标头、请求标头、响应标头,现在我们来对这几种标头进行介绍 通用...
一个程序在计算机中是如何运行的?超级干货!!!
强烈声明:本文很干,请自备茶水!???? 开门见山,咱不说废话! 你有没有想过,你写的程序,是如何在计算机中运行的吗?比如我们搞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...
Python全栈 Linux基础之3.Linux常用命令
Linux对文件(包括目录)有很多常用命令,可以加快开发效率:ls是列出当前目录下的文件列表,选项有-a、-l、-h,还可以使用通配符;c功能是跳转目录,可以使用相对路径和绝对路径;mkdir命令创建一个新的目录,有-p选项,rm删除文件或目录,有-f、-r选项;cp用于复制文件,有-i、-r选项,tree命令可以将目录结构显示出来(树状显示),有-d选项,mv用来移动文件/目录,有-i选项;cat查看文件内容,more分屏显示文件内容,grep搜索内容;>、>>将执行结果重定向到一个文件;|用于管道输出。
​两年前不知如何编写代码的我,现在是一名人工智能工程师
全文共3526字,预计学习时长11分钟 图源:Unsplash 经常有小伙伴私信给小芯,我没有编程基础,不会写代码,如何进入AI行业呢?还能赶上AI浪潮吗? 任何时候努力都不算晚。 下面,小芯就给大家讲一个朋友的真实故事,希望能给那些处于迷茫与徘徊中的小伙伴们一丝启发。(下文以第一人称叙述) 图源:Unsplash 正如Elsa所说,职业转换是...
强烈推荐10本程序员必读的书
很遗憾,这个春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终将会...
作为一个程序员,内存的这些硬核知识你必须懂!
我们之前讲过CPU,也说了CPU和内存的那点事儿,今天咱就再来说说有关内存,作为一个程序员,你必须要懂的哪那些硬核知识! 大白话聊一聊,很重要! 先来大白话的跟大家聊一聊,我们这里说的内存啊,其实就是说的我们电脑里面的内存条,所以嘞,内存就是内存条,数据要放在这上面才能被cpu读取从而做运算,还有硬盘,就是电脑中的C盘啥的,一个程序需要运行的话需要向内存申请一块独立的内存空间,这个程序本身是存放在...
非典逼出了淘宝和京东,新冠病毒能够逼出什么?
loonggg读完需要5分钟速读仅需 2 分钟大家好,我是你们的校长。我知道大家在家里都憋坏了,大家可能相对于封闭在家里“坐月子”,更希望能够早日上班。今天我带着大家换个思路来聊一个问题...
立即提问