Arraylist添加另一个Arraylist后,怎么取出里面的数据

定义了一个Arraylist1,将里面的数据添加add到Arraylist2中.最后Arraylist2中的数据打印结果如下:
[Method [uuid=22345678901c,methodName=平面加工方案1]]

[Method [uuid=22345678901c,methodName=平面加工方案1], [uuid=22345678941c,methodName=平面加工方案2]]

现在想着,把Arraylist2.get(i)中的每一条methodName数据取出来,放在MethodArray中,最后的结果设想如下:
ArrayList MethodArray= new ArrayList();
MethodArray.get(0)值为“平面加工方案1”
MethodArray.get(1)值为“平面加工方案1,平面加工方案2”

现在没办法取到里面的Arraylist值,该怎么做?

4个回答

如果是[] 的话 :在循环里面: String s="[uuid=22345678901c,methodName=平面加工方案1]";
s=StringUtils.substringAfter(s,"methodName=");
String methodName=s.substring(0,s.length()-1); 获取name ,是map类型的话就直接get

ArryList list1 = new ArrayList<>();
list1.add("平面加工方案1");
list1.add("平面加工方案1,平面加工方案2");
ArrayList> list2 = new ArrayList<>();
list2.add(list1)
ArrayList MethodArray = new ArrayList<>();
for(int i = 0; i < list2.size; i++){
MethodArray = list2.get(i);
for(int j = 0; j< tem.size(); j++){
MethodArray.get(j);//打印出这个值即可
}
}

你的具体代码是什么?异常是什么,你要描述清楚,没截图,所以我只能这样理解你的需求。。。。

Arraylist2中的数据打印结果如下:
[Method [uuid=22345678901c,methodName=平面加工方案1]]
[Method [uuid=22345678901c,methodName=平面加工方案1], [uuid=22345678941c,methodName=平面加工方案

[uuid=22345678901c,methodName=平面加工方案1] 这个是list中的一个值 ,[] ?还是 { } , 你是存错了格式 还是就这样的?

Arraylist2中的数据打印结果如下:
[Method [uuid=22345678901c,methodName=平面加工方案1]]
[Method [uuid=22345678901c,methodName=平面加工方案1], [uuid=22345678941c,methodName=平面加工方案

[uuid=22345678901c,methodName=平面加工方案1] 这个是list中的一个值 ,[] ?还是 { } , 你是存错了格式 还是就这样的?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
第一次数据库查询成功,第二次查询去失败了?
我编写一个Android应用,A页面拥有一个选项菜单,点击菜单中的选项,跳转到B页面,B页面接收从A页面传递的数据后,进行数据库查询,在本页面中显示相关内容。 B页面中通过动态添加View的方法,添加了按钮,点击按钮,可进行数据库查询,获取相关值在页面显示。 不过我不想每次返回A页面,选择选项菜单的另一项再进入B页面,于是我在B页面同样放置了选项菜单,让我点击B页面上的选项菜单时,直接在B页面上显示,不过却出现“java.lang.NullPointerException: Attempt to invoke virtual method 'android.database.Cursor android.database.sqlite.SQLiteDatabase.rawQuery(java.lang.String, java.lang.String[])' on a null object reference”的错误。 请问,要怎样做呢? 相关数据库查询的函数 public ArrayList<JapInfo> query_stylecolumn(String style_column, String alp_style) { String sql = String.format("SELECT hiragana,katakana,sound_path FROM Jap_Info AS j " + "LEFT JOIN Alp_style AS a " + "ON j.alpha_style_id = a.id " + "WHERE j.style_column = '%s' and a.style_name = '%s';",style_column,alp_style); ArrayList<JapInfo> japIf = new ArrayList<JapInfo>(); Cursor cursor = mDB.rawQuery(sql,null); while (cursor.moveToNext()){ JapInfo japIfo = new JapInfo(); japIfo.hiragana = cursor.getString(0); japIfo.katakana = cursor.getString(1); japIfo.sound_path = cursor.getString(2); japIf.add(japIfo); } cursor.close(); return japIf; }
这么久没人能帮我吗? Bmob服务器。在查询数据时只能异步查询,onSuccess出现脏数据 ,请问怎么解决?
一些片段代码 //定义个个获取查询出的数据的数量 private int carNum; public int findCars(String goods_id, String user_id){ //--and条件1 BmobQuery<Car> eq1 = new BmobQuery<Car>("car"); eq1.addWhereEqualTo("goods_id", goods_id); //--and条件2 BmobQuery<Car> eq2 = new BmobQuery<Car>("car"); eq2.addWhereEqualTo("user_id", user_id); //整合成and条件 List<BmobQuery<Car>> andQuerys = new ArrayList<BmobQuery<Car>>(); andQuerys.add(eq1); andQuerys.add(eq2); //查询符合整个and条件的人 BmobQuery<Car> query = new BmobQuery<Car>("car"); query.and(andQuerys); query.findObjects(context, new FindCallback() { @Override public void onSuccess(JSONArray arg0) { Log.i("bmob", "for的legrnt::" + arg0.length() + "条数据。"); carNum=arg0.length(); } @Override public void onFailure(int arg0, String arg1) { Log.i("bmob", "查询失败:"); } }); Log.i("bmob", "count:" +carNum); return carNum; } 然后再另一个类中使用该方法,一个点击事件里 public void onClick(View v) { //将商品的id和用户id存入数据库 if(User.getCurrentUser(context)== null){ Intent intent = new Intent(context, LoginActivity.class); context.startActivity(intent); }else { //将商品的id存入数据库 CarDao carDao = new CarDao(context); GoodsDao goodsDao=new GoodsDao(context); //添加到购物车里 if(carDao.findCars(goodsId,user_id)<=0) { Log.i("bmob", "进入for循环。。。。。。"); carDao.saveGoods(goodsId, User.getCurrentUser(context).getObjectId()); }else { carDao.updateCar(carDao.getCarId(goodsId,user_id)); } //商品可售数量减一 goodsDao.updateData(goodsId); } } 数据输出 for的legrnt::3 count:0 也就是说findCars(String goods_id, String user_id)方法中在onSuccess里成功对carNum赋值了,但是return回来后确实0. 在网上查了一些资料说是onSuccess异步加载的问题, 我试过用handler去获取,是可以获取得了在onSuccess里面的数据,但是handler里面的数据我又拿不出给主线程里的变量,还是为null 小弟我能力不够解决这个问题,这问题已经困扰我好几天天了,希望有大神可以帮下我。
fragment跳转另一个fragment的问题!
项目地址: 链接: https://pan.baidu.com/s/1OHSva0M5PIQMWNP0iwzlLg 提取码: csf5 求大能帮我解决一下。我不知道怎么去写这个跳转。 ![图片说明](https://img-ask.csdn.net/upload/201903/12/1552331749_241936.png) 鼠标点击需要跳转(例如点击“苹果手机”); ``` public class MsgFragment extends Fragment { View view; TextView textView; private int i; private String str; private String[] mVals = new String[] { "苹果手机", "笔记本电脑", "电饭煲", "腊肉", "特产", "剃须刀", "宝宝", "康佳" }; private LayoutInflater mInflater; private FlowLayout mFlowLayout; //自定义recyclerveiw的适配器 @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); mInflater = LayoutInflater.from(getContext()); } public MsgFragment() { } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { view = inflater.inflate(R.layout.fragment_msg, container, false); mFlowLayout = view.findViewById(R.id.id_flowlayout); initData(); return view; } public void initData() { /** * 找到搜索标签的控件 */ for ( i = 0; i < mVals.length; i++) { final TextView tv = (TextView) mInflater.inflate( R.layout.search_label_tv, mFlowLayout, false); tv.setText(mVals[i]); str = tv.getText().toString(); //点击事件 tv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { try { switch (str) { case "苹果手机": break; case "笔记本电脑": break; case "电饭煲": break; case "腊肉": break; case "特产": break; case "剃须刀": break; case "宝宝": break; case "康佳": break; default: break; } } catch (Exception e) { e.printStackTrace(); } } }); mFlowLayout.addView(tv);//添加到父View } } } ``` 需要跳转到的fragment ``` public class CollectFragment extends Fragment { private View view;//定义view用来设置fragment的layout public RecyclerView mCollectRecyclerView;//定义RecyclerView //定义以goodsentity实体类为对象的数据集合 private ArrayList<GoodsEntity> goodsEntityList = new ArrayList<GoodsEntity>(); //自定义recyclerveiw的适配器 private CollectRecycleAdapter mCollectRecyclerAdapter; @Nullable @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { //获取fragment的layout view = inflater.inflate(R.layout.item_content, container, false); //对recycleview进行配置 initRecyclerView(); //模拟数据 initData(); return view; } /** * TODO 模拟数据 */ private void initData() { for (int i=0;i<10;i++){ GoodsEntity goodsEntity=new GoodsEntity(); goodsEntity.setGoodsName("模拟数据"+i); goodsEntity.setGoodsPrice("100"+i); goodsEntityList.add(goodsEntity); } } /** * TODO 对recycleview进行配置 */ private void initRecyclerView() { //获取RecyclerView mCollectRecyclerView=view.findViewById(R.id.collect_recyclerView); //创建adapter mCollectRecyclerAdapter = new CollectRecycleAdapter(getActivity(), goodsEntityList); //给RecyclerView设置adapter mCollectRecyclerView.setAdapter(mCollectRecyclerAdapter); //设置layoutManager,可以设置显示效果,是线性布局、grid布局,还是瀑布流布局 //参数是:上下文、列表方向(横向还是纵向)、是否倒叙 mCollectRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity(), LinearLayoutManager.VERTICAL, false)); //设置item的分割线 mCollectRecyclerView.addItemDecoration(new DividerItemDecoration(getActivity(),DividerItemDecoration.VERTICAL)); //RecyclerView中没有item的监听事件,需要自己在适配器中写一个监听事件的接口。参数根据自定义 mCollectRecyclerAdapter.setOnItemClickListener(new CollectRecycleAdapter.OnItemClickListener() { @Override public void OnItemClick(View view, GoodsEntity data) { //此处进行监听事件的业务处理 Toast.makeText(getActivity(),"我是item",Toast.LENGTH_SHORT).show(); } }); } } ```
在其中6个textbox中输入值,其输入的值显示在另一个textbox中
``` <%@ page language="java" contentType="text/html; charset=GBK" %> <%@ page import="weaver.file.*," %> <%@ page import="weaver.general.Util" %> <%@ page import="weaver.conn.RecordSet" %> <jsp:useBean id="ExcelFile" class="weaver.file.ExcelFile" scope="session"/> <iframe id="ExcelOut" name="ExcelOut" border=0 frameborder=no noresize=NORESIZE height="0%" width="0%"></iframe> <%@ page import="java.util.*" %> <% //OA-SAP-DM直连流程-物料主数据新增流程 //导出excel文件处理页面(DM_WF_02_ExcelOut.jsp) RecordSet rs = new RecordSet (); //List list = new ArrayList(); String formid = Util.null2String(request.getParameter("formid")); String requestid = Util.null2String(request.getParameter("requestid")); if(!"".equals(formid)){ formid = formid.replace("-",""); } //声明excel文件对象 ExcelSheet es = new ExcelSheet(); //声明EXCEL中的列名 ExcelRow colname = es.newExcelRow () ; //为EXCEL添加多个列 colname.addStringValue("序号"); colname.addStringValue("物料编码"); colname.addStringValue("描述"); colname.addStringValue("单位"); colname.addStringValue("物料组"); colname.addStringValue("物料组描述"); colname.addStringValue("物料组长描述"); colname.addStringValue("旧物料号"); colname.addStringValue("物料名称"); colname.addStringValue("规格型号"); colname.addStringValue("材质/图号/位号"); colname.addStringValue("执行标准"); colname.addStringValue("所属设备规格/名称或位号"); colname.addStringValue("是否需要做设备管理"); colname.addStringValue("备注"); colname.addStringValue("长描述"); colname.addStringValue("单位描述"); colname.addStringValue("产品组"); colname.addStringValue("产品组描述"); colname.addStringValue("外部物料组"); colname.addStringValue("外部物料组描述"); es.addExcelRow(colname) ; String sql_row="select * from formtable_main_" + formid + "_dt1 where mainid=(select id from formtable_main_"+formid+" where requestid="+requestid+") order by id"; rs.executeSql(sql_row); int i=1; /* String name = Util.null2String(request.getParameter("formid")); String spe = Util.null2String(request.getParameter("requestid")); */ while(rs.next()){ ExcelRow colvalue = es.newExcelRow () ; //for(int i=0;i<list.size();i++){ colvalue.addStringValue(Integer.toString(i)) ; //colvalue.addStringValue(Util.null2String(rs.getString("mdj00")) // 序号 colvalue.addStringValue(Util.null2String(rs.getString("mdj01")));// 物料编码 colvalue.addStringValue(Util.null2String(rs.getString("mdj08")).replace("”","\""));// 描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj10")));// 单位 colvalue.addStringValue(Util.null2String(rs.getString("mdj12")));// 物料组 colvalue.addStringValue(Util.null2String(rs.getString("mdj13")));// 物料组描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj21")));// 物料组长描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj16")));// 旧物料号 String code = Util.null2String(rs.getString("mdj02")); colvalue.addStringValue(code);// 物料名称 colvalue.addStringValue(Util.null2String(rs.getString("mdj03")).replace("”","\""));// 规格型号 colvalue.addStringValue(Util.null2String(rs.getString("mdj04")));// 材质 colvalue.addStringValue(Util.null2String(rs.getString("mdj05")));// 执行标准 colvalue.addStringValue(Util.null2String(rs.getString("mdj07")).replace("”","\""));// 所属设备规格/名称或位号 colvalue.addStringValue(Util.null2String(rs.getString("mdj17")).replace("0","Y"));// 是否需要做设备管理 colvalue.addStringValue(Util.null2String(rs.getString("beiz")));// 备注 colvalue.addStringValue(Util.null2String(rs.getString("mdj09")).replace("”","\""));// 长描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj11")));// 单位描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj14")));// 产品组 colvalue.addStringValue(Util.null2String(rs.getString("mdj15")));// 产品组描述 colvalue.addStringValue(Util.null2String(rs.getString("mdj18")));// 外部物料组 colvalue.addStringValue(Util.null2String(rs.getString("mdj19")));// 外部物料组描述 i++; //} //加入一行 es.addExcelRow(colvalue) ; } ExcelFile.init(); ExcelFile.setFilename("新增物料主数据清单") ; ExcelFile.addSheet("sheet1", es) ; //为EXCEL文件插入一个SHEET out.print("<a href='/weaver/weaver.file.ExcelOut'>导出EXCEL文件</a>"); //out.print("<button id=\"outexcel\" title=\"导出EXCEL\" class=\"BtnLog\" onclick=\"location.href='/weaver/weaver.file.ExcelOut'\" >&nbsp;&nbsp;&nbsp;导出EXCEL</button>"); %> ```
Java利用163邮箱发送邮件出现问题,卡了我几天了,求大神为我解答!!!
我smtp服务开了,邮件可以发送,但是问题是 我第一次开启tomcat 发邮件填写正确密码,可以成功发送,如果再不重启tomcat的情况发再次发送邮件,就不管输入什么密码都能发送成功。 同样的,第一次发送邮件 如果输入的是错误的密码,在不重启tomcat的情况下 再次发送邮件 输入正确密码,还是提示身份验证失败。 求大神为我解惑啊。。 ``` public String findMail() throws Exception { try { Properties pro = new Properties(); pro.put("mail.smtp.host", "smtp.163.com"); pro.put("mail.smtp.auth", "true"); // SSL加密 pro.put("mail.smtp.ssl.enable", "true"); pro.put("mail.smtp.ssl.socketFactory", "465"); // 根据邮件的会话属性构造一个发送邮件的Session,这里需要注意的是用户名那里不能加后缀,否则便不是用户名了 // 还需要注意的是,这里的密码不是正常使用邮箱的登陆密码,而是客户端生成的另一个专门的授权码 MailAuthenticator authenticator = new MailAuthenticator(username, password); Session session = Session.getDefaultInstance(pro, authenticator); // 根据Session 构建邮件信息 Message message = new MimeMessage(session); // 创建邮件发送者地址 Address from = new InternetAddress(username); // 设置邮件消息的发送者 message.setFrom(from); // 验证收件人邮箱地址 List<String> toAddressList = new ArrayList<>(); toAddressList.add(toemail); StringBuffer buffer = new StringBuffer(); if (!toAddressList.isEmpty()) { String regEx = "^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$"; Pattern p = Pattern.compile(regEx); for (int i = 0; i < toAddressList.size(); i++) { Matcher match = p.matcher(toAddressList.get(i)); if (match.matches()) { buffer.append(toAddressList.get(i)); if (i < toAddressList.size() - 1) { buffer.append(","); } } } } String toAddress = buffer.toString(); if (!toAddress.isEmpty()) { // 创建邮件的接收者地址 Address[] to = InternetAddress.parse(toAddress); // 设置邮件接收人地址 message.setRecipients(Message.RecipientType.TO, to); // 邮件主题 // message.setSubject("java邮件测试"); message.setSubject(subject); // 邮件容器 MimeMultipart mimeMultiPart = new MimeMultipart(); // 设置HTML BodyPart bodyPart = new MimeBodyPart(); // 邮件内容 String htmlText = body; bodyPart.setContent(htmlText, "text/html;charset=utf-8"); mimeMultiPart.addBodyPart(bodyPart); // 添加附件 List<String> fileAddressList = new ArrayList<String>(); fileAddressList.add(file); if (fileAddressList != null) { BodyPart attchPart = null; for (int i = 0; i < fileAddressList.size(); i++) { if (!fileAddressList.get(i).isEmpty()) { attchPart = new MimeBodyPart(); // 附件数据源 DataSource source = new FileDataSource( fileAddressList.get(i)); // 将附件数据源添加到邮件体 attchPart.setDataHandler(new DataHandler(source)); // 设置附件名称为原文件名 attchPart.setFileName(MimeUtility.encodeText(source.getName())); mimeMultiPart.addBodyPart(attchPart); } } } message.setContent(mimeMultiPart); message.setSentDate(new Date()); // 保存邮件 message.saveChanges(); // 发送邮件 Transport.send(message); System.out.println("发送成功"); } } catch (Exception e) { e.printStackTrace(); System.out.println("错误原因:"+e); } return null; } ``` 异常信息:javax.mail.AuthenticationFailedException: Authentication failed
关于ViewPager+GridView,实现GridView横向水平滑动的的问题
在网上看了好多DEMO效果都不是想要的然后发现了这个例子下面贴出来 package com.example.bmvod.myapplication; import android.app.Activity; import android.os.Bundle; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.util.DisplayMetrics; import android.view.View; import android.view.ViewGroup; import android.view.ViewGroup.LayoutParams; import android.widget.BaseAdapter; import android.widget.GridView; import android.widget.ImageView; import android.widget.LinearLayout; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.atomic.AtomicInteger; public class MainActivity extends Activity { private LinearLayout linear01; private LinearLayout linear02; private List<Map<String, Object>> listView; private int next = 0; private ViewPager adViewPager; private AdPageAdapter adapter; private ImageView[] imageViews; private ImageView imageView; private AtomicInteger atomicInteger = new AtomicInteger(0); private boolean isContinue = true; private List<View> gridViewlist = new ArrayList<View>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { System.out.println("initView()"); linear01 = (LinearLayout) findViewById(R.id.view_pager_content); linear02 = (LinearLayout) findViewById(R.id.viewGroup); listView = new ArrayList<Map<String, Object>>(); //创建ViewPager adViewPager = new ViewPager(this); //获取屏幕像素相关信息 DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); //根据屏幕信息设置ViewPager广告容器的宽高 //adViewPager.setLayoutParams(new LayoutParams(dm.widthPixels, dm.heightPixels)); //将ViewPager容器设置到布局文件父容器中 linear01.addView(adViewPager); getView(); initCirclePoint(); adViewPager.setAdapter(adapter); adViewPager.addOnPageChangeListener(new AdPageChangeListener()); } /** * ViewPager 页面改变监听器 */ private final class AdPageChangeListener implements OnPageChangeListener { /** * 页面滚动状态发生改变的时候触发 */ @Override public void onPageScrollStateChanged(int arg0) { } /** * 页面滚动的时候触发 */ @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } /** * 页面选中的时候触发 */ @Override public void onPageSelected(int arg0) { //获取当前显示的页面是哪个页面 System.out.println("onPageSelected"); atomicInteger.getAndSet(arg0); //重新设置原点布局集合 for (int i = 0; i < imageViews.length; i++) { imageViews[arg0].setBackgroundResource(R.drawable.point_focused); if (arg0 != i) { imageViews[i].setBackgroundResource(R.drawable.point_unfocused); } } } } private void initCirclePoint() { System.out.println("initCirclePoint()"); imageViews = new ImageView[gridViewlist.size()]; //广告栏的小圆点图标 for (int i = 0; i < gridViewlist.size(); i++) { //创建一个ImageView, 并设置宽高. 将该对象放入到数组中 imageView = new ImageView(this); LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.MATCH_PARENT); layoutParams.setMargins(10, 0, 10, 0); imageView.setLayoutParams(layoutParams); imageViews[i] = imageView; //初始值, 默认第0个选中 if (i == 0) { imageViews[i].setBackgroundResource(R.drawable.point_focused); } else { imageViews[i].setBackgroundResource(R.drawable.point_unfocused); } //将小圆点放入到布局中 linear02.addView(imageViews[i]); } } private void getView() { int[] intView = {R.drawable.one, R.drawable.two, R.drawable.three, R.drawable.four, R.drawable.five, R.drawable.six, R.drawable.seven, R.drawable.eight, R.drawable.nine, R.drawable.ten , R.drawable.eleven, R.drawable.twelve, R.drawable.thirteen, R.drawable.fourteen, R.drawable.fifteen, R.drawable.sixteen, R.drawable.seventeen}; for (int i = 0; i < intView.length; i++) { Map<String, Object> mapView = new HashMap<String, Object>(); mapView.put("image", intView[i]); listView.add(mapView); } getGridView(); } private void getGridView() { boolean bool = true; while (bool) { int result = next + 9; if (listView.size() != 0 && result < listView.size()) { GridView gridView = new GridView(this); gridView.setNumColumns(5); gridView.setVerticalSpacing(30); gridView.setHorizontalSpacing(0); List<Map<String, Object>> gridlist = new ArrayList<Map<String, Object>>(); for (int i = next; i < result; i++) { gridlist.add(listView.get(i)); } MyAdapter myAdapter = new MyAdapter(gridlist); gridView.setAdapter(myAdapter); next = result; gridViewlist.add(gridView); } else if (result - listView.size() <= 9) { System.out.println("剩余多少" + (result - listView.size())); List<Map<String, Object>> gridlist = new ArrayList<Map<String, Object>>(); for (int i = next; i < listView.size(); i++) { gridlist.add(listView.get(i)); } GridView gridView = new GridView(this); gridView.setNumColumns(5); MyAdapter myAdapter = new MyAdapter(gridlist); gridView.setAdapter(myAdapter); next = listView.size() - 1; gridViewlist.add(gridView); bool = false; } else { bool = false; } } adapter = new AdPageAdapter(gridViewlist); } private final class AdPageAdapter extends PagerAdapter { private List<View> views = null; /** * 初始化数据源, 即View数组 */ public AdPageAdapter(List<View> views) { this.views = views; } /** * 从ViewPager中删除集合中对应索引的View对象 */ @Override public void destroyItem(View container, int position, Object object) { ((ViewPager) container).removeView(views.get(position)); } /** * 获取ViewPager的个数 */ @Override public int getCount() { return views.size(); } /** * 从View集合中获取对应索引的元素, 并添加到ViewPager中 */ @Override public Object instantiateItem(View container, final int position) { ((ViewPager) container).addView(views.get(position), 0); // views.get(position).setOnClickListener(new OnClickListener() { // // @Override // public void onClick(View v) { // System.out.println("position"+position); // Intent intent=new Intent(MainActivity.this,OtherViewPage.class); // MainActivity.this.startActivity(intent); // } // }); return views.get(position); } /** * 是否将显示的ViewPager页面与instantiateItem返回的对象进行关联 * 这个方法是必须实现的 */ @Override public boolean isViewFromObject(View view, Object object) { return view == object; } } private class MyAdapter extends BaseAdapter { List<Map<String, Object>> listgrid; private MyAdapter(List<Map<String, Object>> listgrid) { this.listgrid = listgrid; } @Override public int getCount() { return listgrid.size(); } @Override public Object getItem(int position) { return listgrid.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { convertView = getLayoutInflater().inflate(R.layout.grid_view_item, null); ImageView getViewLinear = (ImageView) convertView.findViewById(R.id.getViewLinear); getViewLinear.setBackgroundResource(Integer.parseInt(listgrid.get(position).get("image").toString())); return convertView; } } } ``` ``` 只有两个布局文件一个只有上下两个布局里面的ViewPager和小圆点都写在代码里,另一个就是GRIDVIEW的ITEM 经过测试 gridView.setVerticalSpacing(30);只对当前页有效 翻到第二页上下两个图片间距为0,,,gridView.setHorizontalSpacing(5);无效!求解啊!!!!!
JTable动态增加一行
不常用swing,感觉很陌生.希望大家帮帮忙. 用JTable显示数据库里一个表的信息,有按钮"增加",按下后在表格的最后增加一行,可以往上填数据,然后点击"保存",保存到数据库,也可以选择一行进行编辑,点"保存"保存到数据库.现在我点"增加"按钮后可以增加一行,但是往上填数据的时候,填完一格转到另一格后数据就不见了,不知道怎么回事.代码贴出来,可以运行看看,就三个类,如下:(所有的分都给了) //模型 package product; import java.util.ArrayList; import javax.swing.table.AbstractTableModel; import javax.swing.table.DefaultTableModel; public class ProductTableModel extends AbstractTableModel { private ArrayList list = new ArrayList(); private String[] column = { "Product Name", "Product Description", "Status" }; public ProductTableModel() { } public ProductTableModel(ArrayList list) { this(); setList(list); } public int getColumnCount() { return column.length; } public int getRowCount() { return list.size(); } public Object getValueAt(int arg0, int arg1) { ProductBean p = (ProductBean) list.get(arg0); return getPropertyValueByCol(p, arg1); } public void addList(int index, ProductBean p) { if (index < 0 || index > list.size() - 1) { list.add(p); fireTableRowsInserted(list.size(), list.size()); } else { list.add(index, p); fireTableRowsInserted(index, index); } } public boolean deleteList(int index) { if (index >= 0 && index < list.size()) { list.remove(index); fireTableRowsDeleted(index, index); return true; } else return false; } public boolean updateList(int index, ProductBean p) { if (index >= 0 && index < list.size()) { list.set(index, p); fireTableRowsUpdated(index, index); return true; } else return false; } public ProductBean getList(int index) { if (index >= 0 && index < list.size()) { return (ProductBean) list.get(index); } else return null; } public ArrayList getList() { return list; } public void setList(ArrayList list) { this.list = list; fireTableDataChanged(); } public String getColumnName(int i) { return column[i]; } public void setColumn(String[] column) { this.column = column; } public Object getPropertyValueByCol(ProductBean p, int col) { switch (col) { case 0: return p.getProduct_name(); case 1: return p.getProduct_desc(); case 2: return p.getProduct_status(); } return null; } public boolean isCellEditable(int row, int column) { return true; } } //主要的显示 package product; import java.awt.BorderLayout; import java.awt.Container; import java.awt.Dimension; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.ArrayList; import java.util.LinkedList; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.event.TableModelEvent; import javax.swing.event.TableModelListener; public class ProductFrame extends JFrame { private JPanel pnlTop = null; private JLabel lblProductName = null; private JLabel lblProductDesc = null; private JLabel lblProductStatus = null;       private JButton btnAdd = null; private JButton btnDelete = null; private JButton btnUpdate = null; private JScrollPane panTable = null; private JTable tblProduct = null; private ProductTableModel tmdProduct = null; private ArrayList lstProduct = null; public ProductTableModel getTmdProduct() { if (null == tmdProduct) { tmdProduct = new ProductTableModel(lstProduct); return tmdProduct; } return tmdProduct; } public JTable getTblProduct() { if (null == tblProduct) { tblProduct = new JTable(getTmdProduct()); tblProduct.setEnabled(true); tblProduct.setRowSelectionAllowed(true); return tblProduct; } return tblProduct; } public JScrollPane getPanTable() { if (null == panTable) { panTable = new JScrollPane(); panTable.setViewportView(getTblProduct()); return panTable; } return panTable; } public JPanel getPnlTop() { if (null == pnlTop) { pnlTop = new JPanel(); pnlTop.setLayout(new FlowLayout(FlowLayout.CENTER)); pnlTop.add(getLblProductName());                 pnlTop.add(getLblProductDesc()); pnlTop.add(getLblProductStatus()); pnlTop.add(getBtnAdd()); pnlTop.add(getBtnDelete()); pnlTop.add(getBtnUpdate()); return pnlTop; } return pnlTop; } public JLabel getLblProductName() { if (null == lblProductName) { lblProductName = new JLabel("Product Name"); return lblProductName; } return lblProductName; } public JLabel getLblProductDesc() { if (null == lblProductDesc) { lblProductDesc = new JLabel("Product Description"); return lblProductDesc; } return lblProductDesc; } public JLabel getLblProductStatus() { if (null == lblProductStatus) { lblProductStatus = new JLabel("Status"); return lblProductStatus; } return lblProductStatus; } public JButton getBtnAdd() { if (null == btnAdd) { btnAdd = new JButton("添加"); btnAdd.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { addProductBean(); } }); return btnAdd; } return btnAdd; } public JButton getBtnDelete() { if (null == btnDelete) { btnDelete = new JButton("删除"); btnDelete.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { deleteProduct(); } }); return btnDelete; } return btnDelete; } public JButton getBtnUpdate() { if (null == btnUpdate) { btnUpdate = new JButton("更新"); btnUpdate.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { updateProduct(); } }); return btnUpdate; } return btnUpdate; } public void addProductBean() { ProductBean p = new ProductBean(); getTmdProduct().addList(getTblProduct().getSelectedRow(), p); } public void updateProduct() { ProductBean p = getTmdProduct().getList( getTblProduct().getSelectedRow()); if (p != null) { getTmdProduct().updateList(getTblProduct().getSelectedRow(), p); } } public void deleteProduct() { getTmdProduct().deleteList(getTblProduct().getSelectedRow()); } public void initData() { lstProduct = new ArrayList(); } public ProductFrame() { initData(); Container c = this.getContentPane(); c.setLayout(new BorderLayout()); c.add(getPnlTop(), BorderLayout.NORTH); c.add(getPanTable(), BorderLayout.CENTER); this.setSize(new Dimension(800, 600)); this.setVisible(true); } public static void main(String[] args) { new ProductFrame(); } } //产品类 package product; public class ProductBean { private String product_name; private String product_desc; private String product_status; public String getProduct_name() { return product_name; } public void setProduct_name(String product_name) { this.product_name = product_name; } public String getProduct_desc() { return product_desc; } public void setProduct_desc(String product_desc) { this.product_desc = product_desc; } public String getProduct_status() { return product_status; } public void setProduct_status(String product_status) { this.product_status = product_status; } }
请教一个Activity跳转到另外一个Activity失败的问题
package com.example.t; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.TextView; import android.widget.Toast; public class LoginActivity extends Activity { private EditText mAccount; private EditText mPwd; private Button mLoginButton; private View loginView; private View loginSuccessView; private TextView loginSuccessShow; private LoginDataManager mUserDataManager; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.loginpage); mAccount=(EditText) findViewById(R.id.login_edit_account); mPwd = (EditText) findViewById(R.id.login_edit_pwd); mLoginButton = (Button) findViewById(R.id.login_btn_login); loginView=findViewById(R.id.login_view); loginSuccessView=findViewById(R.id.login_success_view); loginSuccessShow=(TextView) findViewById(R.id.login_success_show); mLoginButton.setOnClickListener(mListener); if (mUserDataManager == null) { mUserDataManager = new LoginDataManager(this); mUserDataManager.openDataBase(); } } OnClickListener mListener = new OnClickListener() { public void onClick(View v) { int id=v.getId(); if( id==R.id.login_btn_login){ login(); } } }; public void login() { if (isUserNameAndPwdValid()) { String userName = mAccount.getText().toString().trim(); String userPwd = mPwd.getText().toString().trim(); int result=mUserDataManager.findUserByNameAndPwd(userName, userPwd); if(result==1){ //login success loginView.setVisibility(View.GONE); loginSuccessView.setVisibility(View.VISIBLE); loginSuccessShow.setText(getString(R.string.user_login_sucess, userName)); Toast.makeText(this, getString(R.string.login_sucess), Toast.LENGTH_SHORT).show(); }else if(result==0){ //login failed,user does't exist Toast.makeText(this, getString(R.string.login_fail), Toast.LENGTH_SHORT).show(); } } } public void register() { if (isUserNameAndPwdValid()) { String userName = mAccount.getText().toString().trim(); String userPwd = mPwd.getText().toString().trim(); //check if user name is already exist int count=mUserDataManager.findUserByName(userName); if(count>0){ Toast.makeText(this, getString(R.string.name_already_exist, userName), Toast.LENGTH_SHORT).show(); return ; } } } public boolean isUserNameAndPwdValid() { if (mAccount.getText().toString().trim().equals("")) { Toast.makeText(this, getString(R.string.account_empty), Toast.LENGTH_SHORT).show(); return false; } else if (mPwd.getText().toString().trim().equals("")) { Toast.makeText(this, getString(R.string.pwd_empty), Toast.LENGTH_SHORT).show(); return false; } return true; } @Override protected void onResume() { if (mUserDataManager == null) { mUserDataManager = new LoginDataManager(this); mUserDataManager.openDataBase(); } super.onResume(); } @Override protected void onDestroy() { super.onDestroy(); } @Override protected void onPause() { if (mUserDataManager != null) { mUserDataManager.closeDataBase(); mUserDataManager = null; } super.onPause(); } } 另一个 package com.example.t; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.Window; import android.widget.AdapterView; import android.widget.GridView; import android.widget.SimpleAdapter; import android.widget.AdapterView.OnItemClickListener; /** * @author Administrator * @description 首页 */ public class HomePageActivity extends Activity implements OnItemClickListener { private boolean[] isPermitted; int drawableitems[] = { R.drawable.aa,R.drawable.bb,R.drawable.cc,R.drawable.dd,R.drawable.ee,R.drawable.ff,R.drawable.gg}; String[] itemsnames = { "最热单品","时尚饰品","珠宝首饰", "品质手表","潮流眼镜","绅士配件","DIY" }; @Override protected void onCreate(Bundle savedInstanceState) { requestWindowFeature(Window.FEATURE_NO_TITLE); super.onCreate(savedInstanceState); setContentView(R.layout.home); GridView gridview = (GridView) findViewById(R.id.GridView); List<Map<String, Object>> itemList = new ArrayList<Map<String, Object>>(); for (int i = 0; i < itemsnames.length; i++) { Map<String, Object> map = new HashMap<String, Object>(); map.put("ItemImage", drawableitems[i]); map.put("ItemText", itemsnames[i]); itemList.add(map); } SimpleAdapter saMenuItem = new SimpleAdapter(this, itemList, // 数据源 R.layout.homeitems, // xml实现 new String[] { "ItemImage", "ItemText" }, // 对应map的Key new int[] { R.id.ItemImage, R.id.ItemText }); // 对应R的Id // 添加Item到网格中 gridview.setAdapter(saMenuItem); gridview.setOnItemClickListener(this); //permit setting isPermitted = new boolean[saMenuItem.getCount()]; } @Override public void onItemClick(AdapterView<?> adapter, View view, int position, long id) { System.out.println("id:" + id); System.out.println("position:" + position); // String[] itemsnames = { "最热单品","时尚饰品","珠宝首饰", "品质手表","潮流眼镜","绅士配件","DIY" }; if (position == 0) { System.out.println("最热单品"); Intent intent1 = new Intent(this, HotActivity.class); startActivity(intent1); } if (position == 1) { System.out.println("时尚饰品"); Intent intent = new Intent(this, FashionActivity.class); startActivity(intent); } if (position == 2) { System.out.println("珠宝首饰"); Intent intent = new Intent(this, JewelryActivity.class); startActivity(intent); } if (position == 3) { System.out.println("品质手表"); Intent intent = new Intent(this, WatchActivity.class); startActivity(intent); } if (position == 4) { System.out.println("潮流眼镜"); Intent intent = new Intent(this, GlassesActivity.class); startActivity(intent); } if (position == 5) { System.out.println("绅士配件"); Intent intent = new Intent(this,GentryActivity.class); startActivity(intent); } if (position == 6) { System.out.println("DIY"); Intent intent = new Intent(HomePageActivity.this,DiyActicity.class); startActivity(intent); } } } 之前可能发错了,不好意思 是不是缺少了一些代码,求补充~
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
程序员需要了解的硬核知识之汇编语言(一)
之前的系列文章从 CPU 和内存方面简单介绍了一下汇编语言,但是还没有系统的了解一下汇编语言,汇编语言作为第二代计算机语言,会用一些容易理解和记忆的字母,单词来代替一个特定的指令,作为高级编程语言的基础,有必要系统的了解一下汇编语言,那么本篇文章希望大家跟我一起来了解一下汇编语言。 汇编语言和本地代码 我们在之前的文章中探讨过,计算机 CPU 只能运行本地代码(机器语言)程序,用 C 语言等高级语...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
java知识体系整理,学会了,月入过万不是梦
欢迎关注个人公众号:程序猿学社 前言: 一转眼,工作4年了,正式写博客也有一年多了,之前就有整理和总结的习惯,只是都记录在有道云,感觉知识点都是很凌乱,花时间系统整理下,该文会一直同步更新,有不足之处,希望各位同行指正,既然,选择做技术这行,就得有分享的精神,而不是抱着别人会超过你的心理。希望各位博友们互相交流,互相进步。 目录 java系统学习 小白也能...
2020年去一线大厂面试先过SSM框架源码这一关!
SSM框架介绍 (1)持久层(Mybatis):Dao层(mapper) DAO层:DAO层主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此。 DAO层的设计首先是设计DAO的接口。 然后在Spring的配置文件中定义此接口的实现类。 然后就可在模块中调用此接口来进行数据业务的处理,而不用关心此接口的具体实现类是哪个类,显得结构非常清晰。 DAO层的数据源配置,以及有...
教你一键快速生成后台代码,这样和测试小姐姐聊天的时间又多了
教你一键快速生成后台代码,咋们作为开发人员,应该把时间精力放在业务逻辑的实现上面。
Java程序员必备基础:内部类解析
前言 整理了一下内部类的相关知识,算是比较全,比较基础的,希望大家一起学习进步。 一、什么是内部类? 在Java中,可以将一个类的定义放在另外一个类的定义内部,这就是内部类。内部类本身就是类的一个属性,与其他属性 定义方式一致。 一个内部类的例子: public class Outer { private int radius = 1; public static int co...
北漂女程序员工作6年面试JD要价28K
写在开头: 上周面试了一位女程序员,上午10::30来我们部门面试,2B哥接待了她. 大家来看看她的简历: 个人简历 个人技能: ● 熟悉spring mvc 、spring、mybatis 等框架 ● 熟悉 redis 、rocketmq、dubbo、zookeeper、netty 、nginx、tomcat、mysql。 ● 阅读过juc 中的线程池、锁的源码以及netty 中的主从多线程...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
人脸生成黑科技:实现人脸转变特效,让人脸自动戴墨镜
上一节我们通过VAE网络完成了人脸生成效果。VAE网络一个特性是会把人脸编码成一个含有200个分量的向量,反过来说在特定分布范围内的含有200个分量的向量就对应一张人脸。由于向量之间可以进行运算,这就意味着我们把两张不同人脸A,B分布转换成两个不同向量z_A,z_B,然后我们使用向量运算例如z_AB = z_A *(1 - alpha) + z_B *alpha,就能将两个向量以一定比例合成一个新...
Java9到Java13各版本新特性代码全部详解(全网独家原创)
Java现在已经发展到了Java13了(正式版本),相信很多朋友还对各个版本还不是很熟悉,这里面专门把Java9到Java13各个版本的一些新特性做了一些详细讲解。我在网上也找了很多,但基本都是官方文档的CV,没有任何代码演示,而且官方的示例代码也不是很好找得到,官方API目前还是Java10,官方文档真是坑啊。所以我在这里专门写了一篇文章,主要针对平时开发与有关的功能Java9到Java13各...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问