首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

我的数据访问函数库的源代码(三)——返回结构数组

/* 2008 4 25 更新 */ 我的数据访问函数库的源码。整个类有1400行,原先就是分开来写的,现在更新后还是分开来发一下吧。 第三部分:返回结构 数组,这个是专门针对网页来设计的。...比如“yyyy-MM-dd HH:mm:ss dddd”         /// 返回BaseTitle结构的数组。...比如“yyyy-MM-dd HH:mm:ss dddd”         /// 返回BaseTitle结构的数组。...ID 传入查询语句,返回第一条记录的第一的字段的值             SetCommand(SQL,);        //设置command             SqlDataReader...ID 传入查询语句,返回第一条记录的第一的字段的值             SetCommand(SQL,);        //设置command             SqlDataReader

1.4K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    为什么我写不出面向对象的代码

    那时书本或者网上是这么解释的 ““面向对象”是专指在程序设计中采用封装、继承、多态和抽象等设计方法。 ” 那么上面的案例代码也有抽象,也有封装,为什么还是算面向过程思维呢。 那么什么是面向对象呢?...关于DDD领域驱动设计,推荐书籍: “《领域驱动设计:软件核心复杂性应对之道》 《实现领域驱动设计》 ” 为什么我们在使用贫血模型 看了上面的代码,我们可能会疑问:我使用贫血模型开发挺好的啊?...为什么还要使用充血模型?也没看出什么不一样啊? 传统开发模式的贫血模型,将数据与业务彻底隔离。...因此我总结为什么人们更愿意使用贫血模型呢: “ 充血模型相对贫血模型存在一定的设计难度,你需要多花时间思考哪些是对象本身的行为 面向过程的编程思想根深蒂固,很难改变 对代码没有太大负责态度,认为怎么简单怎么来...那么建议你多做一些的思考: 1.我的代码是不是面向对象的代码 2.我的代码设计是否遵循 高内聚,低耦合的设计标准 3.我的代码是否遵循设计原则,如单一职责原则,开闭原则等 4. ...

    1.2K20

    「我读」PL 观点 | 未定义行为有利的一面

    本文是我学习这篇文章的笔记,内容是围绕 UB以及 Ralf 的文章进行的二次创作,仅供参考。...什么是未定义行为 在计算机程序设计中,未定义行为(英语:undefined behavior)是指执行某种计算机代码所产生的结果,这种代码在当前程序状态下的行为在其所使用的语言标准中没有规定。...虽然编译器实现可能会针对未定义行为给出诊断信息,但保证编写的代码中不引发未定义行为是程序员自己的责任。这种假设的成立,通常可以让编译器对代码作出更多优化,同时也便于做更多的编译期检查和静态程序分析。...Rust 里的未定义行为 程序员承诺,代码不会出现未定义行为。作为回报,编译器承诺以这样的方式编译代码:最终程序在实际硬件上的表现与源程序根据Rust抽象机的表现相同。...然而,Unsafe 的内涵更加广泛:所有在 Rust 中产生未定义行为的代码是 Unsafe 的,但并非所有 Unsafe 的代码都会产生 未定义行为。

    1.7K30

    为什么if-else会影响我的代码的复杂度

    关于if-else的争议 我之前写了一篇文章《我用规则引擎消除if语句,提高了代码的可扩展性》,这篇文章我想阐述的观点是复杂的if语句可能会影响代码的阅读和代码的扩展性,会将非业务的条件逻辑与业务逻辑混合在一起...时间长了代码会越来越臃肿,因此这种情况下我推荐使用一些设计模式例如策略模式,责任链模式等去优化if语句带来的问题,文中我发现使用规则引擎也能实现类似效果,因此介绍了怎么使用规则引擎Easy Rules去取代...这里我要阐明我的一个观点: “我的观点并不是说,我们在编码时不能使用if-else,而是说我们不应该简陋地用if-else去实现业务的分支流程,因为这样随意的代码堆砌很容易堆出一座座"屎山"。...” 当我们存在不同的业务逻辑时,我们通常习惯使用if-else来实现这些不同的逻辑,时间长了,代码就会难以维护。我相信大部分人写过下面类似的代码。...屎山代码雏形 上面的代码(基于实际项目的伪代码),大家看了后有什么感想。如果我们需要修改上面的条件逻辑,我相信编码者本人都会被这样的代码绕晕,更不用说后面接手的开发了。

    1.5K10

    为什么我的BERT不行?

    当然了,bad case分析这块我也聊了很多,多分析能发现其中的端倪,知道模型需要什么,该怎么处理,我再放一遍在这里,希望能好好阅读。...模型、代码层的问题 检查有没有bug,代码整体流程是否有问题,无论是训练还是推理,这个就得自己检查和使用了,这个没法解,只能自己debug,找问题然后解决。...这里背后的逻辑可以参考我这篇文章: 心法利器[45] | 模型需要的信息提供够了吗 训练问题 针对训练问题,其实也就是一个经验的问题了,多弄其实问题就会小很多,大家可以多去看各个论文使用的超参,一般调的差不多基本都不会有的...,当然这里也是要避免代码bug。...而文章本身的输出并非是按照这个思路走,而是从一些大家经常问的点深入来讨论,希望能从我的角度和风格来思考和回答问题。

    1.2K20

    为什么getTime()返回1970年至今的毫秒?

    今天在写new Date()时候,无意中发现了一个很有意思的方法,getTime(),百度了一下,有人说是计算从1970年1月1日至今的毫秒数 为什么要是1970年呢?...比如java类代码: Date date = new Date(0); System.out.println(date); // 打印出来的结果:Thu Jan 01 08:00:00 CST 1970...但这依然没很好的解释"为什么",出于好奇,继续Google,总算找到了答案: http://en.wikipedia.org/wiki/Unix_time 这里的解释是: 最初计算机操作系统是32位,而时间也是用...到这里,我想问题的答案已经出来了: 因为用32位来表示时间的最大间隔是68年,而最早出现的UNIX操作系统考虑到计算机产生的年代和应用的时限综合取了1970年1月1日作为UNIX TIME的纪元时间(开始时间...最后一个问题: 上面System.out.println(new Date(0)),打印出来的时间是8点而非0点,原因是存在系统时间和本地时间的问题,其实系统时间依然是0点,只不过我的电脑时区设置为东8

    1.2K30

    包验证返回的错误代码

    本文仅供参考,其中列出了由包验证生成的所有错误代码。 错误代码列表 诊断 ID 说明 建议的操作 PKV0001 缺少兼容框架的编译时资产。 将适当的目标框架添加到项目中。...PKV0002 缺少兼容框架和运行时的运行时资产。 将相应运行时的适当资产添加到包中。 PKV0003 缺少兼容框架的运行时独立资产。 将适当的运行时独立目标框架添加到项目中。...PKV0004 缺少编译时资产的兼容运行时资产。 将适当的运行时资产添加到包中。 PKV0005 缺少编译时资产的兼容运行时资产和受支持的运行时标识符。 将适当的运行时资产添加到包中。...CP0001 所比较的程序集中缺少该程序集外部可见的所需类型、枚举、记录或结构。 将缺少的类型添加到缺少该类型的程序集中。 CP0002 所比较的程序集中缺少在该程序集外部可见的所需成员。...将缺少的成员添加到缺少该成员的程序集中。 CP0003 程序集标识的某些部分(名称、公钥令牌、区域性、可重定目标属性或版本)对于比较的双方都不匹配。 更新程序集标识,以便比较的双方都匹配。

    1.8K30

    为什么我要写自己的框架?

    运行的时候不是这边有问题就是那边出现了错误。原来在以前我只想着如何使用它,如何整合别人的代码,却忘了一个最最本真的东西:创造!我几乎失去了编程的能力,变成了电脑面前的代码复制员。...结果是令人沮丧的,当天我都在思考这个问题:我今后到底能干嘛?是继续做一个代码复制员,还是打起精神,看看这些框架的背后有什么内容吧!...于是我又开始新的一轮学习,看大量的书籍,有一天我重新打开Yii框架在我当时看起来很难理解的代码的时候我发现:我居然有点明白它的工作原理,知道整体的架构了!...下图是我现在框架的架构。代码太多,就不做展示了。 ?...js框架 最后说一下我认为的好处: 1、对整体架构的思考 2、提高自己的创造力 3、提高自己独立思考的能力 4、提高自己阅读别人代码的能力 5、用到和认识了大量的编程语言内置函数 下面是我的一点小建议:

    1.3K20

    为什么我的Redis这么“慢”?

    解决方案就是,不使用这些复杂度较高的命令,并且一次不要获取太多的数据,每次尽量操作少量的数据,让 Redis 可以及时处理返回。...此时你需要检查你的业务,是否真的存在集中过期的代码,一般集中过期使用的命令是 expireat 或 pexpireat 命令,在代码中搜索这个关键字就可以了。...下面就针对这两块,分享一下我认为比较合理的 Redis 使用和运维方法,不一定最全面,也可能与你使用 Redis 的方法不同,但以下这些方法都是我在踩坑之后总结的实际经验,供你参考。...业务层面 业务层面主要是开发人员需要关注,也就是开发人员在写业务代码时,如何合理地使用 Redis。...总结 以上就是我在使用 Redis 和开发 Redis 相关中间件时,总结出来 Redis 推荐的实践方法,以上提出的这些方面,都或多或少在实际使用中遇到过。

    3.7K10

    代码模板 | 我的代码没有else

    嗯,我的代码没有else系列,一个设计模式业务真实使用的golang系列。 ? 前言 本系列主要分享,如何在我们的真实业务场景中使用设计模式。...比如抽奖系统的抽奖接口,为什么: 抽奖的步骤是稳定不变的 -> 不变的算法执行步骤 不同抽奖类型活动在某些逻辑处理方式可能不同 -> 变的某些算法 怎么用「模板模式」?...关于怎么用,完全可以生搬硬套我总结的使用设计模式的四个步骤: 业务梳理 业务流程图 代码建模 代码demo 业务梳理 我通过历史上接触过的各种抽奖场景(红包雨、糖果雨、打地鼠、大转盘(九宫格)、考眼力、...------------ //我的代码没有`else`系列 //模板模式 //@auhtor TIGERB //------------------...我的代码没有`else`,只是一个在代码合理设计的情况下自然而然无限接近或者达到的结果,并不是一个硬性的目标,务必较真。 2.

    1K30

    代码组件 | 我的代码没有else

    嗯,我的代码没有else系列,一个设计模式业务真实使用的golang系列。 ? 前言 本系列主要分享,如何在我们的真实业务场景中使用设计模式。...关于怎么用,完全可以生搬硬套我总结的使用设计模式的四个步骤: 业务梳理 业务流程图 代码建模 代码demo 业务梳理 按照如上某东的订单结算页面的示例,我们得到了如下的订单结算页面模块组成图: ?...----------------------- //我的代码没有`else`系列 //组合模式 //@auhtor TIGERB //-------...我的代码没有`else`,只是一个在代码合理设计的情况下自然而然无限接近或者达到的结果,并不是一个硬性的目标,务必较真。 2....---- 我的代码没有else系列 更多文章 代码模板 | 我的代码没有else 链式调用 | 我的代码没有else 点击https://github.com/TIGERB/easy-tips/tree

    1.2K10

    为什么 useState 返回的是 array 而不是 object?

    前言 这是我今天收到的一条推送文章,发现自己好像也没有去思考过这个问题,于是点进来了 明白了原因之后,想用自己的话梳理一遍,分享给其他还不了解的同学 正文 先来看看 useState 的日常用法 const...[count, setCount] = useState(0) 这里可以看到 useState 返回的是一个数组,那么为什么是返回数组而不是返回对象呢?...为什么是返回数组而不是返回对象 要弄懂这个问题要先明白 ES6 的解构赋值,来看 2 个简单的例子: 数组的解构赋值 const foo = [1, 2, 3]; const [one, two, three...,这个问题就很好解释了 如果 useState 返回的是数组,那么使用者可以对数组中的元素命名,代码看起来也比较干净 如果 useState 返回的是对象,在解构对象的时候必须要和 useState 内部实现返回的对象同名...总结 useState 返回的是 array 而不是 object 的原因就是为了降低使用的复杂度,返回数组的话可以直接根据顺序解构,而返回对象的话要想使用多次就得定义别名了 首发自:为什么 useState

    2.3K20

    谁在调试我的代码?

    背景 为了提高开发的软件产品安全性,大部分选择的方案防护方案是,通过用成熟的加固软件进行对自己研发的软件做防护,从而达到对软件搭建一个安全防护墙。...加固软件主要做的两件事,对软件中关键代码的保护以及提高对软件逆向反编译的门槛。 那么软件安全性防护墙的第一道门那就是反调试。反调试技术又细分为静态反调试和动态反调试。...如果程序处于调试状态的情况下,那么这个函数的返回返回真,否则返回假。...CloseHandle 检测 利用异常捕获机制,给CloseHandle函数一个无效的句柄作为输入参数,在程序在没有被调试时,将会返回一个错误代码;而程序被调试器调试时,将会触发一个EXCEPTION_INVALID_HANDLE...反调试和反反调试的方案都是相对的,并不是绝对的安全。反调试强度更高的方案在于驱动层去检测实现。

    67331

    还记得当初为什么选择计算机?我的代码人生旅程‍

    还记得当初为什么选择计算机?我的代码人生旅程‍ 摘要 在这篇博客中,我将探讨计算机科学的魅力、编程的乐趣和技术对个人成长的影响。...引言 大家好,我是猫头虎博主‍,今天和大家分享我的计算机之旅。自从我选择了计算机,我的生活就像是打开了一扇通往未知世界的大门。让我们一起探索这个充满可能的领域吧! 1. 我为什么选择计算机行业?...我现在还从事计算机相关行业吗? 2.1 持续的热情与挑战 没错,我依然热爱这个行业。现在,我不仅仅是编写代码,还在探索人工智能、大数据等前沿技术。每一天都充满了新的挑战和机遇。...2.2 从学习者到分享者 我开始撰写技术博客,分享我在这个领域的所学所感。我希望我的经验能够帮助到正如当年的我一样的编程初学者。 3. 计算机对我的人生道路有何帮助?...3.2 开阔视野,连接世界 计算机科学让我认识到了这个世界的无限可能。我通过网络认识了来自世界各地的朋友,交流技术,分享经验。 小结 计算机不仅是我的职业,更是我探索世界的工具。

    10510

    为什么 2!=false 和 2!=true 返回的都是true

    前言 今天突然想起一个奇怪的问题,记录一下,我在控制台执行内容如下: 由上图可见,2 != false 和 2 != true 返回的值竟然都是true,那么为什么呢,请看下文: 1 !...= true 返回 true 的原因涉及到 JavaScript 中的类型转换和比较规则。 2 类型转换 当使用 !...根据 JavaScript 的转换规则,false 被转换为 0。 现在表达式变成了 2 != 0。 2 和 0 不相等,因此返回 true。 2 != true true 会被转换为数字类型。...根据 JavaScript 的转换规则,true 被转换为 1。 现在表达式变成了 2 != 1。 2 和 1 不相等,因此返回 true。 总结 2 !...= false 返回 true 是因为 2 和 0 不相等。 2 != true 返回 true 是因为 2 和 1 不相等。 这就是为什么 2 != false 和 2 !

    10910

    谁动了我的代码:代码混淆剖析

    好的代码混淆通常会使用所有这些方法,让混淆过的代码与原始的、未混淆的源代码难以区分。生成的代码看起来像是那么回事,这样会迷惑攻击者,并让逆向工程变得难以实施。...然而,要保证安全性,总是需要结合使用多种方法——如果一种方法失败,另一种方法仍然可以发挥作用——这也就是为什么说混淆和加密是很好的组合。...随机性的重要性 说到随机数,我们可以想象一台彩票机:机器的底部是旋转桨,让球在腔体内随机旋转,然后把球从管子里射出去,这意味着每个球都是随机挑选的。 你可能会问:为什么我们要在代码里使用随机元素?...这个库的目的是帮助我们生成随机数,或者我们可以称之为“伪随机数”。为什么是伪随机数?因为使用 rand() 生成的“随机”输出并不是真正随机的。...函数调用被复制到剪贴板(如果给定字符串之前被混淆了,可以是新生成的函数,也可以是现有的函数),因此用户可以直接粘贴它,而不是粘贴给定的字符串。 自动测试生成的函数,验证它是否会返回给定的字符串。

    59210
    领券