RecyclerView adapter.addAll的空指针问题

这次用了别人封装的RecyclerView,自己又将其封装了一下
public void addDataThenNotify(List list){
LogUtil.i("dat", "..." +adapter);
adapter.addAll(list);
adapter.notifyDataSetChanged();
}
这是其中的一段代码,负责向adapter里添加list
但android studio在“adapter.addAll()”这里报空指针,同时我确定adapter、list绝非为空,
而它的size(),也为等同传进去的size(),adapter

1个回答

你都说了你的adapter和list都不为空,那怎么还出空指针。

还是好好检查一下吧,最好可以在这个方法里面打印输出一下list,也可以显示一下adapter.

另外可以看下你adapter初始化的地方,。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
一个类.list.addAll(另一个类.list)与一个类.list=另一类.list 的区别
LinkedList<Zhang> xinList=new LinkedList<Zhang>(); for (int i=cong;i<list.size();i++) { xinList.add( list.get(i)); } list.removeAll(xinList); Lin lin = new Lin(); // lin.list.addAll(xinList); lin.list =xinList; return lin; 就是注释掉的和下一句的区别 怎么用注释的就不好用呢?
recyclerView holder不断创建
RecyclerView list列表清空后用list.addAll()设置新的数据调用adapter.notifyDataSetChanged()为什么会走onCreateViewHolder()创建新holder方法有什么办法在刷新list不创建Holder
ListView更新数据问题
我们可以通过 list.addAll(l); adapter.notifyDataSetChanged(); 更新数据 为什么 list=l(一个带有新数据的List) adapter_gv.notifyDataSetChanged(); 这样不行啊
集合中关于addAll的一些问题
集合a,b, a.addAll(b),a中添加的是b中元素的地址还是具体的元素,我理解是存的地址,那为什么修改a或b中的元素,不会影响另一个
关于在viewpage中的fragment中刷新listview的问题
比如说listview是订单列表,每个item上都有修改价格和取消订单的按钮,点击修改价格的按钮会跳到修改价格的界面,修改后然后返回刷新listview对应的item上的价格, ``` datasList.clear(); datasList.addAll(list); adapter.setData(datasList); adapter.notifyDataSetChanged(); ``` 这样界面的价格会刷新,可是我用同样的方法取消订单,跳到取消订单页,填写取消原因后在返回,被取消的item还在,求各位大神指点一下。 返回来之后数据都是拉的接口。
2个List 数组,如何不用List.addAll().sort(),进行合并排序
如 ArrayList a = [1,5,7,9,10]; ArrayList b = [6,7,8,9,11]; 合并为 ArrayList c = [1,5,6,7,7,8,9,9,10,11];
使用recyclerView更新数据时程序崩溃
我在编写“添加好友”模块时,根据用户输入的用户名,从服务器获取到了相应信息,但将该数据载入recyclerView更新时程序却崩溃了。接下来是我的代码,以及错误日志。求助大家,小白一只,挣扎了一星期也没找到问题所在。 此为主活动部分:思路是获取输入框的用户名,进入Bmob数据库查询。我调试的时候看到用户是成功查询到的。 public class FriendAdd extends AppCompatActivity { private Button searchUser; private EditText newFriendName; private List<Friend> newFriendList=new ArrayList<>(); private RecyclerView recyclerView; private StrangerAdapter adapter; private LinearLayoutManager layoutManager; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_add_friend); searchUser = (Button) findViewById(R.id.addFriend_button_fingNewFriend); newFriendName = (EditText) findViewById(R.id.addFriend_editText_inputFriendName); recyclerView=(RecyclerView)findViewById(R.id.addFriend_recyclerView); adapter =new StrangerAdapter(); layoutManager = new LinearLayoutManager(this); recyclerView.setLayoutManager(layoutManager); recyclerView.setAdapter(adapter); searchUser.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { String strangerName=newFriendName.getText().toString(); if(strangerName.isEmpty()){ createDialog("用户名为空","请输入您所查找用户的用户名"); }else{ BmobQuery<User> query = new BmobQuery<User>(); query.addWhereEqualTo("trueName", strangerName); query.findObjects(new FindListener<User>() { @Override public void done(List<User> object, BmobException e) { if(e==null){ for (User gameScore : object) { //获得信息 Friend newFriend=new Friend(gameScore.gettureName(),gameScore.getdepartment()); newFriendList.add(newFriend); } adapter.setDatas(newFriendList); adapter.notifyDataSetChanged(); }else{ createDialog("查询用户失败",e.getMessage()+e.getErrorCode()); } } }); } } }); } private void createDialog(String title, String msg) { AlertDialog.Builder b=new AlertDialog.Builder(this); b.setMessage(msg); b.setTitle(title); b.setNegativeButton("重试", new DialogInterface.OnClickListener(){ public void onClick(DialogInterface dialog,int which){ dialog.dismiss(); } }); b.create().show(); } } 以下为recyclerView的数据适配器代码: public class StrangerAdapter extends RecyclerView.Adapter<StrangerAdapter.ViewHolder> { private List<Friend> stranger=new ArrayList<>(); static class ViewHolder extends RecyclerView.ViewHolder{ ImageView friendImage; TextView friendName; TextView friendDepartment; public ViewHolder(View view){ super(view); friendImage=(ImageView)view.findViewById(R.id.friendSearch_image_head); friendName=(TextView)view.findViewById(R.id.friendSearch_textView_userName); friendDepartment=(TextView)view.findViewById(R.id.friendSearch_textView_department); } } public StrangerAdapter() { }; public StrangerAdapter(List<Friend> friendList){ stranger=friendList; } public ViewHolder onCreateViewHolder(ViewGroup parent,int viewType){ View view=LayoutInflater.from(parent.getContext()).inflate(R.layout.friend_list_item,parent,false); ViewHolder holder=new ViewHolder(view); return holder; } public void onBindViewHolder(ViewHolder holder,int position){ Friend friend=stranger.get(position); holder.friendImage.setImageResource(friend.getImageId()); holder.friendName.setText(friend.getName()); holder.friendDepartment.setText(friend.getLocation()); } public int getItemCount(){ return stranger.size(); } public void setDatas(List<Friend> list) { stranger.clear(); if (null != list) { stranger.addAll(list); } } } 以下是崩溃后输出的错误日志 04-23 15:28:24.143 16212-16212/com.example.schoolpet E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.schoolpet, PID: 16212 java.lang.ExceptionInInitializerError at java.lang.Class.newInstance(Native Method) at android.app.Instrumentation.newActivity(Instrumentation.java:1070) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2349) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2511) at android.app.ActivityThread.access$900(ActivityThread.java:165) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1375) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:150) at android.app.ActivityThread.main(ActivityThread.java:5621) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:794) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:684) Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.Context cn.bmob.v3.BmobWrapper.getApplicationContext()' on a null object reference at cn.bmob.v3.Bmob.Code(Bmob.java:117) at cn.bmob.v3.Bmob.getApplicationContext(Bmob.java:129) at cn.bmob.v3.b.The.<init>(SPUtil.java:28) at cn.bmob.v3.BmobUser.getCurrentUser(BmobUser.java:871) at com.example.schoolpet.PetPage.<clinit>(PetPage.java:59) at java.lang.Class.newInstance(Native Method)  at android.app.Instrumentation.newActivity(Instrumentation.java:1070)  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2349)  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2511)  at android.app.ActivityThread.access$900(ActivityThread.java:165)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1375)  at android.os.Handler.dispatchMessage(Handler.java:102)  at android.os.Looper.loop(Looper.java:150)  at android.app.ActivityThread.main(ActivityThread.java:5621)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:794)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:684) 
Android List一个简单问题
Android里面的Adapter 更新数据 oldList.clear(); oldList.addAll(newList); 与oldList = newList有什么区别吗? 2种方法 更新出来数据不一样
json字符串如何不报空的问题
从网络解析一个json路径,内容为空,如何保证页面正常显示,只是没有内容而已,让它不崩掉,我在回调方法中进行了空值判断如下,如果地址有数据程序不会蹦,没数据就崩掉,谢谢了 ``` //这是异步任务 @Override protected String doInBackground(String... params) { String json = HttpUtils.getJsonFromNet(params[0]); return json; } @Override protected void onPostExecute(String s) { super.onPostExecute(s); if(s!=null) { listJsonCall.callBack(s); ``` //这是回调方法 @Override public void callBack(String s) { if(s!=null){ loadMore = LoadMoreJsonParse.getLoadMore(s); totalLis.addAll(loadMore); adapter.notifyDataSetChanged(); } ``` ```
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)
在runOnUiThread里面更新adapter有BUG
SpreadService.getAdMsgList(id, pageNumber + "", new ChatCallBack() { @Override public void onSuccess(AppResult result) { List<DynamicdetailBean> list = JSONArray.parseArray(result .getData().toString(), DynamicdetailBean.class); if (list != null && list.size() > 0) { if (isFirstLoading) { datalist.clear(); datalist.addAll(list); } else { datalist.addAll(list); } } //以上是oncreate()方法里面调用的方法,datalist也是在oncreate中初始化的集合,在service里面新建的一个工作线程执行http访问,成功后回调处理数据方法,具体太多,不列出,返回数据都正常, //关键是下面的代码: MainActivity.this.runOnUiThread(new Runnable() { @Override public void run() { if (isFirstLoading) { //是否第一次加载 isFirstLoading = false; adapter = new ListAdapater(MainActivity.this, 1, datalist); listView.setAdapter(adapter); } else { //TODO adapter.notifyDataSetChanged(); } footLoading.setVisibility(View.GONE); isLoading = false; } }); //adapter是继承arrayadapter,就职声明了控件,每怎么重写方法,getview,class Viewholder什么的就不列出来了,如下: private class ListAdapater extends ArrayAdapter<DynamicdetailBean> { private LayoutInflater inflater; private SpannableStringBuilder builder; private Context context; private List<DynamicdetailBean> list; // TODO public ListAdapater(Context context, int res, List<DynamicdetailBean> list) { super(context, res, list); this.inflater = LayoutInflater.from(context); this.context = context; this.list = list; builder = new SpannableStringBuilder("回复"); ForegroundColorSpan yellowSpan = new ForegroundColorSpan(context .getResources().getColor(R.color.red_text)); builder.setSpan(yellowSpan, 0, builder.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); } } 但是每次从其他Activity跳转过来后,有时正常显示更新listview内容,有时就报错了:说listview没收到notification,如下: 但是如果不用runOnUiThread,改成用handler发消息就不会出错: handler.sendMessage(handler.obtainMessage(1, datalist)); Handler handler = new Handler(){ public void handleMessage(android.os.Message msg) { datalist = (List<DynamicdetailBean>) msg.obj; switch(msg.what){ case 1: if (isFirstLoading) { isFirstLoading = false; adapter = new ListAdapater(OfficialActivity.this, 1, datalist); listView.setAdapter(adapter); } else { //TODO adapter.notifyDataSetChanged(); } footLoading.setVisibility(View.GONE); isLoading = false; break; } }; }; 这是为什么呢,runOnUiThread有限制条件么?还请各位大神指点啊!!!
Type safety: Unchecked cast from Object to List<Blog> 大家讨论一下!
先看这个警告出现的代码吧: Message message = new Message(); message.obj = bos; handler.sendMessage(message);` 这是在一个线程里发送信息到主线程。下面在主线程进行强转: mList.addAll((List<Blog>) msg.obj); 这样转的时候会出现上面的警告,在网上找到了几个方法方法: 1、方法上添加@SuppressWarnings("unchecked"); 2、设置eclipse的属性; 3、 if (obj instanceof ArrayList<?>) { mList.addAll((List<Blog>) msg.obj); } 前两个方法能把警告去除,只是感觉不是最好的方法,第三个方法感觉好一点,只是不能支除警告,各位有没有更好的方法呢?
为什么这个treeSet 加了一个比较器就可以存储重复值了
``` package Work1; import java.util.ArrayList; import java.util.Comparator; import java.util.List; public class DictionariesDemo { public static void main(String[] args) { List<String> list = new ArrayList<String>(); list.add("list"); list.add("sum"); list.add("list"); list.add("avg"); list.add("dictionaries"); list.add("demo"); ComparableStr comparableStr = new ComparableStr(); comparableStr.sort(list); for(String li:list){ System.out.println(li); } } } ``` ``` package Work1; import java.util.Comparator; import java.util.List; import java.lang.String; import java.util.TreeSet; public class ComparableStr { public void sort(List<String> list){ TreeSet<String> treeSet= new TreeSet<String>(new Comparator<String>() { @Override public int compare(String o1, String o2) { int flag = o1.compareTo(o2); if(flag>=0){ flag=1; } return flag; } }); treeSet.addAll(list); list.clear(); list.addAll(treeSet); } } ```
集合类如ArrayList中为什么不提供addAll(E[] arr)方法。
在多次写测试demo时,在初始化List,加一些假数据时,总是很麻烦,需要多次调用add方法, List是提供 addAll(Collection<? extends E> c)方法的,其实现是将集合c转为Object[],再调用arrayCopy ``` public boolean addAll(Collection<? extends E> c) { Object[] a = c.toArray(); int numNew = a.length; ensureCapacityInternal(size + numNew); // Increments modCount System.arraycopy(a, 0, elementData, size, numNew); size += numNew; return numNew != 0; ``` 那为什么不提供一个参数为数组的方法,addAll(E[] arr)方法,参数为数组呢,这样初始化List内部数据时写起来就很快。我自己测了一下,似乎没什么问题 ``` List<Integer> list = new ArrayList<>(); list.addAll(new int[]{1,2,3,4}); ``` 这样不就更好吗
recyclerView的数据无法一次性更新出来(fragment)
我是用XUtils3的网络框架 ![这是展示解析出来的信息界面](https://img-ask.csdn.net/upload/201607/21/1469071154_861920.png) 问题:运行这个App然后点到“消息”界面(fragment),只能显示一条数据,当我切换到别的界面,然后又切换回“消息”界面,又刷新出两条数据;当全部数据全部显示出来以后,再次切换界面就会报错 代码如下 @ContentView(R.layout.fragment_message) public class Message extends Fragment { String url = "http://dxy.com/app/i/feed/tags2sub/list"; private String TAG = "Message"; private List<MessageInfo.DataBean.ItemsBean> messageList = new ArrayList<>(); @ViewInject(R.id.message_recycler) private RecyclerView message_recycler; private MyAdapter mAdapter; public Message() { // Required empty public constructor } @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = x.view().inject(this, inflater, container); //数据初始化 initData(); message_recycler.setHasFixedSize(true); message_recycler.setLayoutManager(new LinearLayoutManager(getActivity())); mAdapter = new MyAdapter(); message_recycler.setAdapter(mAdapter); return view; } /** * 点击事件 * @param view */ @Event(R.id.message) private void onClick(View view){ startActivity(new Intent(getActivity(), MessageActivity.class)); } /** * 解析数据 */ private void initData() { HashMap<String, String> map = new HashMap<>(); map.put("ac", "d5424fa6-adff-4b0a-8917-4264daf4a348"); HttpUtils.get(url, map, new MyCallBack<String>() { @Override public void onSuccess(String result) { // Toast.makeText(getActivity(), ""+result, Toast.LENGTH_SHORT).show(); Gson gson = new Gson(); MessageInfo messageInfo = gson.fromJson(result, MessageInfo.class); List<MessageInfo.DataBean.ItemsBean> items = messageInfo.getData().getItems(); messageList.addAll(items); // mAdapter.notifyItemRangeInserted(0, messageList.size()); mAdapter.notifyDataSetChanged(); Toast.makeText(getActivity(), "--------" + messageList.size(), Toast.LENGTH_SHORT).show(); } }); } /** * recyeler适配器 */ class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyHolder>{ @Override public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = getActivity().getLayoutInflater().inflate(R.layout.message_recycler_item, parent, false); MyHolder myHolder = new MyHolder(view); return myHolder; } @Override public void onBindViewHolder(MyHolder holder, int position) { MessageInfo.DataBean.ItemsBean itemsBean = messageList.get(position); holder.mHb_pressure.setText(itemsBean.getTags().get(position).getTag_name()); holder.mIntroduction.setText(itemsBean.getTags().get(position).getContent()); // notifyItemChanged(position); // holder.itemView.setTag(itemsBean); } @Override public int getItemCount() { return messageList.size(); } class MyHolder extends RecyclerView.ViewHolder{ private final TextView mHb_pressure; private final TextView mIntroduction; public MyHolder(View itemView) { super(itemView); mHb_pressure = (TextView) itemView.findViewById(R.id.HB_pressure); mIntroduction = (TextView) itemView.findViewById(R.id.Introduction); } } } }
分别用多线程处理两段代码,怎样写才能实现
在我controller请求层里面有接收到页面传过来的文档后,分别对每一条数据进行对应的逻辑操作,怎样才能保证for循环里面的两条代码分别用多线程来执行呢? 代码如下: public Map<String, Object> upload(@RequestParam(value = "path", required = false) String path, @RequestParam(value = "dns1", required = false) String dns1, @RequestParam(value = "dns2", required = false) String dns2, HttpServletResponse response,HttpServletRequest request)throws Exception { Map<String, Object> map = new HashMap<String, Object>(); String webPath=request.getServletContext().getRealPath(""); //读取TXT文件里面的域名信息 List<String> importTxt = TextUtils.importTxt(new File(webPath + path)); Dns dns = new Dns(); List<Dns> original_datas = new ArrayList<>();//dns1数据 List<Dns> this_datas = new ArrayList<>();//dns2数据 ExecutorService pool = Executors.newFixedThreadPool(10); for (String domain : importTxt) { if (domain == null ||domain.isEmpty()){ dns.setDomain("域名空"); }else { //解析两份数据(这两条代码需要分别用多线程来执行) //original_datas.addAll(DnsUtils.getIps(domain, dns1)); //this_datas.addAll(DnsUtils.getIps(domain, dns2)); Thread thread1 = new Thread(new Runnable() { @Override public void run() { try { original_datas.addAll(DnsUtils.getIps(domain, dns1)); System.out.println("线程1="+original_datas.toString()); } catch (IOException | InterruptedException e) { e.printStackTrace(); } } }); Thread thread2 = new Thread(new Runnable() { @Override public void run() { try { this_datas.addAll(DnsUtils.getIps(domain, dns2)); System.out.println("线程2="+this_datas.toString()); } catch (IOException | InterruptedException e) { e.printStackTrace(); } } }); pool.execute(thread1); pool.execute(thread2); } } pool.shutdown(); Thread.sleep(5000); System.out.println("original_datas="+original_datas.toString()); System.out.println("this_datas="+this_datas.toString()); //数据对比 List<String> dnsDuibi = MyUtil.dnsDuibi(original_datas,this_datas); dnsService.addList(original_datas); dnsService.addList(this_datas); map.put("msg", "上传成功"); map.put("success", true); //map.clear(); // 原数据比 this_data map.put("original_datas", original_datas); map.put("this_datas", this_datas); map.put("dnsDuibi", dnsDuibi); return map; 我上面自己写的那个线程是有问题的,因为不睡眠的话,系统始终比线程块快,会造成外面的输出 会没有值,而里面的输出有值的情况,而且这样写效率也不行. 求大佬指点迷津,发现自己多线程都没搞明白,心态有点崩
android Activity怎么改成Fragment
原来是activity 我改成了Fragmentactivity,在下面的添加到fragmentlist中时直接报错 程序结束 ``` private List<Fragment> fragmentlist; private ZBarDemoActivity fragment1; private Fragment2 fragment2; 。。。。。。 @SuppressWarnings("unchecked") public void initDatasViewPager() { //Intent intent = new Intent(main.this,ZBarDemoActivity.class); fragmentlist = new ArrayList<Fragment>(); fragment1 = new ZBarDemoActivity();// fragment2 = new Fragment2();// fragmentlist.addAll((Collection<? extends Fragment>) fragment1);显示这里错误 fragmentlist.addAll((Collection<? extends Fragment>) fragment2); fragmentViewPager.setAdapter(new FragmentAdapter(getSupportFragmentManager(), fragmentlist, this)); fragmentViewPager.setOnPageChangeListener(new MyOnPageChangeListener()); } ```
关于Collections.binarySearch的问题
我在测试写Collections.binarySearch发现以下的问题,大哥们能不能帮我解惑下: public static void main(String[] args) { List<String> all = new ArrayList<String>(); Collections.addAll(all, "ww","wh","gh","dr"); System.out.println(all); int point = Collections.binarySearch(all,"ww"); System.out.println(pu); } 这是我测试的代码,发现一个问题,这样是其中有两个内容出现重复现象,那么查询到的point就是负数,比如我添加的元素有hh,hw.那么查询hh的话,会是负数,查询hw就不会.疑惑中。
android 怎么把一个Activity装进一个fragment里?
想把一个fragmentactivity(里面有一个webview和一个悬浮按钮)放在fragment里 ``` fragmentlist = new ArrayList<Fragment>(); fragmentlist.add(fragment1); fragmentlist.addAll((Collection<? extends Fragment>) fragment2);这样写 直接报错 停止运行 ``` 所以想把fragmentactivity在放到一个fragment里 这样也许可行
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
花了20分钟,给女朋友们写了一个web版群聊程序
参考博客 [1]https://www.byteslounge.com/tutorials/java-ee-html5-websocket-example
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
这30个CSS选择器,你必须熟记(上)
关注前端达人,与你共同进步CSS的魅力就是让我们前端工程师像设计师一样进行网页的设计,我们能轻而易举的改变颜色、布局、制作出漂亮的影音效果等等,我们只需要改几行代码,不需...
国产开源API网关项目进入Apache孵化器:APISIX
点击蓝色“程序猿DD”关注我回复“资源”获取独家整理的学习资料!近日,又有一个开源项目加入了这个Java开源界大名鼎鼎的Apache基金会,开始进行孵化器。项目名称:AP...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
编写Spring MVC控制器的14个技巧
本期目录 1.使用@Controller构造型 2.实现控制器接口 3.扩展AbstractController类 4.为处理程序方法指定URL映射 5.为处理程序方法指定HTTP请求方法 6.将请求参数映射到处理程序方法 7.返回模型和视图 8.将对象放入模型 9.处理程序方法中的重定向 10.处理表格提交和表格验证 11.处理文件上传 12.在控制器中自动装配业务类 ...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
求小姐姐抠图竟遭白眼?痛定思痛,我决定用 Python 自力更生!
点击蓝色“Python空间”关注我丫加个“星标”,每天一起快乐的学习大家好,我是 Rocky0429,一个刚恰完午饭,正在用刷网页浪费生命的蒟蒻...一堆堆无聊八卦信息的网页内容慢慢使我的双眼模糊,一个哈欠打出了三斤老泪,就在此时我看到了一张图片:是谁!是谁把我女朋友的照片放出来的!awsl!太好看了叭...等等,那个背景上的一堆鬼画符是什么鬼?!真是看不下去!叔叔婶婶能忍,隔壁老王的三姨妈的四表...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
相关热词 如何提升c#开发能力 矩阵乘法c# c#调用谷歌浏览器 c# 去空格去转义符 c#用户登录窗体代码 c# 流 c# linux 可视化 c# mvc 返回图片 c# 像素空间 c# 日期 最后一天
立即提问