前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[快速解析JSON字符串的方法 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
转载文章
...显示的文件属性第一个字符‘-‘表示这是一个普通文件,第二个字段表示权限,第三个字段表示链接数,第四个字段表示所有者,第五个字段表示所属组,第六个字段表示文件大小,第七个字段表示时间,第八个地段表示文件名。 实例2 ls -a 查看包含以 . 开始的隐藏文件与目录信息 显示隐藏文件 实例3 ls-lh 以易读的格式显示文件的大小 以人性化更清晰的显示文件 实例4 ls– i 显示文件或目录的inode(i节点)编号 i节点可以看作是一个指向磁盘上该文件存储区的地址 四、touch 命令 touch命令可创建一个文件或者更改文件时间 实例1 touch a.txt 创建一个a.txt文件 一开始使用ls命令查看当前目录显示没有文件,然后使用touch命令创建了一个a.txt文件 实例2更改a.txt的时间 可以看到文件名没有改变,只有时间改变了 五、mkdir命令 mkdir命令可以创建一个目录 命令格式: mkdir 【选项】【文件名】 命令选项参数: -p : 递归创建目录 -v : 创建新目录显示信息 实例1 mkdir abc 创建一个空目录 实例2 mkdir -p test/test1 递归创建多个目录 实例3 mkdir-v hao 创建新目录显示信息 六、cp 命令 cp命令用来对一个或多个文件,目录进行拷贝 命令格式: cp【选项】【参数】 命令选项 -r 递归的复制子文件或子目录 -a 复制时保留源文档的所有属性(包括权限、时间等) 实例1 cp -a a.txt test 复制a.txt的所有属性复制到test 实例2 cp -r text /opt 复制text下的所有子文件到opt下 七、rm 命令 rm命令可以删除不需要的文件或者目录 命令格式 rm 【选项】【文件】 选项:-i 删除前,提示是否删除 -f 不提示,强制删除-r 递归删除,删除目录以及目录下的所有内容 实例1 rm -i a.txt删除a.txt 并显示提示 实例2 rm -f text 强制删除text 实例3 rm -r test 递归删除test下所有子文件 实例4 rm -rf hao 递归强制删除文件 八、mv命令 mv命令用来移动或者重命名文件或目录 实例1 mv a.txt b.txt 将a.txt改名为b.txt 实例2 mv b.txt /opt 将b.txt 移动到opt下 九、 find 命令 find命令用来搜索文件或目录 命令格式: find 【命令选项】【路径】【表达式选项】 命令选项: -empty 查找空白文件或目录 -group 按组查找 -name 按文档名称查找 -iname 按文档名称查找,且不区分大小写 -mtime 按修改时间查找 -size 按容量大小查找 -type 按文档类型查找,文件(f),目录(d),设备(b,c),链接(l)等 -user 按用户查找 -exec 对找到的档案执行特定的命令 -a 并且 -o 或者 查找当前目录下所有的普通文件 find ./ -type f 查找大于1mb的文件后列出文件的详细信息‘ find ./ -size +1M -exec ls – l {} ; 查找计算机中所有大于1mb的文件 find / -size +1M -a -type f 查找当前目录下名为hello.doc 的文档 find -name hello.doc 查找/root目录下所有名称以.log 结尾的文档 十、du命令 用来计算文件或目录的容量大小 命令格式: du 【选项】 【文件或目录】 命令选项: -h 人性化显示容量信息 -a 查看所有目录以及文件的容量信息 -s 仅显示总容量 实例1 du -h /opt 实例2 du -a /opt 实例3 du -s /opt 2.1.2查看文件内容 一、 cat 命令 cat命令用来查看文件内容 命令格式: cat 【选项】 【文件】 选项命令 -b 显示行号,空白行不显示行号 -n 显示行号,包含空白行 实例1. cat /opt/test 查看test里面的内容 实例2.cat -n /opt/test 显示行号 二、more命令和less命令 more命令可以分页查看文件内容,通过空格键查看下一页,q键则退出查看。 less命令也可以分页查看文件内容,空格是下一页,方向键可以上下翻页,q键退出查看 命令格式: more 【文件名】 用来查看指定文件 more -num 【文件名】 可以指定显示行数 less 【文件名】 查看指定文件 三、head 命令 head 命令可以查看文件头部内容,默认显示前10行 命令格式 head -6 【文件名】 显示的是文件前6行 head -n -6 【文件名】 显示除了最后6行最后的行 head -c 10 【文件名】显示前十个字节的数据 四、tail 命令 tail命令用来查看文件尾部内容,默认显示后10行 命令格式: tail -6 【文件名】 显示最后6行 tail -f 【文件名】即时显示文件中新写入的行 五、wc 命令 wc命令用来显示文件的行、单词与字节统计信息 命令格式: wc 【选项】【文件】 选项: -c 显示文件字节统计信息 -l 显示文件行数统计信息 -w 显示文件单词统计信息 实例1 依次显示文件的行数,单词数,字节数 实例2 使用-c选项显示文件的字节信息 实例3 使用-l 选项显示文件行数 实例4 使用-w选项显示文件单词个数 六、grep命令 grep命令用来查找关键字并打印匹配的值 命令格式: grep【选项】 匹配模式【文件】 选项: -i 查找时忽略大小写 -v 取反匹配 -w 匹配单词 –color 显示颜色 实例1 在test文件中过滤出包含a的行 实例2 过滤不包含a关键词的行 七、echo 命令 echo命令用来输出显示一行指定的字符串 实例1 显示一行普通的字符串 实例2 显示转义字符使用-e选项 本篇文章为转载内容。原文链接:https://blog.csdn.net/Zenian_dada/article/details/88669234。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-06-16 19:29:49
512
转载
转载文章
...tsx 调用初始化方法,获取讲话对象engine = pyttsx.init()engine.say('加油!努力吧少年')engine.runAndWait() 使用 SAPI 在 python 中,你也可以使用 SAPI 来做文本到语音的转换。 【示例】使用 SAPI 实现文本转换语音 from win32com.client import Dispatch 获取讲话对象speaker = Dispatch('SAPI.SpVoice') 讲话内容speaker.Speak('猪哥猪哥,你真了不起')speaker.Speak('YL美吗?')speaker.Speak('ZS说她美吖') 释放对象del speaker 使用 SpeechLib 使用 SpeechLib,可以从文本文件中获取输入,再将其转换为语音。先使用 pip 安装, 命令如下: pip install comtypes 【示例】使用 SpeechLib 实现文本转换语音 from comtypes.client import CreateObjectfrom comtypes.gen import SpeechLib 获取语音对象,源头engine = CreateObject('SAPI.SpVoice') 输出到目标对象的流stream = CreateObject('SAPI.SpFileStream')infile = 'demo.txt'outfile = 'demo_audio.wav' 获取流写入通道stream.open(outfile, SpeechLib.SSFMCreateForWrite) 给语音源头添加输出流engine.AudioOutputStream = stream 读取文本内容 打开文件f = open(infile, 'r', encoding='utf-8') 读取文本内容theText = f.read() 关闭流对象f.close() 语音对象,读取文本内容engine.speak(theText)stream.close() 语音转换为文本 使用 PocketSphinx PocketSphinx 是一个用于语音转换文本的开源 API。它是一个轻量级的语音识别引擎, 尽管在桌面端也能很好地工作,它还专门为手机和移动设备做过调优。首先使用 pip 命令安装所需模块,命令如下: pip install PocketSphinxpip install SpeechRecognition 下载地址:https://pypi.org/project/SpeechRecognition/ 下载缓慢推荐您使用第三方通道下载 pip install -i https://mirrors.aliyun.com/pypi/simple 模块名 【示例】使用 PocketSphinx 实现语音转换文本 import speech_recognition as sr 获取语音文件audio_file = 'demo_audio.wav' 获取识别语音内容的对象r = sr.Recognizer() 打开语音文件with sr.AudioFile(audio_file) as source:audio = r.record(source) 将语音转化为文本 print('文本内容:', r.recognize_sphinx(audio)) recognize_sphinx() 参数中language='en-US' 默认是英语print('文本内容:', r.recognize_sphinx(audio, language='zh-CN')) 普通话识别问题 speech_recognition 默认识别英文,是不支持中文的,需要在Sphinx语音识别工具包里面下载对应的 普通话包 和 语言模型 。 安装步骤: 下 载 地 址:https://sourceforge.net/projects/cmusphinx/files/Acoustic%20and%20Language%20Models/ 点击 Mandarin下载cmusphinx-zh-cn-5.2.tar.gz并解压. 在python安装目录下找到Lib\site-packages\speech_recognition 点击进入pocketsphinx-data文件夹,会看到一个en-US文件夹,再新建文件夹zh-CN 在这个文件夹中添加进入刚刚解压的文件,需要注意:把解压出来的zh_cn.cd_cont_5000文件夹重命名为acoustic-model、zh_cn.lm.bin命名为language-model.lm.bin、zh_cn.dic中dic改为dict格式。即与en-US文件夹中命名一样。 参考:https://blog.csdn.net/qq_32643313/article/details/99936268 致以感谢 后序 浅显的学习语音识别,不足之处甚多,深究后,将更新文章。 感谢跟随老师的代码在未知领域里探索,希望我能走的更高更远 本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_46092061/article/details/113945654。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-01-27 19:34:15
279
转载
SpringBoot
...t可以为我们提供一个快速构建Web应用的基础框架,而Maven则可以帮助我们管理项目的依赖关系。 3. 创建SpringBoot项目 接下来,我们可以开始创建我们的SpringBoot项目。首先,打开命令行工具,并进入你要存放项目的位置。然后,输入以下命令来创建一个新的SpringBoot项目: bash mvn archetype:generate -DgroupId=com.example -DartifactId=springboot-mongoapp -DarchetypeArtifactId= spring-boot-starter-parent -DinteractiveMode=false 这行命令的意思是使用Maven的archetype功能来生成一个新的SpringBoot项目,该项目的组ID为com.example, artifactID为springboot-mongoapp,父依赖为spring-boot-starter-parent。这个命令会自动为你创建好所有的项目文件和目录结构,包括pom.xml和src/main/java/com/example/springbootmongoapp等文件。 4. 配置SpringBoot和MongoDB 在创建好项目之后,我们需要进行一些配置工作。首先,我们需要在pom.xml文件中添加SpringDataMongoDB的依赖: xml org.springframework.boot spring-boot-starter-data-mongodb 这行代码的意思是我们需要使用SpringDataMongoDB来处理MongoDB的相关操作。然后,我们需要在application.properties文件中添加MongoDB的连接信息: properties spring.data.mongodb.uri=mongodb://localhost:27017/mydb 这行代码的意思是我们的MongoDB服务器位于本地主机的27017端口上,且数据库名为mydb。 5. 使用MongoTemplate操作MongoDB 在配置完成后,我们就可以开始使用MongoTemplate来操作MongoDB了。MongoTemplate是SpringDataMongoDB提供的一个类,它可以帮助我们执行各种数据库操作。下面是一些基本的操作示例: java @Autowired private MongoTemplate mongoTemplate; public void insert(String collectionName, String id, Object entity) { mongoTemplate.insert(entity, collectionName); } public List find(String collectionName, Query query) { return mongoTemplate.find(query, Object.class, collectionName); } 6. 使用Repository操作MongoDB 除了MongoTemplate之外,SpringDataMongoDB还提供了Repository接口,它可以帮助我们更加方便地进行数据库操作。我们完全可以把这个接口“继承”下来,然后自己动手编写几个核心的方法,就像是插入数据、查找信息、更新记录、删除项目这些基本操作,让它们各司其职,活跃在我们的程序里。下面是一个简单的示例: java @Repository public interface UserRepository extends MongoRepository { User findByUsername(String username); void deleteByUsername(String username); default void save(User user) { if (user.getId() == null) { user.setId(UUID.randomUUID().toString()); } super.save(user); } @Query(value = "{'username':?0}") List findByUsername(String username); } 7. 总结 总的来说,SpringBoot与MongoDB的集成是非常简单和便捷的。只需要几步简单的配置,我们就可以使用SpringBoot的强大功能来操作MongoDB。而且你知道吗,SpringDataMongoDB这家伙还藏着不少好东西嘞,像数据映射、查询、聚合这些高级功能,全都是它的拿手好戏。这样一来,我们开发应用程序就能又快又高效,简直像是插上了小翅膀一样飞速前进!所以,如果你正在琢磨着用NoSQL数据库来搭建你的数据存储方案,那我真心实意地拍胸脯推荐你试试SpringBoot配上MongoDB这个黄金组合,准保不会让你失望!
2023-04-09 13:34:32
78
岁月如歌-t
Apache Lucene
...近,随着互联网技术的快速发展,越来越多的企业和机构开始重视大数据处理和搜索性能的优化。特别是在电子商务、社交媒体和金融行业,海量数据的实时检索变得越来越关键。在此背景下,Apache Lucene作为一款开源全文搜索引擎库,其在高并发环境下的表现备受关注。近期,一篇关于“如何利用Apache Solr和Lucene优化电商平台搜索性能”的文章引起了广泛关注。Solr是基于Lucene的一个分布式搜索平台,它在电商搜索场景中展现了强大的优势。 文章指出,通过合理配置Solr的并发控制策略,如使用“软提交”和“硬提交”相结合的方法,可以显著提升搜索响应速度。此外,Solr还支持分布式搜索,可以在多台服务器上分片存储索引,从而实现横向扩展,有效应对高并发访问的压力。在实际应用中,某知名电商平台通过引入Solr和优化索引并发控制策略,实现了搜索响应时间缩短30%以上,用户体验得到了明显提升。 除了技术层面的优化,该文章还强调了运维管理和系统监控的重要性。例如,通过Prometheus和Grafana构建监控体系,可以实时跟踪Solr集群的状态,及时发现潜在问题并进行调优。同时,定期进行性能测试和压力测试,也是确保系统稳定运行的关键步骤。 总之,随着企业对数据处理能力的要求不断提高,Apache Lucene及其相关技术的应用前景十分广阔。通过不断优化并发控制策略和运维管理,可以显著提升系统的搜索性能和用户体验,为企业创造更大的商业价值。
2024-11-03 16:12:51
116
笑傲江湖
Superset
...元素进行展示和传达的方法,使用户能够更直观、高效地理解数据间的关联、趋势和模式。在Superset中,数据可视化是其核心功能之一,它支持多种图表类型,并允许用户自定义仪表盘,以拼图形式灵活构建数据故事。 云原生架构 , 云原生架构是一种专为云环境设计的应用程序开发和部署方式,强调微服务、容器化、持续集成/持续部署(CI/CD)等技术实践。Superset在升级过程中强化与云原生架构的兼容性,意味着它能更好地适应分布式、弹性伸缩的云环境,提供更加稳定、高效的服务。 全局过滤器 , 全局过滤器是Superset中的一项交互功能,允许用户在一个统一的位置设置筛选条件,进而影响整个仪表盘上所有关联的数据图表。这意味着用户可以快速调整视角,从不同维度探索数据,提高数据分析的效率和深度。 自然语言处理(NLP)查询功能 , 自然语言处理是计算机科学领域的一个分支,用于理解和生成人类语言。在BI工具如Tableau和Power BI中应用的NLP查询功能,则是指用户可以通过输入日常对话式的语句来查询和分析数据,降低非技术人员使用数据可视化工具的技术门槛,实现更为人性化和便捷的数据交互体验。 WCAG 2.1标准 , WCAG(Web Content Accessibility Guidelines,网页内容可访问性指南)是由万维网联盟(W3C)制定的一系列指导原则,旨在确保残障人士也能无障碍地访问和使用网络内容。WCAG 2.1是其最新版本,对包括移动设备在内的各类互联网产品提出了更高的无障碍设计要求,微软等公司在BI工具中努力遵循这一标准,目的是让视力障碍、行动不便等各种特殊需求的用户群体都能够平等地获取和利用数据可视化工具提供的信息。
2023-09-02 09:45:15
150
蝶舞花间
转载文章
...度匹配的实际问题中,快速傅里叶变换(FFT)展现出了其强大的优化能力。通过巧妙地将问题转化为求解序列卷积的最大值,我们可以借助FFT技术将原本可能需要O(n^2)时间复杂度的运算降低至O(nlogn),从而高效找到最优解。实际上,FFT的应用远不止于此,它在信号处理、图像处理、数据压缩等领域都有着广泛而深入的应用。 近日,在科学计算领域,《自然》杂志报道了一项利用FFT算法优化能源传输网络的研究成果。科研团队成功运用FFT分析了电网中各个节点间的电力波动情况,通过对大量实时数据进行快速卷积计算,精准预测并优化了电能分配策略,极大地提高了能源传输效率和稳定性,这再次验证了FFT在实际工程问题中的强大作用。 此外,深度学习领域的研究者也在探索如何结合FFT与卷积神经网络(CNN),以提升模型训练速度和推理效率。一项发表于《IEEE Transactions on Neural Networks and Learning Systems》的论文中,研究人员创新性地提出了一种基于FFT的卷积操作方法,可以显著减少CNN中的计算量,尤其在处理大规模图像识别任务时效果尤为明显。 总的来说,从日常生活中的情侣手环亮度调整问题到关乎国计民生的能源传输优化,再到前沿的人工智能技术突破,快速傅里叶变换始终以其独特的数学魅力和高效的计算性能发挥着关键作用。随着科学技术的发展,我们有理由相信FFT将在更多领域带来革命性的解决方案。
2023-01-20 17:51:37
525
转载
转载文章
...rame的align方法,它返回的是一个元组,含有两个对象的重索引版本: 另一个不可或缺的功能是,通过一组索引可能不同的Series构建一个DataFrame。 跟前面一样,这里也可以显式定义结果的索引(丢弃其余的数据): 时间和“最当前”数据选取 假设你有一个很长的盘中市场数据时间序列,现在希望抽取其中每天特定时间的价格数据。如果数据不规整(观测值没有精确地落在期望的时间点上),该怎么办?在实际工作当中,如果不够小心仔细的话,很容易导致错误的数据规整化。看看下面这个例子: 利用Python的datetime.time对象进行索引即可抽取出这些时间点上的值: 实际上,该操作用到了实例方法at_time(各时间序列以及类似的DataFrame对象都有): 还有一个between_time方法,它用于选取两个Time对象之间的值: 正如之前提到的那样,可能刚好就没有任何数据落在某个具体的时间上(比如上午10点)。这时,你可能会希望得到上午10点之前最后出现的那个值: 如果将一组Timestamp传入asof方法,就能得到这些时间点处(或其之前最近)的有效值(非NA)。例如,我们构造一个日期范围(每天上午10点),然后将其传入asof: 拼接多个数据源 在金融或经济领域中,还有几个经常出现的合并两个相关数据集的情况: ·在一个特定的时间点上,从一个数据源切换到另一个数据源。 ·用另一个时间序列对当前时间序列中的缺失值“打补丁”。 ·将数据中的符号(国家、资产代码等)替换为实际数据。 第一种情况:其实就是用pandas.concat将两个TimeSeries或DataFrame对象合并到一起: 其他:假设data1缺失了data2中存在的某个时间序列: combine_first可以引入合并点之前的数据,这样也就扩展了‘d’项的历史: DataFrame也有一个类似的方法update,它可以实现就地更新。如果只想填充空洞,则必须传入overwrite=False才行: 上面所讲的这些技术都可实现将数据中的符号替换为实际数据,但有时利用DataFrame的索引机制直接对列进行设置会更简单一些: 收益指数和累计收益 在金融领域中,收益(return)通常指的是某资产价格的百分比变化。一般计算两个时间点之间的累计百分比回报只需计算价格的百分比变化即可:对于其他那些派发股息的股票,要计算你在某只股票上赚了多少钱就比较复杂了。不过,这里所使用的已调整收盘价已经对拆分和股息做出了调整。不管什么样的情况,通常都会先算出一个收益指数,它是一个表示单位投资(比如1美元)收益的时间序列。 从收益指数中可以得出许多假设。例如,人们可以决定是否进行利润再投资。我们可以利用cumprod计算出一个简单的收益指数: 得到收益指数之后,计算指定时期内的累计收益就很简单了: 当然了,就这个简单的例子而言(没有股息也没有其他需要考虑的调整),上面的结果也能通过重采样聚合(这里聚合为时期)从日百分比变化中计算得出: 如果知道了股息的派发日和支付率,就可以将它们计入到每日总收益中,如下所示: 本篇文章为转载内容。原文链接:https://blog.csdn.net/geerniya/article/details/80534324。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-12-16 19:15:59
324
转载
MyBatis
...的项目更加稳定可靠的方法。今天,我要给大家讲一个小故事,关于一个因为事务隔离级别设置不当而闹出的笑话。事情是这样的,在用MyBatis框架开发的时候,因为对事务隔离级别的理解不够深入,结果搞得自己的操作影响到了别人的事务,真是忙中出乱啊。希望通过这个故事,能够帮助你更好地理解和使用MyBatis中的事务管理。 1. 事务的基本概念 在开始我们的故事之前,让我们先来了解一下什么是事务。嘿,你知道吗?所谓的事务就是一系列的数据库操作,就像一串动作连贯的舞蹈一样,要么这整套动作都完美完成,要么就干脆一个都不做,这样就能保证数据一直保持整齐和准确啦!在很多人同时用一个系统的时候,事务处理得好不好特别关键,因为这关系到系统的稳定不稳,还有数据对不对得准。 2. 事务隔离级别的定义 在数据库中,事务隔离级别是用来控制多个事务并发执行时的行为。不同的隔离级别就像是给每个事务戴上了不同厚度的“眼镜”。有的眼镜让你能看到别人改了啥,有的则让你啥也看不见,只能看到自己改的东西。这样就能控制一个事务能看到另一个事务做了哪些数据修改,以及这些修改对它来说是不是看得见。常见的隔离级别包括: - 读未提交(Read Uncommitted):最低级别,允许一个事务看到另一个事务未提交的数据。 - 读已提交(Read Committed):标准的SQL隔离级别,保证一个事务只能看到另一个事务提交后的数据。 - 可重复读(Repeatable Read):保证在一个事务内多次读取同一数据的结果是一致的,即使其他事务对这些数据进行了更新。 - 串行化(Serializable):最高的隔离级别,它确保所有事务按顺序执行,避免了幻读问题。 3. 设置不当的事务隔离级别 现在,让我们进入正题——当事务隔离级别设置不当会带来什么后果。想象一下,你正在打造一个超级好用的网购平台,里面有个超赞的功能——就是让用户可以把心仪的商品随便往购物车里扔,就跟平时逛超市一样爽!为了保证大家用起来顺心,而且数据别出岔子,在用户往购物车里加东西的时候,得确保其他用户的操作不会搞出乱子。 但是,如果我们在MyBatis的配置文件中设置了不恰当的事务隔离级别,比如说将隔离级别设为Read Uncommitted,那么就可能会遇到一些预料之外的问题。比如说,有个人正打算把东西加到购物车里,结果这时候另一个人正在更新商品信息,而且这更新还没完呢。这时候,第一个用户可能会发现购物车里多了不该有的东西,或者是商品数量莫名其妙增加了,这样一来,数据就乱套了。 4. 如何正确设置事务隔离级别 为了避免上述问题的发生,我们应该根据具体的应用场景选择合适的事务隔离级别。对于大多数Web应用来说,推荐使用Read Committed作为默认的隔离级别。这个隔离级别刚刚好,既能确保数据一致,又不会拖系统并发性能的后腿。 下面,我将通过一个简单的MyBatis配置示例来展示如何设置事务隔离级别: xml 在这个配置中,我们通过标签指定了事务隔离级别为READ_COMMITTED。这样一来,就算你应用里的并发事务多到像是菜市场一样热闹,数据依然能稳得跟老牛一样,不会乱套。 5. 结语 通过今天的分享,我希望你已经对MyBatis中的事务隔离级别有了更深的理解,并且学会了如何正确设置它们来避免潜在的问题。记得啊,在搞数据库操作的时候,给事务隔离级别整得合适特别重要,这样能让咱们的系统变得更稳当、更靠谱。当然啦,这只是一个开始嘛。等你对MyBatis和数据库事务机制越来越熟悉之后,你就会发现更多的窍门来提升系统的性能和保证数据的一致性了。希望你在未来的编程旅程中不断进步,享受每一次技术探索的乐趣! --- 以上就是我为你准备的文章。如果你有任何疑问或想要了解更多关于MyBatis的知识,请随时告诉我!
2024-11-12 16:08:06
33
烟雨江南
Beego
...接池是一个非常有效的方法,可以帮助我们提高数据库的性能。不过呢,咱们也得不断地摸索和捣鼓,才能找到那个最适合自家数据库的连接池配置。就像是找鞋子一样,不试穿几双,怎么能知道哪一双穿起来最合脚、最舒服呢?所以,对于数据库连接池的配置,咱也得慢慢尝试、逐步调整,才能找到最佳的那个“黄金比例”。同时,我们也应该注意保持良好的编程习惯,避免产生无谓的资源浪费。希望这篇内容能实实在在帮到你,让你更溜地掌握和运用Beego框架下的数据库连接池,让数据操作变得更顺手、更高效。
2023-12-11 18:28:55
528
岁月静好-t
Kotlin
...init属性的使用方法、常见错误及其解决方案,帮助你更好地理解和利用这一特性。 1. 什么是Lateinit Property? lateinit是一个预定义的关键字,在Kotlin中用于声明一个属性,该属性可以在类外部被初始化,但必须在使用之前完成初始化。这意味着当你声明一个lateinit属性时,你承诺在代码执行过程中会调用其对应的初始化方法。哎呀,这个特性啊,它主要用在那些要到执行的时候才知道具体数值的玩意儿上头,或者在编程那会儿还不清楚确切数值咋整的情况。就像是你准备做饭,但到底加多少盐,得尝了味道再定,对吧?或者是你去超市买东西,但预算还没算好,得看商品价格了再做决定。这特性就跟那个差不多,灵活应变,随情况调整。 2. 示例代码 如何使用Lateinit Property? 首先,我们来看一个简单的例子,演示如何在类中声明并使用lateinit属性: kotlin class DataProcessor { lateinit var data: String fun loadData() { // 假设在这里从网络或其他源加载数据 data = "Processed Data" } } fun main() { val processor = DataProcessor() processor.loadData() println(processor.data) // 输出:Processed Data } 在这个例子中,data属性被声明为lateinit。这意味着在main函数中创建DataProcessor实例后,我们不能立即访问data属性,而是必须先调用loadData方法来初始化它。一旦初始化,就可以安全地访问和使用data属性了。 3. 使用Lateinit Property的注意事项 虽然lateinit属性提供了很大的灵活性,但在使用时也需要注意几个关键点: - 必须在使用前初始化:这是最基础的要求。如果你尝试在未初始化的状态下访问或使用lateinit属性,编译器会抛出IllegalStateException异常。 - 不可提前初始化:一旦lateinit属性被初始化,就不能再次修改其值。尝试这样做会导致运行时错误。 - 性能考量:虽然lateinit属性可以延迟初始化,但它可能会增加应用的启动时间和内存消耗,特别是在大量对象实例化时。 4. 遇到“Lateinit Property Not Initialized Before Use”错误怎么办? 当遇到这个错误时,通常意味着你试图访问或使用了一个未初始化的lateinit属性。解决这个问题的方法通常是: - 检查初始化逻辑:确保在使用属性之前,确实调用了对应的初始化方法或进行了必要的操作。 - 代码重构:如果可能,将属性的初始化逻辑移至更合适的位置,比如构造函数、特定方法或事件处理程序中。 - 避免不必要的延迟初始化:考虑是否真的需要延迟初始化,有时候提前初始化可能更为合理和高效。 5. 实践中的应用案例 在实际项目中,lateinit属性特别适用于依赖于用户输入、网络请求或文件读取等不确定因素的数据加载场景。例如,在构建一个基于用户选择的配置文件加载器时: kotlin class ConfigLoader { lateinit var config: Map fun loadConfig() { // 假设这里通过网络或文件系统加载配置 config = loadFromDisk() } } fun main() { val loader = ConfigLoader() loader.loadConfig() println(loader.config) // 此时config已初始化 } 在这个例子中,config属性的加载逻辑被封装在loadConfig方法中,确保在使用config之前,其已经被正确初始化。 结论 lateinit属性是Kotlin中一个强大而灵活的特性,它允许你推迟属性的初始化直到运行时。然而,正确使用这一特性需要谨慎考虑其潜在的性能影响和错误情况。通过理解其工作原理和最佳实践,你可以有效地利用lateinit属性来增强你的Kotlin代码,使其更加健壮和易于维护。
2024-08-23 15:40:12
95
幽谷听泉
转载文章
...ke内置函数,即模式字符串替换函数。 oname函数实现的功能是: 将第一个参数中符合%.s模式的替换成%.o 再继续将上述结果中符合%.c模式的替换成%.o 也就是把所有 .s 和 .c文件名替换成 .o文件名。 这个函数的功能就是计算源文件名(c源文件,汇编源文件)所相对应的目标文件名(经过编译汇编后的文件)。 CONTIKI_OBJECTFILES = ${addprefix $(OBJECTDIR)/,${call oname, $(CONTIKI_SOURCEFILES)} }PROJECT_OBJECTFILES = ${addprefix $(OBJECTDIR)/,${call oname, $(PROJECT_SOURCEFILES)} } 定义CONTIKI_OBJECTFILES变量 首先用oname函数,将CONTIKI_SOURCEFILES所对应的源文件名,改为目标文件名,如process.c将会变为process.o 再在文件名前边加上前缀$(OBJECTDIR)/,前边我们知道这个变量为obj_native,故process.c会变为obj_native/process.o 这个变量应该是代表即将生成的Contiki操作系统的目标文件名 定义PROJECT_OBJECTFILES变量 功能同上 这个变量应该是代表即将生成的项目中的目标文件名 PROJECT_SOURCEFILES这个变量为空,所以PROJECT_OBJECTFILES也为空。 Provide way to create $(OBJECTDIR) if it has been removed by make clean$(OBJECTDIR):mkdir $@ $@是自动化变量,表示规则中的目标文件集。我们知道OBJECTDIR为obj_native,所以$@为obj_native。 mkdir $@生成obj_native目录。 但是这个依赖关系链,怎么会涉及到obj_native的? 调试了一下: 在生成CONTIKI_OBJECTFILES所代表的文件时,目录不存在,会先找依赖关系生成目录,再生成具体文件。 所以mkdir obj_native会被执行。 (2) ifdef APPSAPPDS = ${wildcard ${foreach DIR, $(APPDIRS), ${addprefix $(DIR)/, $(APPS)} }} \${wildcard ${addprefix $(CONTIKI)/apps/, $(APPS)} \${addprefix $(CONTIKI)/platform/$(TARGET)/apps/, $(APPS)} \$(APPS)}APPINCLUDES = ${foreach APP, $(APPS), ${wildcard ${foreach DIR, $(APPDS), $(DIR)/Makefile.$(APP)} }}-include $(APPINCLUDES)APP_SOURCES = ${foreach APP, $(APPS), $($(APP)_src)}DSC_SOURCES = ${foreach APP, $(APPS), $($(APP)_dsc)}CONTIKI_SOURCEFILES += $(APP_SOURCES) $(DSC_SOURCES)endif The project's makefile can also define in the APPS variable a list of applications from the apps/ directory that should be included in the Contiki system. hello-world这个例子没有定义APPS变量,故这段不会执行。 我们假设定义了APPS变量,其值为APPS += antelope unit-test。 相关知识点: wildcard函数: 返回所有符合pattern的文件名,以空格隔开。 $(wildcard pattern) The argument pattern is a file name pattern, typically containing wildcard characters (as in shell file name patterns). The result of wildcard is a space-separated list of the names of existing files that match the pattern. foreach函数: The syntax of the foreach function is: $(foreach var,list,text) The first two arguments, var and list, are expanded before anything else is done; note that the last argument, text, is not expanded at the same time. Then for each word of the expanded value of list, the variable named by the expanded value of var is set to that word, and text is expanded. Presumably text contains references to that variable, so its expansion will be different each time. The result is that text is expanded as many times as there are whitespace-separated words in list. The multiple expansions of text are concatenated, with spaces between them, to make the result of foreach. 每次从list中取出一个词(空格分隔),赋给var变量,然后text(一般有var变量)被拓展开来。 只要list中还有空格分隔符就会一直循环下去,每一次text返回的结果都会以空格分隔开。 ${wildcard ${foreach DIR, $(APPDIRS), ${addprefix $(DIR)/, $(APPS)} }} 先分析${foreach DIR, $(APPDIRS), ${addprefix $(DIR)/, $(APPS)} } 其中DIR是变量(var),$(APPDIRS)是列表(list),这个例子中没有定义APPDIRS这个变量,估计是用于定义除了$CONTIKI/apps/之外的apps目录。 ${addprefix $(DIR)/, $(APPS)}是text。我们假设定义了APPDIRS为a b。 那么第一次:DIR 会被赋值为a,${addprefix $(DIR)/, $(APPS)},又我们假定APPS为antelope unit-test,所以最终会被拓展为a/antelope a/unit-test。 DIR 会被赋值为b,${addprefix $(DIR)/, $(APPS)},又我们假定APPS为antelope unit-test,所以最终会被拓展为b/antelope b/unit-test。 最终这两次结果会以空格分隔开,即a/antelope a/unit-test b/antelope b/unit-test ${wildcard a/antelope a/unit-test b/antelope b/unit-test} 返回空,因为找不到符合这样的目录。 所以最终这句语句,实现的功能是,返回$APPDIRS目录中,所有符合$APPS的目录。 ${wildcard ${addprefix $(CONTIKI)/apps/, $(APPS)} 这句语句返回$(CONTIKI)/apps/目录下所有符合$APPS的目录,即contiki-release-2-7/apps/antelope contiki-release-2-7/apps/unit-test ${addprefix $(CONTIKI)/platform/$(TARGET)/apps/, $(APPS)} 这句语句返回$(CONTIKI)/platform/$(TARGET)/apps/目录下所有$APPS的目录,即contiki-release-2-7/platform/native/apps/antelope contiki-release-2-7/platform/native/apps/unit-test。 在contiki-release-2-7/platform/native目录下,并没有apps目录,后边有差错处理机制。 $(APPS) 在当前目录下的所有$APPS目录,即antelope unit-test。 在hello-world例子中,并没有这些目录。 所以APPDS变量是包含所有与$APPS有关的目录。 APPINCLUDES变量是所有需要导入的APP Makefile文件。 在所有APPDS目录下,所有Makefile.$(APPS)文件。 在我们的假设条件APPS = antelope unit-test, APPDIRS = 只会导入contiki-release-2-7/apps/antelope/Makefile.antelope contiki-release-2-7/apps/unit-test/Makefile.unit-test 其余的均不存在,所以在include指令前要有符号-,即出错继续执行后续指令。 contiki-release-2-7/apps/antelope/Makefile.antelope: 分别定义了两个变量,antelope_src用于保存antelope这个app的src文件,antelope_dsc用于保存antelope这个app的dsc文件。 contiki-release-2-7/apps/unit-test/Makefile.unit-test: 分别定义了两个变量,unit-test_src用于保存unit-test这个app的src文件,unit-tes_dsc用于保存unit-test这个app的dsc文件。 变量APP_SOURCES APP_SOURCES = ${foreach APP, $(APPS), $($(APP)_src)} 取出所有APPS中的src文件变量,这个例子是$(antelope_src) 和$(unit-test_src) 变量APP_SOURCES DSC_SOURCES = ${foreach APP, $(APPS), $($(APP)_dsc)} 取出所有APPS中的dsc文件变量,这个例子是$(antelope_dsc) 和$(unit-test_dsc) CONTIKI_SOURCEFILES += $(APP_SOURCES) $(DSC_SOURCES) 这段话的最终目的: 将$APPS相关的所有源文件添加进CONTIKI_SOURCEFILES变量中。 (3) target_makefile := $(wildcard $(CONTIKI)/platform/$(TARGET)/Makefile.$(TARGET) ${foreach TDIR, $(TARGETDIRS), $(TDIR)/$(TARGET)/Makefile.$(TARGET)}) Check if the target makefile exists, and create the object directory if necessary.ifeq ($(strip $(target_makefile)),)${error The target platform "$(TARGET)" does not exist (maybe it was misspelled?)}elseifneq (1, ${words $(target_makefile)})${error More than one TARGET Makefile found: $(target_makefile)}endifinclude $(target_makefile)endif 这断代码主要做的就是,找到在所有TAGET目录下找到符合的Makefile.$(TARGET)文件,放到target_makefile变量中。 再检查是否存在或者重复。并做相应的错误提示信息。 ${error The target platform "$(TARGET)" does not exist (maybe it was misspelled?)} ${error More than one TARGET Makefile found: $(target_makefile)} 我们这个例子中 TARGET = native 并且 TARGETDIRS为空 所以最后会导入$(CONTIKI)/platform/native/Makefile.native 接下去要开始分析target和cpu的makefile文件了。 转载于:https://www.cnblogs.com/songdechiu/p/6012718.html 本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_34399060/article/details/94095820。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-03-28 09:49:23
283
转载
转载文章
... Boot应用时可以快速集成特定功能。例如,在本文中,我们创建了一个名为“db-count-starter”的自定义Starter,它包含了自动统计Repository实例数量的功能,并且通过自动装配机制无缝融入Spring Boot应用。 自动装配 (Auto-Configuration) , 在Spring Boot框架中,自动装配是一种能够根据项目类路径中的类自动配置Bean的行为。当Spring Boot应用启动时,会扫描项目的类路径并查找META-INF/spring.factories文件中的自动配置类列表。这些配置类通常使用@Configuration注解,它们会依据项目已有的依赖及配置信息来自动创建、配置和注入Bean。在本文中,我们通过实现DbCountAutoConfiguration类实现了对DbCountRunner的自动装配。 CommandLineRunner , CommandLineRunner是Spring Boot提供的一个接口,任何实现该接口的类在Spring Boot应用启动完成后都会运行其run(String... args)方法。这使得开发者可以在应用启动后执行一些初始化或一次性任务。在本例中,我们创建了DbCountRunner类来实现CommandLineRunner接口,以便在Spring Boot应用启动时收集所有Repository实例的数量并打印出来。
2023-02-10 20:49:04
270
转载
MyBatis
...供了所有数据库操作的方法。SqlSessionFactory 和 SqlSession 的关系如下图所示:  当我们在应用程序中创建一个 SqlSessionFactory 对象时,它会自动打开一个数据库连接,并将其保存在内存中。这样,每次我们想要创建一个 SqlSession 对象时,就像去 SqlSessionFactory 那儿说“嗨,给我开个数据库连接”,然后它就会从内存这个大口袋里掏出一个已经为我们预先打开的数据库连接。这种方式能够显著缩短创建和释放数据库连接所需的时间,让咱们的应用程序跑得更溜、更快。 二、MyBatis 如何处理数据库连接的打开与关闭 在 MyBatis 中,我们可以使用两种方式来处理数据库连接的打开与关闭。一种是手动管理,另一种是自动管理。 1. 手动管理 手动管理是指我们在应用程序中直接控制数据库连接的打开与关闭。这是最原始的方式,也是最直观的方式。我们可以通过 JDBC API 来实现数据库连接的打开与关闭。比如,我们可以想象一下这样操作:先用 DriverManager.getConnection() 这个神奇的小功能打开通往数据库的大门,然后呢,当我们不需要再跟数据库“交流”的时候,就用 Statement.close() 或 PreparedStatement.close() 这两个小工具把门关上,这样一来,我们就完成了数据库连接的开启和关闭啦。这种方式的好处就是超级灵活,就像你定制专属T恤一样,我们可以根据应用程序的独特需求,随心所欲地调整数据库连接的表现,让它更听话、更好使。缺点是工作量大,容易出错,而且无法充分利用数据库连接池的优势。 2. 自动管理 自动管理是指 MyBatis 在内部自动管理数据库连接的打开与关闭。这种方式的优点是可以避免手动管理数据库连接的繁琐工作,提高应用程序的性能。不过呢,这种方式有个小缺憾,就是不够灵活,咱们没法随心所欲地掌控数据库连接的具体表现。另外,想象一下这个场景哈,如果我们开发的小程序里,好几个线程兄弟同时挤进去访问数据库的话,就很可能碰上并发问题这个小麻烦。 三、MyBatis 的自动管理机制 为了实现自动管理,MyBatis 提供了一个名为“StatementExecutor”的类,它负责处理 SQL 查询请求。StatementExecutor 使用一个名为“PreparedStatementCache”的缓存来存储预编译的 SQL 查询语句。每当一个新的 SQL 查询请求到来时,StatementExecutor 就会在 PreparedStatementCache 中查找是否有一个匹配的预编译的 SQL 查询语句。如果有,就直接使用这个预编译的 SQL 查询语句来执行查询请求;如果没有,就先使用 JDBC API 来编译 SQL 查询语句,然后再执行查询请求。在这个过程中,StatementExecutor 将会自动打开和关闭数据库连接。当StatementExecutor辛辛苦苦执行完一个SQL查询请求后,它会像个聪明的小助手那样,主动判断一下是否有必要把这个SQL查询语句存放到PreparedStatementCache这个小仓库里。当SQL查询语句被执行的次数蹭蹭蹭地超过了某个限定值时,StatementExecutor这个小机灵鬼就会把SQL查询语句悄悄塞进PreparedStatementCache这个“备忘录”里头,这样一来,下次再遇到同样的查询需求,咱们就可以直接从“备忘录”里拿出来用,省时又省力。 四、总结 总的来说,MyBatis 是一个强大的持久层框架,它可以方便地管理数据库连接,提高应用程序的性能。然而,在使用 MyBatis 时,我们也需要注意一些问题。首先,我们应该合理使用数据库连接,避免长时间占用数据库连接。其次,我强烈建议大家伙尽可能多用 PreparedStatement 类型的 SQL 查询语句,为啥呢?因为它比 Statement 那种类型的 SQL 查询语句可安全多了。就像是给你的查询语句戴上了防护口罩,能有效防止SQL注入这类安全隐患,让数据处理更稳当、更保险。最后,我强烈推荐你们在处理预编译的 SQL 查询语句时,用上 PreparedStatementCache 这种缓存技术。为啥呢?因为它能超级有效地提升咱应用程序的运行速度和性能,让整个系统更加流畅、响应更快,就像给程序装上了涡轮增压器一样。
2023-01-11 12:49:37
99
冬日暖阳_t
Apache Lucene
...本自动摘要则帮助我们快速把握文档的核心内容,两者结合,简直不要太酷! 2. Apache Lucene简介 走进全文检索的世界 首先,我们得了解一下Apache Lucene。这货是个用Java写的开源全文搜索神器,索引能力超强,搜东西快得飞起!Lucene的核心功能包括创建索引、存储索引以及执行复杂的查询等。简单来说,Lucene就是你进行全文检索时的超级助手。 代码示例: java // 创建索引目录 Directory directory = FSDirectory.open(Paths.get("/path/to/index")); // 创建索引写入器 IndexWriterConfig config = new IndexWriterConfig(new StandardAnalyzer()); IndexWriter indexWriter = new IndexWriter(directory, config); // 添加文档到索引 Document doc = new Document(); doc.add(new TextField("content", "这是文档的内容", Field.Store.YES)); indexWriter.addDocument(doc); indexWriter.close(); 这段代码展示了如何利用Lucene创建索引并添加文档的基本步骤。这里用了TextField来存文档内容,这样一来,搜索起来就灵活多了,想找啥就找啥。 3. 全文检索中的文本自动摘要 为什么我们需要它? 文本自动摘要是指通过算法自动生成文档摘要的过程。这不仅有助于提高阅读效率,还能有效节省时间。想象一下,如果你能在搜索引擎里输入关键词后,直接看到每篇文章的重点内容,那该有多爽啊!在Lucene里实现这个功能,就意味着我们能让信息的处理和展示变得更聪明、更贴心。 思考过程: 当我们处理大量文本时,手动编写摘要显然是不现实的。因此,开发一种自动化的方法就显得尤为重要了。这不仅仅是技术上的挑战,更是提升用户体验的关键所在。 4. 实现文本自动摘要 策略与技巧 实现文本自动摘要主要涉及两个方面:选择合适的摘要生成算法,以及如何将这些算法集成到Lucene中。 摘要生成算法: - TF-IDF:一种统计方法,用来评估一个词在一个文档或语料库中的重要程度。 - TextRank:基于PageRank算法的思想,用于提取文本中的关键句子。 代码示例(使用TextRank): java import com.huaban.analysis.jieba.JiebaSegmenter; import com.huaban.analysis.jieba.SegToken; public class TextRankSummary { private static final int MAX_SENTENCE = 5; // 最大句子数 public static String generateSummary(String text) { JiebaSegmenter segmenter = new JiebaSegmenter(); List segResult = segmenter.process(text, JiebaSegmenter.SegMode.INDEX); // 这里简化处理,实际应用中需要构建图结构并计算TextRank值 return "这是生成的摘要,简化处理..."; // 真实实现需根据具体算法调整 } } 注意:上述代码仅作为示例,实际应用中需要完整实现TextRank算法逻辑,并将其与Lucene的搜索结果结合。 5. 集成到Lucene 让摘要成为搜索的一部分 为了让摘要功能更加实用,我们需要将其整合到现有的搜索流程中。这就意味着每当用户搜东西的时候,除了给出相关的资料,还得给他们一个简单易懂的内容概要,这样他们才能更快知道这些资料是不是自己想要的。 代码示例: java public class LuceneSearchWithSummary { public static void main(String[] args) throws IOException { Directory directory = FSDirectory.open(Paths.get("/path/to/index")); IndexReader reader = DirectoryReader.open(directory); IndexSearcher searcher = new IndexSearcher(reader); QueryParser parser = new QueryParser("content", new StandardAnalyzer()); Query query = parser.parse("搜索关键词"); TopDocs topDocs = searcher.search(query, 10); for (ScoreDoc scoreDoc : topDocs.scoreDocs) { Document doc = searcher.doc(scoreDoc.doc); System.out.println("文档标题:" + doc.get("title")); System.out.println("文档内容摘要:" + TextRankSummary.generateSummary(doc.get("content"))); } reader.close(); directory.close(); } } 这段代码展示了如何在搜索结果中加入文本摘要的功能。每次搜索时,都会调用TextRankSummary.generateSummary()方法生成文档摘要,并显示给用户。 6. 结论 展望未来,无限可能 通过本文的学习,相信你已经掌握了在Lucene中实现全文检索文本自动摘要的基本思路和技术。当然,这只是开始,随着技术的发展,我们还有更多的可能性去探索。无论是优化算法性能,还是提升用户体验,都值得我们不断努力。让我们一起迎接这个充满机遇的时代吧! --- 希望这篇文章对你有所帮助,如果有任何问题或想了解更多细节,请随时联系我!
2024-11-13 16:23:47
87
夜色朦胧
转载文章
...。那么解决这个问题的方法就是负反馈。下载完了检查一遍就好了。 由于google patent下载的文件是以公开号命名的,所以对照要下载的和已下载的公开号就能看出哪些专利没有下载成功。 我这里写了一个python小脚本。 import pandas as pdimport os读取待下载专利的公开号,地址修改成你自己存放的位置df = pd.read_excel("target.xlsx",header= 0, usecols= "B").drop_duplicates()取前11位作为对比(以中国专利作为参考)PublicNumber_tgt = list(map(lambda x: x[0:11],df["公开(公告)号"].to_list()))读取已下载专利的公开号,地址修改成你自己存放的位置filelist=os.listdir(r'C:\Users\mornthx\Desktop\专利全文')取前11位作为对比PublicNumber_dl = list(map(lambda x: x[0:11],filelist))比较两者差值diff = set(PublicNumber_tgt).difference(set(PublicNumber_dl))print(diff) 没下载的专利具体问题具体解决就好了。 希望能帮到大家! 本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_38688347/article/details/124000919。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-11-21 12:55:28
275
转载
Flink
...一个Socket接收字符串数据,将其转换为大写,并打印结果。这里的source和transformed就是构成JobGraph的一部分。 2. ExecutionPlan 通往高效执行的道路 接下来,我们来看看ExecutionPlan。当你的JobGraph准备好之后,Flink会根据它生成一个ExecutionPlan。这个计划详细说明了怎么在集群上同时跑数据流,包括怎么安排任务、分配资源之类的。 为什么ExecutionPlan至关重要? - 性能优化:ExecutionPlan考虑到了各种因素(如网络延迟、机器负载等)来优化任务的执行效率,确保数据流能够快速准确地流动。 - 容错机制:通过合理的任务划分和错误恢复策略,ExecutionPlan可以保证即使在某些节点失败的情况下,整个系统也能稳定运行。 示例代码: 虽然ExecutionPlan本身并不直接提供给用户进行编程操作,但你可以通过配置参数来影响它的生成。例如: java env.setParallelism(4); // 设置并行度为4 这条语句会影响ExecutionPlan中任务的并行执行方式。更高的并行度通常能让吞吐量变得更好,但同时也可能会让网络通信变得更复杂,增加不少额外的工作量。 3. 探索背后的秘密 JobGraph与ExecutionPlan的互动 现在,让我们思考一下JobGraph和ExecutionPlan之间的关系。可以说,JobGraph是ExecutionPlan的基础,没有一个清晰的JobGraph,就无法生成有效的ExecutionPlan。ExecutionPlan就是JobGraph的具体操作指南,它告诉你怎么把这些抽象的想法变成实实在在的计算任务。 思考与探讨: - 在设计你的Flink应用程序时,是否考虑过JobGraph的结构对最终性能的影响? - 你有没有尝试过调整ExecutionPlan的某些参数来提升应用程序的效率? 4. 实践中的挑战与解决方案 最后,我想分享一些我在使用Flink过程中遇到的实际问题及解决方案。 问题1:数据倾斜导致性能瓶颈 - 原因分析:数据分布不均匀可能导致某些算子处理的数据量远大于其他算子,从而形成性能瓶颈。 - 解决办法:可以通过重新设计JobGraph,比如引入更多的分区策略或调整算子的并行度来缓解这个问题。 问题2:内存溢出 - 原因分析:长时间运行的任务可能会消耗大量内存,尤其是在处理大数据集时。 - 解决办法:合理设置Flink的内存管理策略,比如增加JVM堆内存或利用Flink的内存管理API来控制内存使用。 --- 好了,朋友们,这就是我对Flink中的JobGraph和ExecutionPlan的理解和分享。希望这篇文章能让你深深体会到它们的价值,然后在你的项目里大展身手,随意挥洒!如果你有任何疑问或者想要进一步讨论的话题,欢迎随时留言交流! 记住,学习技术就像一场旅行,重要的是享受过程,不断探索未知的领域。希望我们在数据流的世界里都能成为勇敢的探险家!
2024-11-05 16:08:03
113
雪落无痕
转载文章
...。或许你也会对下面的方法比较熟悉$t->set_file $t->set_var 当我对于phplib的执行效率不满意的时候,我开始寻找下一个PHP的模板引擎,于是smarty跳入我的视野范围,当我费尽心血去学会了smarty并使用开发了很多东西,而现在的我突然发现记得的也就只有下面的方法了$s->assign $s->display 究竟我们需要模板引擎来做什么呢,MVC?简单?易用?效率?请看下文的分析。 二、程序处理的分析 1.PHPLIB的程序处理过程 从phplib的处理开始讲起$t = new Template() $t->set_file $t->set_var $t->parse $t->p 看上面的代码,翻译成中文就是初始化模板类$t 设置模板文件 设置模板变量 分析模板文件中的模板变量 输出内容 通过了最少5个步骤在php程序中实现模板的处理 2.Smarty的程序处理过程 现在来看smarty的处理$s = new Smarty $s->assign $s->display 翻译成中文就是初始化模板类$s 设置模板变量 解析并输出模板 3.Discuz!模板的程序处理过程include template(tplname); 主要作用就是指定给程序需要处理的模板文件 在上述三种模板处理机制中,最容易理解和接受就是Discuz!模板的处理过程。初始化、设置变量、解析模板、输出内容,Discuz!只用了一个函数来做。对于一个开源的论坛软件,这样处理的好处是显而易见的,对于Discuz!进行二次开发的程序员的要求降低。简化模板语言,方便风格和插件的制作,这也在一定程度上促进了Discuz!的传播 三、模板源文件的语法 在phplib中处理循环嵌套的时候,使用: {it} 在smarty中处理循环嵌套的时候,引入了< {section name=loopName loop=$loopArray}>(当然还有foreach这样的) 在Discuz!中处理循环嵌套的时候, 其实真正的模板面对的可以说是不懂PHP或者懂一点PHP的美工同志们,模板的复杂就意味着美工制作页面的难度加大。在必不可少的需要模板有逻辑处理的时候,为什么不在html代码中使用原生态的PHP语法,而让美工相当于去学习另外一种语言呢?在我个人的经验中,显然是Discuz!的模板语言更为简单易学,也为我节省了更多的时间。 四、Discuz!模板处理机制 我剥离出一个简单的Discuz!模板处理函数function template($file, $templateid = 0, $tpldir = '') { $tplfile = DISCUZ_ROOT.'./'.$tpldir.'/'.$file.'.htm';//模板源文件,此处$tplfile变量的值可能是D:\discuz\templates\default\demo.htm $objfile = DISCUZ_ROOT.'./forumdata/templates/'. $templateid.'_'.$file.'.tpl.php';//模板缓存文件,此处$objfile变量的值可能是D:\discuz\forumdata\templates\1_demo.tpl.php //如果模板源文件的修改时间迟于模板缓存文件的修改时间, //就是模板源文件被修改而模板缓存没有更新的时候, //则调用parse_template函数重新生成模板缓存文件。 if(@filemtime($tplfile) > @filemtime($objfile)) { require_once DISCUZ_ROOT.'./include/template.func.php'; parse_template($file, $templateid, $tpldir); } //返回缓存文件名称 //$objfile变量内容可能为D:\discuz\forumdata\templates\1_demo.tpl.php return $objfile; } 而php页面的模板执行语句include template('demo'); 实际上在本例中就是相当于include 'D:\discuz\forumdata\templates\1_demo.tpl.php'; 这个流程就是一个demo.php文件中当数据处理完成以后include template('demo'),去显示页面。 五、总结 我也曾经看到过有列举出很多种的PHP模板引擎,但是我觉着phplib、smarty、Discuz!模板机制就足以说明问题了。 1.我们需要模板来做什么? 分离程序与界面,为程序开发以及后期维护提供方便。 2.我们还在关心什么? PHP模板引擎的效率,易用性,可维护性。 3.最后的要求什么? 简单就是美! 我的文章好像没有写完,其实已经写完了,我要说明的就是从PHP的模板引擎看Discuz!模板机制。分析已经完成,或许以后我会再写篇实际数据的测试供给大家参考! Tags: none 版权声明:原创作品,欢迎转载,转载时请务必以超链接形式标明文章原始地址、作者信息和本声明。 本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_42557656/article/details/115159292。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-10-07 14:43:46
109
转载
SpringCloud
...了用实例代码给你细细解析,还会手把手教你如何对症下药,给出相应的解决办法。 二、Spring Cloud Gateway异常概述 1. 路由匹配异常 在配置路由规则时,若规则设置不正确或者请求无法匹配到任何路由,Gateway会抛出异常。比方说,就像这样的情形:假如客户端向我们发送了一个请求,但是呢,在咱们的gateway路由配置里头,我们还没给这个请求对应的路径或者服务名设定好,这时候,这种问题就有可能冒出来啦。 java @Bean public RouteLocator customRouteLocator(RouteLocatorBuilder builder) { // 假设这里没有配置"/api/user"的路由,那么请求该路径就会出现404异常 return builder.routes() .route("product-service", r -> r.path("/api/product").uri("lb://PRODUCT-SERVICE")) .build(); } 2. 过滤器异常 Spring Cloud Gateway支持自定义过滤器,若过滤器内部逻辑错误或资源不足等,也可能引发异常。比如在开发权限校验过滤器的时候,假如咱们的验证逻辑不小心出了点小差错,就可能会让本来正常的请求被误判、给挡在外面了。 java @Component public class AuthFilter implements GlobalFilter, Ordered { @Override public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) { // 假设这里的token解析或校验过程出现问题 String token = exchange.getRequest().getHeaders().getFirst("Authorization"); // ...省略校验逻辑... if (isValidToken(token)) { return chain.filter(exchange); } else { // 若返回错误信息时处理不当,可能导致异常 return exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED).buildMono(); } } // ... } 三、异常排查与解决策略 1. 路由匹配异常 : - 排查方法:首先检查路由配置是否正确且完整,确保所有接口都有对应的路由规则。 - 解决方案:添加或修复缺失或错误的路由规则。 2. 过滤器异常 : - 排查方法:通过日志定位到具体哪个过滤器报错,然后审查过滤器内部逻辑。对于自定义过滤器,应重点检查业务逻辑和资源管理部分。 - 解决方案:修复过滤器内部的逻辑错误,保证过滤器能够正确执行并返回预期结果。同时呢,千万记得要做好应对突发状况的工作,就像在过滤器里头万一出了岔子,咱们得确保能给客户端一个明明白白的反馈信息,而不是啥也不说就直接把异常抛出去,让请求咔嚓一下就断掉了。 四、总结与思考 面对Spring Cloud Gateway的异常情况,我们需要具备敏锐的问题洞察力和严谨的排查手段。每一个异常背后都可能是架构设计、资源配置、代码实现等方面的疏漏。所以呢,咱们在日常敲代码的时候,不仅要死磕代码质量,还得把Spring Cloud Gateway的运作机理摸得门儿清。这样一来,当问题突然冒出来的时候,就能快速找到“病灶”,手到病除地解决它。这样子,我们的微服务架构才能真正硬气起来,随时准备好迎接那些复杂多变、让人头疼的业务场景和挑战。 在实际开发中,每一次异常处理的过程都是我们深化技术认知,提升解决问题能力的良好契机。让我们一起在实战中不断积累经验,让Spring Cloud Gateway更好地服务于我们的微服务架构。
2023-07-06 09:47:52
97
晚秋落叶_
NodeJS
...引擎,用于在浏览器中解析、编译和执行JavaScript代码。在Node.js中,V8引擎被用作其运行环境的核心部分,将JavaScript代码转换为机器码,实现高性能的服务器端JavaScript应用。 无服务器架构(Serverless Architecture) , 在本文语境下,无服务器架构是一种云计算模型,其中开发者无需关注底层服务器的运维管理,只需编写和上传业务逻辑代码至服务提供商如AWS Lambda。在这种模式下,平台会自动管理和扩展计算资源,按需执行代码并仅对实际使用的计算资源计费。 实时通信应用 , 实时通信应用是指能够实现实时数据交换和互动的应用程序,如在线聊天室、协同编辑文档工具等。这类应用通常依赖于WebSocket、Socket.IO等技术,以确保信息能够近乎实时地在客户端与服务器之间双向传输。 RESTful API , RESTful API是一种基于HTTP协议,遵循Representational State Transfer(表述性状态转移)设计原则构建的应用程序接口。它通过HTTP方法(GET、POST、PUT、DELETE等)来操作资源,并且具有统一接口格式,便于不同系统之间的数据交互。 AWS Lambda , AWS Lambda是Amazon Web Services提供的无服务器计算服务。用户可以在Lambda上部署和执行代码片段(函数),而无需预置或管理服务器。Lambda根据触发器(如API调用、文件上传等事件)自动执行代码,并按实际执行时间计费,从而实现高度可扩展性和成本效益。 npm , npm(Node Package Manager)是Node.js的包管理器,提供了便捷的方式来安装、共享和更新Node.js模块。开发者可以通过npm从全球最大的开源JavaScript软件库下载第三方代码包,以便在自己的项目中复用他人开发的功能组件,极大地提高了开发效率。
2024-01-24 17:58:24
147
青春印记-t
转载文章
...它,进入 main 方法,执行完所有的方法,也就会退出了 我们写的代码就是通过 Handler 驱动起来的,我们 Activity 的 onCreate、onResume、onStop 等等这些生命周期方法,包括我们的 UI 绘制的信号,这些UI绘制的事件都是通过 Handler Looper 循环内部发起的,来调用回调我们的各个 Activity,各个 Fragment 等等这样的一些组件里面的各个生命周期方法,我们的代码就是在循环里面执行的,所以不会阻塞 简述 Handler 的实现原理 Android 应用是通过消息驱动运行的,在 Android 中一切皆消息,包括触摸事件,视图的绘制、显示和刷新等等都是消息 Handler 是消息机制的上层接口,平时开发中我们只会接触到 Handler 和 Message,内部还有 MessageQueue 和 Looper 两大助手共同实现消息循环系统。 延迟消息是怎么实现的? 无论是即时消息还是延迟消息,都是计算出具体的时间,然后作为消息的 when 字段进程赋值 在 MessageQueue 中找到合适的位置(安排 when 小到大排列),并将消息插入到 MessageQueue 中;这样, MessageQueue 就是一个按照消息时间排列的一个链表结构 为什么 Handler 会报内存泄漏? 因为是内部类持有外部类的对象, sendMessage 的时候会调用到 Handler 的 enqueueMessage 方法,msg.target = this; Message 会持有 handler,而 handler 持有调用 handler 的对象,所以 gc 不能回收 Binder 篇 Binder 的定向制导,如何找到目标 Binder,唤起进程或者线程呢? Binder 实体服务其实有两种: 一是通过 addService 注册到 ServiceManager 中的服务,比如 ActivityManagerService、PackageManagerService、PowerManagerService 等,一般都是系统服务; 还有一种是通过 bindService 拉起的一些服务,一般是开发者自己实现的服务 这里先看通过 addService 添加的被 ServiceManager 所管理的服务 ServiceManager 是比较特殊的服务,所有应用都能直接使用,因为 ServiceManager 对于 Client 端来说 Handle 句柄是固定的,都是 0,所以 ServiceManager 服务并不需要查询,可以直接使用 Binder 为什么会有两棵 binder_ref 红黑树? Binder_proc 中存在两棵 binder_ref 红黑树,其实两棵红黑树中的节点是复用的,只是查询方式不同,一个通过 Handle 句柄,一个通过 node 节点查找 refs_by_node 红黑树主要是为了 Binder驱动往用户空间写数据所使用的,而 refs_by_desc 是用户空间向 Binder 驱动写数据使用的,只是方向问题 比如在服务 addService 的时候,binder 驱动会在在 ServiceManager 进程的 binder_proc 中查找 binder_ref 结构体 Binder 是如何做到一次拷贝的 用户空间的虚拟内存地址是映射到物理内存中的 对虚拟内存的读写实际上是对物理内存的读写,这个过程就是内存映射 这个内存映射过程是通过系统调用 mmap() 来实现的 Binder借助了内存映射的方法,在内核空间和接收方用户空间的数据缓存区之间做了一层内存映射,就相当于直接拷贝到了接收方用户空间的数据缓存区,从而减少了一次数据拷贝 Binder机制是如何跨进程的 在内核空间创建一块接收缓存区, 实现地址映射:将内核缓存区、接收进程用户空间映射到同一接收缓存区 发送进程通过系统调用(copy_from_user)将数据发送到内核缓存区;由于内核缓存区和接收进程用户空间存在映射关系,故相当于也发送了接收进程的用户空间,实现了跨进程通信 就举例这么多了,面试题也不是几个就能全部覆盖的,毕竟面试官不是吃素的,他会换着花样问你;有想跳槽拿高薪的 Android 开发的朋友,我这里分享一份 Handler、Binder 精选面试 PDF 文档;私信发送 “面试” 直达获取;想拿高薪的人很多,就看你肯不肯努力了 面试题 PDF 文档内容展示: Handler 机制之 Thread Handler 机制之 ThreadLocal Handler 机制之 SystemClock 类 Handler 机制之 Looper 与 Handler 简介 Android 跨进程通信 IPC 之 Binder 之 Framewor k层 C++ 篇 Android 跨进程通信 IPC 之 Binder 之 Framework 层 Java 篇 Android 跨进程通信 IPC 之 Binder 的补充 Android 跨进程通信 IPC 之 Binder 总结 小伙伴们如果有需要以上这些资料:私信发送 “面试” 直达获取,承诺100%免费! 本篇文章为转载内容。原文链接:https://blog.csdn.net/m0_62167422/article/details/127129133。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-11-15 10:35:50
218
转载
转载文章
...来,随着大数据技术的快速发展,Apache Spark作为一款高效、通用的大数据处理引擎,其在实时流处理、机器学习、SQL查询等方面展现出了强大的性能。据Databricks公司(Spark的主要贡献者)最新发布的博客,Apache Spark 3.2版本引入了一系列优化和新特性,比如对动态分区剪枝的改进、对Catalyst查询优化器的增强以及对Structured Streaming功能的扩展,这些都将为数据分析工作者提供更加强大且易用的工具。 与此同时,跨系统数据迁移与整合也是现代企业数据架构中的关键环节。近期,业界领先的云服务商如AWS、阿里云等相继推出了基于Spark的无缝数据集成服务,支持从Hadoop、MySQL等多种数据源到目标数据库的高效迁移,同时强化了数据转换、清洗以及合规性检查等功能,使得在整个数据生命周期管理中,数据工程师能够更加便捷地实现异构数据源之间的同步与融合。 此外,针对电商领域的数据分析实战,可参考某电商平台公开的年度报告,了解其如何运用Spark SQL结合各类大数据技术挖掘用户行为模式、预测销售趋势,并依据地区、时间等维度精细化运营策略,从而提升整体业务表现。这将有助于读者对照实际案例,深化对文中所述统计分析方法在实际场景中的应用理解。 综上所述,紧跟大数据技术和应用的发展趋势,持续探索Spark SQL在数据处理及跨系统迁移方面的最佳实践,结合行业实例深入解析,将助力我们更好地应对日益增长的数据挑战,为企业决策提供强有力的数据支撑。
2023-09-01 10:55:33
320
转载
MemCache
...,专门负责在服务器间快速传递数据。这货可厉害了,能大大提高咱们程序跑起来的速度和反应灵敏度,简直就是程序员的得力助手,能让网站运行得跟开挂了一样流畅!所以,如果你想要让自己的应用飞起来,Memcached绝对是你的不二之选!然而,随着业务复杂度的增加,数据版本控制的需求变得愈发重要。本文将探讨如何在Memcached中实现多版本控制,旨在为开发者提供一种有效管理数据版本的方法。 第一部分:理解多版本控制的必要性 在许多场景下,同一数据项可能需要多个版本来满足不同需求。例如,在电商应用中,商品信息可能需要实时更新价格、库存等数据;在社交应用中,用户评论或帖子可能需要保留历史版本以支持功能如撤销操作。这种情况下,多版本控制显得尤为重要。 第二部分:Memcached的基本原理与限制 Memcached通过键值对的方式存储数据,其设计初衷是为了提供快速的数据访问,而不涉及复杂的数据结构和事务管理。这就好比你有一款游戏,它的规则设定里就没有考虑过时间旅行或者穿越时空的事情。所以,你不能在游戏中实现回到过去修改错误或者尝试不同的未来路径。同理,这个系统也一样,它的设计初衷没有考虑到版本更新时的逻辑问题,所以自然也就无法直接支持多版本控制了。 第三部分:实现多版本控制的方法 1. 使用命名空间进行版本控制 一个简单的策略是为每个数据项创建一个命名空间,其中包含当前版本的键和历史版本的键。例如: python import memcache mc = memcache.Client(['127.0.0.1:11211'], debug=0) def set_versioned_data(key, version, data): mc.set(f'{key}_{version}', data) mc.set(key, data) 保存最新版本 设置数据 set_versioned_data('product', 'v1', {'name': 'Product A', 'price': 10}) 更新数据并设置新版本 set_versioned_data('product', 'v2', {'name': 'Product A (Updated)', 'price': 15}) 2. 利用时间戳进行版本控制 另一种方法是在数据中嵌入一个时间戳字段,作为版本标识。这种方法在数据频繁更新且版本控制较为简单的情况下适用。 python import time def set_timestamped_data(key, timestamp, data): mc.set(f'{key}_{timestamp}', data) mc.set(key, data) 设置数据 set_timestamped_data('product', int(time.time()), {'name': 'Product A', 'price': 10}) 更新数据 set_timestamped_data('product', int(time.time()) + 1, {'name': 'Product A (Updated)', 'price': 15}) 第四部分:优化与挑战 在实际应用中,选择何种版本控制策略取决于具体业务需求。比如说,假设你老是得翻查过去的数据版本,那用时间戳或者命名空间跟数据库的搜索功能搭伙用,可能会是你的最佳选择。就像你去图书馆找书,用书名和出版日期做检索,比乱翻一气效率高多了。这方法就像是给你的数据做了个时间轴或者标签系统,让你想看哪段历史一搜就出来,方便得很!同时,考虑到内存资源的限制,应合理规划版本的数量,避免不必要的内存占用。 结论 Memcached本身不提供内置的多版本控制功能,但通过一些简单的编程技巧,我们可以实现这一需求。无论是使用命名空间还是时间戳,关键在于根据业务逻辑选择最适合的实现方式。哎呀,你知不知道在搞版本控制的时候,咱们得好好琢磨琢磨性能优化和资源管理这两块儿?这可是关乎咱们系统稳不稳定的头等大事,还有能不能顺畅运行的关键!别小瞧了这些细节,它们能让你的程序像开了挂一样,不仅跑得快,而且用起来还特别省心呢!所以啊,做这些事儿的时候,可得细心点,别让它们成为你系统的绊脚石! 后记 在开发过程中,面对复杂的数据管理和版本控制需求,灵活运用现有工具和技术,往往能取得事半功倍的效果。嘿!小伙伴们,咱们一起聊聊天呗。这篇文章呢,就是想给那些正跟咱们遇到相似难题的编程大神们一点灵感和方向。咱们的目标啊,就是一块儿把技术这块宝地给深耕细作,让它开出更绚烂的花,结出更甜美的果子。加油,程序员朋友们,咱们一起努力,让代码更有灵魂,让技术更有温度!
2024-09-04 16:28:16
98
岁月如歌
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
sudo !!
- 使用sudo权限重新执行上一条命令。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"