SpringDataJPA中封装BaseService问题,哪个大佬有经验?帮帮小弟

Dao层继承了JpaRepository,有了单表的CRUD方法,省去了很多力气。
但是service层需要封装个**BaseService**来让所有的Service继承,以此来获取单表的CRUD方法。
但BaseService该怎么封装呢,谁会?帮帮小弟,谢谢了!

1个回答

weixin_41939424
weixin_41939424 已经实现了,大佬威武!大佬牛逼!请受小弟膜拜
2 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
SpringBoot中Mapper如果在BaseService里面注入会有什么问题吗?
我们的Service层都会集成一个BaseService. 今天有几个相同的Service用到了同一个Mapper, 我一直以来都是在每个Service中注入一个私有的Mapper. 但是其实在BaseService里面注入一个public的Mapper给Service继承不也能直接用吗? 这样会有什么风险吗?
SpringDataJpa如何实现公共方法的封装。
## 如何实现SpringDataJpa公共代码的封装 Jpa在框架层面上实现了常用的CRUD操作。我想在Controller的父类上,父类自带了普通的增删改查接口,然后子类只需要扩展额外个性化功能即可。 个人实现如下,BaseRepository 实现JpaRepository, BaseService中,注入BaseRepository BaseController中,注入BaseService 现在个人碰到的问题是,在User Controller调用查询的时候,service使用了SimpleJpaRepository 这个默认实现来进行查询,查询的泛型被定义为BaseEntity,BaseEntity并非一个实体 所以报错。 求教,我的想法有没有什么问题? 然后就是,我的这种想要实现的方式有没有什么已有的最佳实践? 最后,如果有大佬可以指点出我的问题,能帮我调试一下,更是感激不尽。 ####现在的代码结构 ![图片说明](https://img-ask.csdn.net/upload/201909/11/1568182337_150797.png) ####Entity ``` @MappedSuperclass @Data public abstract class BaseEntity { @Id @GeneratedValue(generator = "core-uuid") @GenericGenerator(name = "core-uuid", strategy = "uuid2") private String id; @CreationTimestamp private Date createTime; @UpdateTimestamp private Date updateTime; } ``` ####Repository: BaseRepository ``` public interface BaseRepository<T extends BaseEntity> extends JpaRepository<T,String> {} ``` UserRepository ``` public interface UserRepository extends BaseRepository<User> {} ``` ####Service BaseService ``` public abstract class BaseService<R extends BaseRepository<T>, T extends BaseEntity> { @Resource public R repository; public T selectOne(String id) { return repository.getOne(id); } public List<T> selectListAll() { System.out.println(repository.getClass()); return repository.findAll(); } public void insert(T entity) { repository.save(entity); } public void delete(T entity) { repository.delete(entity); } public void deleteById(String id) { repository.deleteById(id); } } ``` UserService ``` @Service public class UserService extends BaseService<UserRepository, User> { } ``` ####Controller ``` @Slf4j public abstract class BaseController<S extends BaseService,E extends BaseEntity> { @Resource protected S service; @GetMapping public List<E> findAll(){ return service.selectListAll(); } } ``` UserController ``` @RestController @RequestMapping("/user") public class UserController extends BaseController<UserService, User> { } ```
关于抽象 和 接口在java项目结构中的一些问题,有图。
mapper:接口baseMapper(公共接口),接口UserMapper继承baseMapper(其他接口); service:接口baseService(公共接口),接口UserService继承baseService(其他接口); serviceImpl:抽象baseServiceImpl,接口UserServiceImpl 实现 baseService,UserService 今天看到一个JAVA项目结构是这种,所有有点不明白,是否有baseService存在的必要性,如下图 ![图片说明](https://img-ask.csdn.net/upload/201907/14/1563051335_115732.jpg) __________________________________ 以下为2019-7-17作者补充。 经过测试后,结构重新优化,如下图: ![图片说明](https://img-ask.csdn.net/upload/201907/17/1563355451_359451.png) BaseService 为 通用接口; BaseServiceImpl 为BaseService的实现类,BaseServiceImpl定义为抽象类。 UserService 继承了 BaseService 接口,BaseService定义为接口; UserServiceImpl 继承了(extends)BaseServiceImpl,且 implements UserService接口;
SSH项目中,在抽取完baseService后,重新部署,出现以下错误无法解决
![图片说明](https://img-ask.csdn.net/upload/201503/10/1425976839_202121.png) 自己排了一个下午也排不到哪里错,真心求大神 ![图片说明](https://img-ask.csdn.net/upload/201503/10/1425976806_463185.png)
Spring中的bean中的name属性问题
java程序代码 private BaseMapper baseMapper = null; public void setBaseMapper(BaseMapper baseMapper) { this.baseMapper = baseMapper; } Spring中的bean配置 <bean id="baseCityQuery" class="com.service.xukai.BaseService"> <property name="baseMapper" ref="baseMapper" /> </bean> java代码中的baseMapper 一定要和Spring配置中的name值一样吗? 我遇到BaseMapper的变量名写成mapper 即private BaseMapper mapper = null; public void setBaseMapper(BaseMapper mapper) { this.mapper = mapper; } 这样也可以运行呢???求教了。。。
使用maven命令install打包项目提示XXX类不是抽象的
* ArticleCategoryServiceImpl不是抽象的并且未覆盖BaseService中的抽象方法get ![image](http://owiapvokx.bkt.clouddn.com/18-2-8/59236695.jpg) * ArticleCategoryServiceImpl类中的代码如下: ```java @Service("articleCategoryService") public class ArticleCategoryServiceImpl extends BaseServiceImpl<ArticleCategory> implements ArticleCategoryService { @Autowired private ArticleCategoryDao articleCategoryDao; @Override public BaseDao<ArticleCategory> getDao() { return articleCategoryDao; } } ``` * BaseServiceImpl中的代码如下: ```java public abstract class BaseServiceImpl<T> implements BaseService<T> { /** * 抽象方法,必须实现,返回DAO实例 * @return DAO实例 */ public abstract BaseDao<T> getDao(); @Override public int insert(T t) { return getDao().insert(t); } @Override public List<T> getList(T t) { return getDao().getList(t); } @Override public T get(Serializable id) { return getDao().get(id); } } ``` * BaseService中的代码如下: ```java public interface BaseService<T> { public List<T> getList(T t); public T get(Serializable id); } ``` 若是使用idea工具可以build成功,但是会在部署后,通过页面访问接口时会出现以下问题: ![image](http://owiapvokx.bkt.clouddn.com/18-2-8/12458475.jpg) 所以这个问题还是上面ArticleCategoryServiceImpl打包不成功造成的 各位大神,有遇到这个问题的吗,麻烦帮忙看看,谢谢啦!
关于mybatis通用mapper的问题。
项目是maven管理的,用的mybatis+spring,单表的CRUD都需要手写,感觉很麻烦。于是网上找了通用mapper的配置方法。 在POM.XML加入了 <dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper</artifactId> <version>${mapper.version}</version> </dependency> <dependency> <groupId>javax.persistence</groupId> <artifactId>persistence-api</artifactId> <version>1.0</version> </dependency> 这两个包配置。 然后新建了一个基本业务接口 ``` public interface BaseService<T>{ } ``` 基本业务接口的实现类: ``` @Service public abstract class BaseServiceImpl<T> implements BaseService<T> { CrBaseMapper<T> crBaseMapper; @Resource CourseMapper courseMapper; public int add(T entity, boolean insertSelective) { if (insertSelective) { return this.crBaseMapper.insertSelective(entity); } return this.crBaseMapper.insert(entity); } public int delete(T entity) { return this.crBaseMapper.deleteByPrimaryKey(entity); } public int update(T entity, boolean updateSelective) { if (updateSelective) { return this.crBaseMapper.updateByPrimaryKeySelective(entity); } return this.crBaseMapper.updateByPrimaryKey(entity); } public T get(Long pk) { return this.crBaseMapper.selectByPrimaryKey(pk); } public List<T> selectAll() { return this.crBaseMapper.selectAll(); } } ``` 然后就是基本DAO接口: ``` @Repository public abstract interface CrBaseMapper<T> extends Mapper<T> { } ``` 。 最后在applicationContext.xml也进行了如下的配置: ``` <bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.isea533.mybatis.mapper"/> <property name="properties"> <value> mappers=tk.mybatis.mapper.common.Mapper </value> </property> </bean> <context:component-scan base-package="com.insi.cream"/> ``` 是哪里配置有问题吗,为什么启动时候还是提示 Error creating bean with name 'crBaseMapper' defined in file? 求大神解答,感激不仅!!!!~~~~
java编译时发生错误,显示已过时,怎么修改
Information:java: 编译器 (1.8.0_31) 中出现异常错误。 如果在 Bug Parade 中没有找到该错误, 请在 Java Developer Connection (http://java.sun.com/webapps/bugreport) 中建立 Bug。请在报告中附上您的程序和以下诊断信息。谢谢。 Information:java: Errors occurred while compiling module 'framework' Information:javac 1.8.0_31 was used to compile java sources Information:17-6-16 09:59 - Compilation completed with 1 error and 18 warnings in 9s 338ms Error:java: java.lang.AssertionError: isSubClass R E:\JetBrains\framework\src\main\java\com\ng\framework\dao\BaseDao.java Warning:(14, 38) java: com.ng.framework.support.query中的com.ng.framework.support.query.UserDefineContext已过时 E:\JetBrains\framework\src\main\java\com\ng\framework\dao\hb\CriteriaExt.java Warning:(176, 24) java: org.hibernate.Criteria中的createCriteria(java.lang.String,java.lang.String,int,org.hibernate.criterion.Criterion)已过时 Warning:(163, 24) java: org.hibernate.Criteria中的createCriteria(java.lang.String,java.lang.String,int)已过时 Warning:(145, 24) java: org.hibernate.Criteria中的createCriteria(java.lang.String,int)已过时 Warning:(127, 24) java: org.hibernate.Criteria中的createAlias(java.lang.String,java.lang.String,int,org.hibernate.criterion.Criterion)已过时 Warning:(116, 24) java: org.hibernate.Criteria中的createAlias(java.lang.String,java.lang.String,int)已过时 Warning:(128, 15) java: org.hibernate.Criteria中的createAlias(java.lang.String,java.lang.String,int,org.hibernate.criterion.Criterion)已过时 Warning:(146, 15) java: org.hibernate.Criteria中的createCriteria(java.lang.String,int)已过时 Warning:(164, 15) java: org.hibernate.Criteria中的createCriteria(java.lang.String,java.lang.String,int)已过时 Warning:(177, 15) java: org.hibernate.Criteria中的createCriteria(java.lang.String,java.lang.String,int,org.hibernate.criterion.Criterion)已过时 E:\JetBrains\framework\src\main\java\com\ng\framework\dao\OrmProperty.java Warning:(76, 32) java: org.hibernate.metadata.ClassMetadata中的getIdentifier(java.lang.Object)已过时 E:\JetBrains\framework\src\main\java\com\ng\framework\dao\ql\proxy\ProxyFactory.java Warning:(180, 13) java: com.ng.framework.dao.ql.annotation中的com.ng.framework.dao.ql.annotation.Select已过时 Warning:(180, 50) java: com.ng.framework.dao.ql.annotation中的com.ng.framework.dao.ql.annotation.Select已过时 Warning:(201, 13) java: com.ng.framework.dao.ql.annotation中的com.ng.framework.dao.ql.annotation.Update已过时 Warning:(201, 50) java: com.ng.framework.dao.ql.annotation中的com.ng.framework.dao.ql.annotation.Update已过时 E:\JetBrains\framework\src\main\java\com\ng\framework\common\EntityAccessorDelegate.java Warning:(183, 38) java: com.ng.framework.common.EntityAccessor中的queryMapByRequest(com.ng.framework.support.query.QueryRequest)已过时 Warning:(184, 29) java: com.ng.framework.common.EntityAccessor中的queryMapByRequest(com.ng.framework.support.query.QueryRequest)已过时 E:\JetBrains\framework\src\main\java\com\ng\framework\service\BaseService.java Warning:(45, 13) java: com.ng.framework.common.EntityAccessorDelegate中的persist(E)已过时
关于spring+hibernate配置多数据源的问题
我的项目是个webservice项目,使用了hibernate+spring框架,由于项目中要用到两个数据库(都是oracle数据库),我在网上查了一些资料,但是在我的项目中做数据源切换的时候总是切换不过去,也就是说只能连接默认的数据源,一下是我的spring配置文件: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd" default-autowire="byName"> <context:annotation-config /> <!-- AXIS2通过该对象加载spring中的bean 固定配置 --> <bean id="applicationContext" class="org.apache.axis2.extensions.spring.receivers.ApplicationContextHolder" /> <!-- end --> <!-- AXIS2本地业务配置 --> <bean id="PAPWebService" class="com.pap.ws.PAPWebService" /> <!-- end --> <context:component-scan base-package="com.pap"> <context:include-filter type="regex" expression=".dao.impl.*" /> <context:include-filter type="regex" expression=".serviec.impl.*" /> <context:include-filter type="regex" expression=".entity.*" /> </context:component-scan> <bean id="tmsDataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource"> <property name="driver" value="oracle.jdbc.driver.OracleDriver" /> <property name="driverUrl" value="jdbc:oracle:thin:@172.17.30.80:1521:tms" /> <property name="user" value="SELFSERVICE" /> <property name="password" value="Password123" /> <!-- 最大数据库连接数 --> <property name="maximumConnectionCount" value="100" /> <!-- 最小数据库连接数 --> <property name="minimumConnectionCount" value="3" /> <!-- 最少保持的空闲连接数(默认2个) --> <property name="prototypeCount" value="3" /> <!-- 没有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受 --> <!-- <property name="maximumNewConnections" value="20"/> --> <!-- 最大的并发连接数 --> <property name="simultaneousBuildThrottle" value="50" /> <!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁 默认30秒 --> <property name="houseKeepingSleepTime" value="10000" /> <!-- 用于保持连接的测试语句 --> <property name="houseKeepingTestSql" value="select sysdate from dual" /> <!-- 在使用之前测试 --> <property name="testBeforeUse" value="true" /> </bean> <bean id="hisDataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource"> <property name="driver" value="oracle.jdbc.driver.OracleDriver" /> <property name="driverUrl" value="jdbc:oracle:thin:@172.17.1.252:1521:ORCL" /> <property name="user" value="system" /> <property name="password" value="aaaaaa" /> <!-- 最大数据库连接数 --> <property name="maximumConnectionCount" value="100" /> <!-- 最小数据库连接数 --> <property name="minimumConnectionCount" value="3" /> <!-- 最少保持的空闲连接数(默认2个) --> <property name="prototypeCount" value="3" /> <!-- 没有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受 --> <!-- <property name="maximumNewConnections" value="20"/> --> <!-- 最大的并发连接数 --> <property name="simultaneousBuildThrottle" value="50" /> <!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁 默认30秒 --> <property name="houseKeepingSleepTime" value="10000" /> <!-- 用于保持连接的测试语句 --> <property name="houseKeepingTestSql" value="select sysdate from dual" /> <!-- 在使用之前测试 --> <property name="testBeforeUse" value="true" /> </bean> <bean id="dynamicDataSource" class="com.pap.datasource.DynamicDataSource"> <!-- 通过key-value的形式来关联数据源 --> <property name="targetDataSources"> <map key-type="java.lang.String"> <entry value-ref="tmsDataSource" key="tmsDataSource"></entry> <entry value-ref="hisDataSource" key="hisDataSource"></entry> </map> </property> <property name="defaultTargetDataSource" ref="tmsDataSource"> </property> </bean> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> <property name="dataSource" ref="dynamicDataSource" /> <property name="packagesToScan"> <list> <value>com.pap.entity</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!-- <prop key="hibernate.hbm2ddl.auto">update</prop> --> </props> </property> </bean> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <tx:annotation-driven transaction-manager="transactionManager" /> </beans> 下面是我写的两个用于切换数据源的类: DataSourceContextHolder.java package com.pap.datasource; public class DataSourceContextHolder { public static final String DATA_SOURCE_TMS = "tmsDataSource"; public static final String DATA_SOURCE_HIS = "hisDataSource"; private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>(); public static void setDataSourceType(String customerType) { contextHolder.set(customerType); } public static String getDataSourceType() { return contextHolder.get(); } public static void clearDataSourceType() { contextHolder.remove(); } } DynamicDataSource.java package com.pap.datasource; import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource; public class DynamicDataSource extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { return DataSourceContextHolder.getDataSourceType(); } } dao层代码 package com.pap.dao.impl; import java.io.Serializable; import java.util.List; import org.hibernate.criterion.DetachedCriteria; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import org.springframework.stereotype.Repository; import com.pap.dao.BaseDao; @Repository("baseDao") public class BaseDaoImpl extends HibernateDaoSupport implements BaseDao{ @Override public <T> Serializable save(T entity) throws Exception { Serializable s = this.getHibernateTemplate().save(entity); return s; } @Override public <T> void update(T entity) throws Exception { this.getHibernateTemplate().update(entity); } @SuppressWarnings("unchecked") @Override public <T> List<T> query(String hql,Object[] values) throws Exception { return this.getHibernateTemplate().find(hql, values); } @Override public <T> List<T> query(String hql, Object value) throws Exception { return query(hql, new Object[]{value}); } @Override public <T>T getEntity(Class<T> entityClass, Serializable id) throws Exception { return this.getHibernateTemplate().get(entityClass, id); } @SuppressWarnings("unchecked") @Override public <T> List<T> find(DetachedCriteria detachedCriteria, int firstResult, int maxResults) throws Exception { return getHibernateTemplate().findByCriteria(detachedCriteria, firstResult, maxResults); } @Override @SuppressWarnings("unchecked") public <T> List<T> find(DetachedCriteria criteria) throws Exception { return getHibernateTemplate().findByCriteria(criteria); } } service层代码,我是在这里做的数据源切换 package com.pap.service.impl; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.annotation.Resource; import org.hibernate.criterion.DetachedCriteria; import org.hibernate.criterion.Restrictions; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import com.pap.dao.BaseDao; import com.pap.datasource.DataSourceContextHolder; import com.pap.entity.ChargeTypeDict; import com.pap.entity.ClinicForRegist; import com.pap.entity.MedicalCard; import com.pap.entity.Patient; import com.pap.entity.SelfTerminal; import com.pap.entity.TransactionRecord; import com.pap.entity.User; import com.pap.service.BaseService; @Service @Transactional(propagation = Propagation.REQUIRED) public class BaseServiceImpl implements BaseService { @Resource private BaseDao baseDao; /** * 查询排号信息 */ @Override public List<ClinicForRegist> queryClinicForRegist(java.sql.Date clinicDate, Object[] timeDesc, int firstResult, int maxResults) throws Exception { DataSourceContextHolder.setDataSourceType(DataSourceContextHolder.DATA_SOURCE_HIS); DetachedCriteria detachedCriteria = DetachedCriteria.forClass(ClinicForRegist.class); detachedCriteria.add(Restrictions.eq("clinicDate", clinicDate)); detachedCriteria.add(Restrictions.in("timeDesc", timeDesc)); List<ClinicForRegist> list = baseDao.find(detachedCriteria, firstResult, maxResults); DataSourceContextHolder.clearDataSourceType(); return list; } } webservice接口类 package com.pap.ws; import java.sql.Timestamp; import java.util.Calendar; import java.util.Date; import java.util.List; import javax.annotation.Resource; import org.apache.log4j.Logger; import com.pap.entity.ChargeTypeDict; import com.pap.entity.ClinicForRegist; import com.pap.entity.ClinicIndex; import com.pap.entity.DeptDict; import com.pap.entity.MedicalCard; import com.pap.entity.Patient; import com.pap.entity.Privileges; import com.pap.entity.Response; import com.pap.entity.SelfTerminal; import com.pap.entity.TransactionRecord; import com.pap.entity.User; import com.pap.service.BaseService; import com.pap.util.MD5Util; public class PAPWebService { @Resource BaseService baseService; /** * 查询可挂号信息 * @param firstResult 起始条数 * @param maxResults 最大条数 * @return */ public Response queryClinicRegist(int firstResult, int maxResults) { Response response = new Response(); try { Calendar calendar = Calendar.getInstance(); int hour = calendar.get(Calendar.HOUR_OF_DAY); String[] timeDesc = null; if (8 < hour && hour < 12) { timeDesc = new String[] { "白天", "上午", "下午", "昼夜" }; } else if (hour > 11 && hour < 18) { timeDesc = new String[] { "白天", "下午", "昼夜" }; } else { timeDesc = new String[] {"昼夜" }; } List<ClinicForRegist> list = baseService.queryClinicForRegist(new java.sql.Date(calendar.getTimeInMillis()), timeDesc, firstResult, maxResults); if(list.size() > 0){ response.setResult("S"); response.setArrayData(list); }else{ response.setResult("F"); response.setResult("没有查询到记录"); } } catch (Exception e) { e.printStackTrace(); response.setResult("F"); response.setErrorInfo(e.getMessage()); } return response; } public void setClinicForRegist(ClinicForRegist clinicForRegist){ } public void setClinicIndex(ClinicIndex clinicIndex){ } public void setDeptDict(DeptDict deptDict){ } }
菜鸟碰到一个弄不明白的问题,好心人快来帮帮忙!
看代码 package dali.pigfriend.common.interfaces; /** * 数据库信息管理业务接口。 * 数据库信息管理逻辑 * @author Administrator * */ public interface DateManageService { /** * 初始化数据包类属性 * @param datePack */ public void init(PageDatePack datePack); /** * 查找数据 * @param datePack 查询参数封装在该对象中 */ public void search(PageDatePack datePack); /** * 保存数据修改 * @param datePack */ public void save(PageDatePack datePack); } package dali.pigfriend.common.interfaces; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Service; @Service public class BaseService implements DateManageService{ /** * dao类,与数据库交互的dao类 */ @Autowired @Qualifier("baseDao") private DateManageDao datManDao; public DateManageDao getDatManDao() { return datManDao; } public void setDatManDao(DateManageDao datManDao) { this.datManDao = datManDao; } @Override public void init(PageDatePack datePack) { // TODO Auto-generated method stub System.out.println("BaseService.init()"); } @Override public void search(PageDatePack datePack) { // TODO Auto-generated method stub } @Override public void save(PageDatePack datePack) { // TODO Auto-generated method stub } } package dali.pigfriend.backstage.base.action; import org.springframework.beans.factory.annotation.Autowired; import dali.pigfriend.backstage.base.service.MenuManageService; import dali.pigfriend.backstage.base.service.TestService; import dali.pigfriend.common.interfaces.*; public class MenuManageAction extends BaseAction{ /** * */ @Autowired public MenuManageAction(MenuManageService menuManageService){ System.out.println("构造MenuManageAction类++++++++++"); this.setDatManSer(menuManageService); } private static final long serialVersionUID = 1L; @Autowired private TestService testService; @Override public String managePage() { // TODO Auto-generated method stub this.testService.init(); //搞不懂的是下面这行代码,就是它为嘛不调用DateManageService子类的init方法,而是调用父类BaseService的init方法 this.getDatManSer().init(super.getDatePack()); return RESULT_MANAGE_PAGE; } } 通过浏览器请求调用MenuManageAction动作类的managePage。
java.lang.ClassNotFoundException明明有这个
java.lang.ClassNotFoundException: org.apache.http.conn.socket.LayeredConnectionSocketFactory at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1891) at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1734) at com.crux.wxms.service.BaseService.<init>(BaseService.java:29) at com.crux.wxms.service.RefundService.<init>(RefundService.java:8) at com.crux.wxms.controller.wx.WeiXinPayController.refundTest(WeiXinPayController.java:176) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:136) at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:832) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:743) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:961) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:895) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:967) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:858) at javax.servlet.http.HttpServlet.service(HttpServlet.java:624) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:843) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:121) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:218) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:442) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1082) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:623) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Unknown Source)
Controller Service Dao 关系
``` public class UserController extends WAFController<UserService> { } ``` UserController.java ``` public class UserService extends WAFService<UserDAO> { } ``` UserService.java ``` public class UserDAO extends DAOSupport { } ``` UserDAO.java ``` public abstract class WAFController<T extends WAFService<?>> extends BaseController<T> { } ``` WAFController.java ``` public abstract class WAFService<T extends DAOSupport> extends BaseService<T> { } ``` WAFService.java ``` public abstract class BaseController<T extends BaseService<?>> { } ``` BaseController.java ``` public abstract class BaseService<T extends DAOSupport> { } ``` BaseService.java ``` public class DAOSupport implements DAO { } ``` DAOSupport.java ``` public interface DAO { } ``` DAO.java
SSM自动注入servcice失败? 注入和service不为空
Invalid bound statement (not found): com.shanghaidb.real.service.BaseService.checkIp] with root cause 可以进controller 进不去sercice 将serviceimpl中的代码放controller中直接访问mapper 运行ok serviceimpl中有@service注解 为何?
郁闷+头疼!怎么都想不通,怎么就不会调用重写后的方法呢?在线等好心人回答
看代码 package dali.pigfriend.common.interfaces; /** 数据库信息管理业务接口。 数据库信息管理逻辑 @author Administrator * / public interface DateManageService { /* 初始化数据包类属性 @param datePack */ public void init(PageDatePack datePack); /** 查找数据 @param datePack 查询参数封装在该对象中 */ public void search(PageDatePack datePack); /** 保存数据修改 @param datePack */ public void save(PageDatePack datePack); } package dali.pigfriend.common.interfaces; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Service; @Service public class BaseService implements DateManageService{ /** dao类,与数据库交互的dao类 */ @Autowired @Qualifier("baseDao") private DateManageDao datManDao; public DateManageDao getDatManDao() { return datManDao; } public void setDatManDao(DateManageDao datManDao) { this.datManDao = datManDao; } @Override public void init(PageDatePack datePack) { // TODO Auto-generated method stub System.out.println("BaseService.init()"); } @Override public void search(PageDatePack datePack) { // TODO Auto-generated method stub } @Override public void save(PageDatePack datePack) { // TODO Auto-generated method stub } } package dali.pigfriend.backstage.base.action; import org.springframework.beans.factory.annotation.Autowired; import dali.pigfriend.backstage.base.service.MenuManageService; import dali.pigfriend.backstage.base.service.TestService; import dali.pigfriend.common.interfaces.*; public class MenuManageAction extends BaseAction{ /** * */ @Autowired public MenuManageAction(MenuManageService menuManageService){ System.out.println("构造MenuManageAction类++++++++++"); this.setDatManSer(menuManageService); } private static final long serialVersionUID = 1L; @Autowired private TestService testService; @Override public String managePage() { // TODO Auto-generated method stub this.testService.init(); //搞不懂的是下面这行代码,就是它为嘛不调用DateManageService子类的init方法,而是调用父类BaseService的init方法 this.getDatManSer().init(super.getDatePack()); return RESULT_MANAGE_PAGE; } } package dali.pigfriend.backstage.base.service; import org.springframework.stereotype.Service; import dali.pigfriend.backstage.core.*; @Service public class MenuManageService extends BaseService{ public MenuManageService(){ System.out.println("创建MenuManageService实例!"+hashCode()); } @Override public void init(PageDatePack datePack) { // TODO Auto-generated method stub System.out.println("MenuManageService init function"); } } 通过浏览器请求调用MenuManageAction动作类的managePage。 收起
spring.net 泛型配置报错问题
我在一个类里定义了两个泛型对角如下: ``` public class UserController : Controller { // // GET: /User/ BaseService<MDL.User_Test_T> user_test_t { set; get; } BaseService<MDL.Role_Info_T> role_info_t { set; get; } } ``` xml 配置如下: ``` <object type="WebApp.Controllers.UserController, WebApp" singleton="false" > <property name="role_info_t" ref="role_info_t" /> <property name="user_test_t" ref="user_test_t" /> </object> <object name="role_info_t" type="BLL.BaseService&lt;MDL.Role_Info_T>, BLL" singleton="false" > </object> <object name="user_test_t" type="BLL.BaseService&lt;MDL.User_Test_T>, BLL" singleton="false" > </object> ``` 但运行时报对象转换错误 ![图片说明](https://img-ask.csdn.net/upload/201601/05/1451977184_358773.png) 请大神指点
hibernate 手动控制事务回滚失败
spring配置: <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass" value="com.mysql.jdbc.Driver" /> <property name="jdbcUrl" value="jdbc:mysql://192.168.0.124:3306/art8k?useUnicode=true&amp;characterEncoding=utf-8" /> <property name="user" value="root" /> <property name="password" value="123456" /> <property name="initialPoolSize"><value>5</value></property> <property name="minPoolSize"><value>20</value></property> <property name="maxPoolSize"><value>100</value></property> <property name="acquireIncrement"><value>5</value></property> <property name="maxIdleTime"><value>100</value></property> </bean> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="hibernateProperties"> <value> hibernate.dialect=org.hibernate.dialect.MySQLDialect hibernate.show_sql=true hibernate.format_sql=false </value> </property> <property name="packagesToScan" value="com.art8k.platform.*.*.bean"/> </bean> <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes> <tx:method name="get*" read-only="true"/> <tx:method name="find*" read-only="true"/> <tx:method name="list*" read-only="true"/> <tx:method name="*" rollback-for="Exception"/> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="operation" expression="execution(* com.art8k.platform..service.*.*(..))" /> <aop:advisor advice-ref="txAdvice" pointcut-ref="operation" /> </aop:config> <bean id="dao" class="com.art8k.platform.dao.IDaoManager"> <property name="sessionFactory"> <ref bean="sessionFactory"/> </property> </bean> <bean id="baseService" abstract="true" class="com.art8k.platform.service.BaseService"> <property name="dao"> <ref bean="dao"/> </property> </bean> BaseService.java public BaseService() { if (SpringUtil.getWebApplicationContext()!=null && SpringUtil.getWebApplicationContext().getBean("dao") != null) { this.dao = (IDaoManager) SpringUtil.getWebApplicationContext().getBean("dao"); } } /** * 数据库操作 dao */ @SuppressWarnings("unchecked") @Resource protected IDaoManager dao; @SuppressWarnings("unchecked") public void setDao(IDaoManager dao) { this.dao = dao; } @SuppressWarnings("unchecked") public IDaoManager getDao() { return dao; } IDaoManager.java public class IDaoManager<T, P, PK extends Serializable> extends HibernateDaoSupport implements GeneraDAO<T, P, PK> { /** * <p> * 持久化业务逻辑数据对象 ,无返回值 * </p> */ public void saveIObject(final T object) { getHibernateTemplate().save(object); } /** * <p> * 持久化业务逻辑数据对象,新增或者更新 ,无返回值 * </p> * * @param object * T 业务逻辑数据对象 */ public void saveOrUpdateIObject(final T object) { getHibernateTemplate().saveOrUpdate(object); } 我自己的service集成BaseService,我在service里的一个方法内插入两条数据,如果出现异常,把本次对数据库的所有操作回滚,现在问题是回滚失败,代码如下: public int saveProduct(HmProduct hmProduct) { int result = ConstanData.SUCCESSCODE; Session sessions = null; sessions = this.getDao().getHibernateTemplate().getSessionFactory().openSession(); sessions.beginTransaction(); try { sessions.save(hmProduct); HmProductLog hmProductLog = new HmProductLog(); hmProductLog.setProductId(hmProduct.getId()); hmProductLog.setPrice(hmProduct.getPrice()); hmProductLog.setCreateTime(new Date()); sessions.save(hmProductLog); } catch (Exception e) { // TODO Auto-generated catch block sessions.getTransaction().rollback(); result = ConstanData.FAILURECODE; e.printStackTrace(); }finally{ sessions.close(); } return result; }
java 设计之相同业务代码重构问题
最近在做一些代码的重构,就比如代码的冗余来说,比如说有3个service写的代码基本全部相同,就是根据传递的参数type值不同而返回的数据结果不同,这种情况我们该如何去进行代码的抽离,需要进行重新设计,希望大神门给点独特的建议,详细介绍: 就比如这段代码,sort是类型有:1、2、3值,category有:4、5、6值,就是这个sort和category有值传的不同,返回结果不同,不想3个service都写一样的代码,太冗余了。 代码如下: String json = testService.get(param, json,sort); List list = demoService.select(category); ... ... ... 方案:1、我能想到的就是把这代码新建了一个抽象类,3个service去继承他 2、用适配器 3、写一个baseservice类,3个service起引用依赖baseservice。 ps:求大神帮忙,小弟刚用这个csdn,没有币,大家担待下。
Activiti任务监听器调用SSM DAO层
我用jeesite平台想开发一个学生提交作业给老师的工作流,工作流中通过任务监听器动态设置任务执行人(老师)框架是spring +spring mvc+ mybatis + mysql 任务监听器通过实现TaskListener接口的类并通过可视化工具中在老师TASK节点设置了create时调用该类 监听器的代码如下 ``` @Component @Service public class Teacherlisten extends CrudService<StudentToTeacherDao, StudentToT eacher> implements TaskListener{ private String userId; private StudentToTeacher st; private String assignee; private static final long serialVersionUID = 1L; @Override public void notify(DelegateTask delegateTask){ userId = delegateTask.getVariable("apply").toString(); st=dao.findteacher(userId); assignee=st.getTeacher(); delegateTask.setAssignee(assignee); } } ``` 下面为CrudService自动装配DAO的代码 ``` @Transactional(readOnly = true) public abstract class CrudService<D extends CrudDao<T>, T extends DataEntity<T>> extends BaseService { /** * 持久层对象 */ @Autowired protected D dao; ``` 我的设想是通过调用DAO方法访问数据库查询学生对应的老师,然后将执行人设置为该老师,但是遇到的问题是自动装配DAO时 值为NULL,原因可能是监听器与Spring 加载时出问题,已经尝试过很多方法,最后使用JDBC实现的,但是mybatis的框架在这里没用上,希望大神能帮小弟一下,指点一下如何在监听器中能够将Spring与mybatis整合的DAO层引进来。
Mybatis 调用sql server储存过程,有参数,有返回值,得到是个空值
首先是XML 文件 <parameterMap type="java.util.Map" id="testParameterMap"> <parameter property="addend1" jdbcType="VARCHAR" mode="IN"/> <parameter property="addend2" jdbcType="VARCHAR" mode="IN"/> <parameter property="addend3" jdbcType="NUMERIC" mode="IN"/> <parameter property="addend4" jdbcType="NUMERIC" mode="IN"/> <parameter property="addend5" jdbcType="VARCHAR" mode="IN"/> <parameter property="addend6" jdbcType="VARCHAR" mode="IN"/> <parameter property="addend7" jdbcType="VARCHAR" mode="IN"/> <parameter property="sum" jdbcType="VARCHAR" mode="OUT"/> </parameterMap> <select id="procTrainPay" parameterMap="testParameterMap" statementType="CALLABLE" > {call PROC_TRAIN_PAY(?,?,?,?,?,?,?,?)} </select> sql 语句 sql在sql server里面执行成功 得到自己想要的效果 USE [TE_BASE] GO /****** Object: StoredProcedure [dbo].[PROC_TRAIN_PAY] Script Date: 01/30/2015 13:15:12 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER PROCEDURE [dbo].[PROC_TRAIN_PAY]( @OT varchar(300) , @ISSUE VARCHAR(20), @TRAIN NUMERIC, @EXAM NUMERIC, @Billtrain varchar(20),@Billexam varchar(20), @OP13 varchar(20),@PL VARCHAR(30) out ) --@OT是id @ISSUE 期号 @TRAIN 培训金额@EXAM 考试金额 @Billtrain培训发票号 @Billexam考试发票 @OP13收费人 as declare @PointerPrev int declare @PointerCurr int declare @SUUEECE int --记录成功的多少条 declare @SUM int declare @OT00 int --学员培训申请表ID declare @OT08 varchar(100) --学员项目名称 declare @OT02 varchar(20) --学员培训期号 declare @COUNT int --该计划一共有多少学员 declare @OT03 varchar(30) --档案号 declare @OP03 NUMERIC --培训金额 declare @OP09 NUMERIC --考试金额 declare @DATE varchar(10) --获取当前日期 declare @OT031 varchar(20) --记录档案号是否重复 declare @X int --自增数 set @PointerCurr=1 --循环字符串用的 set @SUM=0 set @SUUEECE=0 SET @X=0 BEGIN TRANSACTION BEGIN while(@PointerCurr<LEN(@OT)) BEGIN set @OT08=NULL set @OT02=NULL set @OT03=NULL set @OP03=NULL set @OP09=NULL set @OT031=NULL set @PointerPrev=CHARINDEX('`',@OT,@PointerCurr) --计算出截取的ID set @OT00=CAST(SUBSTRING(@OT,@PointerCurr,@PointerPrev-@PointerCurr) as int) set @PointerCurr=@PointerPrev+1 SELECT @OT08=OT08,@OT02=OT02 FROM OA_STUDENT_TRAIN where OT00=@OT00 if(@ISSUE IS NOT NULL) BEGIN SET @OT02=@ISSUE end if(@OT08 IS NULL or @OT02 IS NULL) begin rollback --事物回滚 SET @PL = 'N' return end --获取这期培训多少人,生产档案号 SELECT @COUNT= COUNT(OT03) FROM OA_STUDENT_TRAIN where ot02 = @OT02 and (OT03 IS NOT NULL or OT03 != '')--查询出已经有学员档案号的学员 --生出学员档案号 SET @OT03=@OT02+'000'+@COUNT+@X SET @X=@X+1 --查询次学员的档案号是否重复 SELECT @OT031=OT03 FROM OA_STUDENT_TRAIN WHERE OT03=@OT03 if(@OT031 IS NOT NULL) begin rollback --事物回滚 print '事物回滚了' SET @PL = 'N' return end --培训期号 档案号 向学员报名里面插入 declare @sql varchar(MAX) SET @sql='update OA_STUDENT_TRAIN set OT02='+@OT02+', OT03='+@OT03+' where OT00='+cast(@OT00 as varchar) exec(@sql) SET @SUM=@@error+@SUM --取出这个作业项目的收费标准 SELECT @OP03=OS03,@OP09=OS07 FROM OA_FEE_SCALE WHERE OS06=@OT08 select @DATE=convert(varchar(10),getdate(),120) if(@OP09 IS NULL OR @OP03 IS NULL) begin rollback --事物回滚 SET @PL = 'N' return end --金额 if(@TRAIN=0 or @TRAIN is NULL) begin set @OP03=@TRAIN end if(@EXAM = 0 or @EXAM is NULL ) begin set @OP09=@EXAM end --插入学员缴费记录 insert into OA_STUDENT_PAY(OP01,OP02,OP04,OP03,OP06,OP07,OP09,OP05,OP13) values( @OT03,'现金',@DATE,@OP03,@Billtrain,@Billexam,@OP09,@OT08,@OP13) SET @SUM=@@error+@SUM END if(@SUM>0) begin rollback--事物回滚 SET @PL = 'N' return end else begin COMMIT --事物提交 SET @PL ='Y' end END return @SUUEECE 这个是我的DAO层 @Transactional public Map<String,Object> procTrainPay(Map <String,Object> map){ return baseMapper.procTrainPay(map); } 这个是我调用的dao Map<String,Object> map= new HashMap<String,Object>(); map.put("addend1",str[x]+"`" ); map.put("addend2",studentPay.getOp02() ); map.put("addend3",studentPay.getOp03() ); map.put("addend4",studentPay.getOp09() ); map.put("addend5",studentPay.getOp07() ); map.put("addend6",studentPay.getOp08() ); map.put("addend7",user.getSu01() ); Map <String,Object>mapl=baseService.procTrainPay(map); System.out.println(mapl.get("sum")); 执行的结果是空指针。 mapl得到的是一个空值, procTrainPay方法执行没报错。 这里是我sql返回值写错了?还是我的xml配置写错?
相见恨晚的超实用网站
搞学习 知乎: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就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
深深的码丨Java HashMap 透析
HashMap 相关概念 HashTab、HashMap、TreeMap 均以键值对像是存储或操作数据元素。HashTab继承自Dictionary,HashMap、TreeMap继承自AbstractMap,三者均实现Map接口 **HashTab:**同步哈希表,不支持null键或值,因为同步导致性能影响,很少被使用 **HashMap:**应用较多的非同步哈希表,支持null键或值,是键值对...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 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)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
JDK12 Collectors.teeing 你真的需要了解一下
前言 在 Java 12 里面有个非常好用但在官方 JEP 没有公布的功能,因为它只是 Collector 中的一个小改动,它的作用是 merge 两个 collector 的结果,这句话显得很抽象,老规矩,我们先来看个图(这真是一个不和谐的图????): 管道改造经常会用这个小东西,通常我们叫它「三通」,它的主要作用就是将 downstream1 和 downstre...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的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...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问