如果您想了解php–为什么此代码生成的随机代码存储为7位数而不是8位数和编写php程序产生一个随机数的知识,那么本篇文章将是您的不二之选。我们将深入剖析php–为什么此代码生成的随机代码存储为7位数而
如果您想了解php – 为什么此代码生成的随机代码存储为7位数而不是8位数和编写php程序产生一个随机数的知识,那么本篇文章将是您的不二之选。我们将深入剖析php – 为什么此代码生成的随机代码存储为7位数而不是8位数的各个方面,并为您解答编写php程序产生一个随机数的疑在这篇文章中,我们将为您介绍php – 为什么此代码生成的随机代码存储为7位数而不是8位数的相关知识,同时也会详细的解释编写php程序产生一个随机数的运用方法,并给出实际的案例分析,希望能帮助到您!
本文目录一览:- php – 为什么此代码生成的随机代码存储为7位数而不是8位数(编写php程序产生一个随机数)
- 32位数据转8位数据和8位数据转32位数据
- C# 按照相应逻辑生成指定位数的随机数
- CC++ 生成各位数不相等的随机数
- Foxnic-Web 代码生成 (2) —— 代码生成的配置类
php – 为什么此代码生成的随机代码存储为7位数而不是8位数(编写php程序产生一个随机数)
下面的代码生成八位数,但在db中存储时有时存储为7位数.db列宽为int(11),db为mysql(5.0.45)
srand ((double) microtime( )*1000000);
$maxid = rand(0,100000000);
$mtidno = str_pad($maxid,8);
$shuffled = str_shuffle($mtidno);
echo $shuffled;
解决方法:
首先,通过使用这样的str_pad,您将引入空格,这些空格可以进入“随机”数字的中间.
将str_pad调用更改为:
str_pad($maxid, 8, "0");
摆脱空间.但请注意,其他问题提供了创建随机8位数字的更好方法.
然后,当您的随机播放结果以0开始时,它们将会下降.
要解决此问题,您可以在数据库中使用CHAR(8).然后它将显示前导零.
32位数据转8位数据和8位数据转32位数据
1。32位数据转换为8位数据
UINT32 m_num32[512];//32里面有参数 UINT8 m_num8[2048]; UINT8 m_temp; memset(m_num8,2048); for(int i = 0; i < 512; i++) { m_temp = m_num32[i] >> 24; m_num8[i] = m_temp; m_temp = m_num32[i] >> 16; m_num8[i + 512] = m_temp; m_temp = m_num32[i] >> 8; m_num8[i + 1024] = m_temp; m_temp = m_num32[i]; m_num8[i + 1536] = m_temp; }
2.8位数据转换位32位数据
UINT32 m_num32[512]; UINT8 m_num8[2048];//8里面有数据 UINT8 m_temp; memset(m_num32,512); for(int i = 0; i < 512; i++) { m_temp = m_num8[i]; m_num32[i] |= m_temp << 24; m_temp = m_num8[i + 512]; m_num32[i] |= m_temp << 16; m_temp = m_num8[i + 1024]; m_num32[i] |= m_temp << 8; m_temp = m_num8[i + 1536]; m_num32[i] |= m_temp; }
C# 按照相应逻辑生成指定位数的随机数
1
//生成23位的随机数
public class RandomHash
2 {
3 public static System.Collections.Generic.Dictionary<string, HashSet<string>> Hashtable = new Dictionary<string, HashSet<string>>();
4
5 /// <summary>
6 /// Check digit(模10)
7 /// </summary>
8 /// <param name="num"></param>
9 /// <returns></returns>
10 public static string Genchecknum(string num)
11 {
12 string result = string.Empty;
13 try
14 {
15 if (num.Length == 22)
16 {
17 int sum = 0;
18 for (int i = 0; i < 22; i++)
19 {
20 int dit = 0;
21 //is Odd
22 if (Convert.ToBoolean(i % 2))
23 {
24 dit = int.Parse(num.Substring(i, 1)) * 2;
25 if (dit > 9)
26 dit = dit - 9;
27 }
28 else
29 {
30 dit = int.Parse(num.Substring(i, 1));
31 }
32 sum = sum + dit;
33 }
34 double doublesum = Math.Ceiling(Convert.ToDouble(sum) / 10) * 10;
35 result = (doublesum - sum).ToString();
36 }
37 }
38 catch
39 {
40 }
41 return result;
42 }
43
44 public static string GenRandom(string acct, string country, string type, string tranName)
45 {
46 string refnum = string.Empty;
47 Random random = new Random();
48 DateTime dt = DateTime.Now;
49 string acctnum = string.Empty;
50 string prefix = string.Empty;
51 string fieldType = string.Empty;
52 string binNum = string.Empty;
53 try
54 {
55 prefix = "7";
56 acctnum = binNum == null ? acct.Substring(0, 6) : binNum;
57 }
58 catch (Exception ex)
59 {
60 throw ex;
61 }
62 string ID = dt.ToString("yyyyMMddHHmmss");
63 {
64 if (Hashtable.ContainsKey(ID))
65 {
66 bool isnotunique = true;
67 int runnum = 0;
68 do
69 {
70 string ran = random.Next(99999).ToString("00000");
71 //refNum 由站位数字prefix + acct账号的前6位 + 年份的最后一位数字 + 当天是当年的第多少天 + 当前的HHmmss + 五位的随机数, 以及 校验生成的一位数字
72 refnum = prefix + acctnum + dt.Year.ToString().Substring(3, 1) + dt.DayOfYear.ToString("000") + dt.ToString("HHmmss") + ran;
73
74 string checknum = Genchecknum(refnum);
75 refnum = refnum + checknum;
76 //插入非重的Refnum到Hashtable中去,确保同一秒种生成的RefNum不出现重复
77 if (!Hashtable[ID].Contains(refnum))
78 {
79 isnotunique = false;
80 Hashtable[ID].Add(refnum);
81 }
82 //循环再获取新的Refnum
83 runnum++;
84 if (runnum > 50000)
85 {
86 dt = DateTime.Now;
87 ID = dt.ToString("yyyyMMddHHmmss");
88 }
89 } while (isnotunique);
90
91 }
92 else
93 {
94 Hashtable.Clear();
95 string ran = random.Next(99999).ToString("00000");
96 refnum = prefix + acctnum + dt.Year.ToString().Substring(3, 1) + dt.DayOfYear.ToString("000") + dt.ToString("HHmmss") + ran;
97
98 string checknum = Genchecknum(refnum);
99 refnum = refnum + checknum;
100 HashSet<string> hs = new HashSet<string>();
101 hs.Add(refnum);
102 Hashtable.Add(ID, hs);
103 }
104 }
105 return refnum;
106 }
107 }
CC++ 生成各位数不相等的随机数
最近想写一个1A2B的小游戏来练习一下,结果在第一步生成随机数的时候就遇到了一点点问题。
游戏初始化时需要先生成一个四位随机数,且各位各不相等。于是最开始的思路是生成一个整数数组,只需要判断生成的随机数字是否跟之前的数字有重复,有则重新生成即可,但是之后发现两个问题。首先是,函数每次调用后生成的随机数是一样的。第二,生成的随机数如果0在第一位,则调用itoa函数时会被舍弃掉。
后来研究中发现,出现的原因是srand放在了函数里,每次调用函数都就重置随机数种子至初始值,于是就会出现生成的随机数都一样的情况。至于第二种错误,可以通过另一种方式来巧妙避免。代码如下,代码中的思路为:
先生成一个0-9的整数数组,再随机从中取一个数,只要不等于-1就将其取出放置到要生成的随机数中,并将该位置为-1。这样做也能提高一点点效率,而不用去删除数组成员。
1 /****************************************************************************** 2 *函数名称:void GetRandom(char * random) 3 *函数功能:产生一个各位数不相等的四位随机数 4 *入口参数:random为返回的随机数 5 *返 回 值:无 6 *备 注:先生成一个0-9的整数数组,再随机从中取四个数,每取一个将该位置为-1 7 *******************************************************************************/ 8 void GetRandom(char * random){ 9 int i,j[10],k; 10 for (i = 0; i < 10; i++){ 11 j[i] = i; 12 } 13 for(i = 4; i++14 //生成第i个随机数 15 k = (int)rand() % 10;k为下标 16 while (j[k] == -117 k = (k + 1) % ; 18 } 19 random[i] = '0' + j[k]; 20 j[k] = -; 21 22 }
Foxnic-Web 代码生成 (2) —— 代码生成的配置类
Foxnic-Web 代码生成 (2) —— 代码生成的配置类
概述
在上一节,我们已经讲述了代码生成的基本步骤,但是对细节部分并未展开。利用 Foxnic-Generator 包进行代码生成的方式是多种多样的,我们这里提到的配置类这是其中一种,例如 在 Foxnic-EAM 项目里,有很多的代码生成非使用配置类来完成的。
我们优先选择配置类讲解,显然配置类有其优势。首先,配置类按数据表隔离,一数据表一模块一个配置类。其次,在配置类内部,按配置对象的不同,分别在不同的方法内进行配置代码的编写。例如,配置模型时在 configModel 方法内编写配置代码,配置字段时在 configFields 方法内编写配置代码。
那么,代码生成的配置为什么要用 Java 类,而不是用 Json 、XML 或 YML 呢?首先,不管是 Json 、XML 或 YML、Java,都是在编辑器敲文本。那么哪一种方式敲文本是最方便的呢,自然是 Java 了,因为有开发工具强大的支持。
本文中的示例代码均可在 https://gitee.com/LeeFJ/foxni... 项目中找到,本文对照 webfull 项目讲解。
配置类
代码生成配置类都是 ModuleCodeConfig 类的子类,在 ModuleCodeConfig 类内定义了若干方法,这些方法可以让我们分门别类的对模块代码的方方面面进行配置。在生成代码时,这些方法会按照一定的顺序进行调用,最终生成我们想要的代码。我们先来看一个示例:
package org.github.foxnic.web.generator.module.mall;
import com.github.foxnic.generator.builder.business.option.ServiceOptions;
import com.github.foxnic.generator.builder.model.PoClassFile;
import com.github.foxnic.generator.builder.model.VoClassFile;
import com.github.foxnic.generator.builder.view.option.*;
import com.github.foxnic.generator.config.WriteMode;
import com.leefj.webfull.constants.db.WebFullTables.WEBFULL_EXAMPLE_ORDER;
import com.leefj.webfull.domain.example.Address;
import com.leefj.webfull.domain.example.meta.OrderMeta;
import com.leefj.webfull.proxy.example.AddressServiceProxy;
import org.github.foxnic.web.generator.module.BaseCodeConfig;
public class ExampleOrderConfig extends BaseCodeConfig<WEBFULL_EXAMPLE_ORDER> {
/**
* 配置模型,为 po 和 vo 添加 额外的属性等
*/
@Override
public void configModel(PoClassFile poType, VoClassFile voType) {
poType.addSimpleProperty(Address.class,"address","收件地址","关联的收件地址对象");
}
/**
* 配置字段
*/
@Override
public void configFields(ViewOptions view) {
// ID 字段通常隐藏
view.field(WEBFULL_EXAMPLE_ORDER.ID).basic().hidden();
// NAME 字段,单行文本框
view.field(WEBFULL_EXAMPLE_ORDER.ORDER_NO)
// 搜索栏:设置模糊搜索
.search().fuzzySearch()
// 表格列:指定对齐方式
.table().alignLeft()
// 表单:指定表单编辑器为文本输入框,并指定默认值
.form().textInput()
// 表单校验:必填
.form().validate().required()
;
// NAME 字段,单行文本框
view.field(WEBFULL_EXAMPLE_ORDER.ADDRESS_ID)
.basic().label("收件地址")
.form().selectBox()
.queryApi(AddressServiceProxy.QUERY_LIST).valueField("id").textField("address")
.fillWith(OrderMeta.ADDRESS)
// 表单校验:必填
.form().validate().required()
;
}
/**
* 配置搜索
*/
@Override
public void configSearch(ViewOptions view, SearchAreaOptions search) {
// 搜索布局
search.inputLayout(new Object[]{
WEBFULL_EXAMPLE_ORDER.ORDER_NO
});
}
/**
* 配置 List 表格
*/
@Override
public void configList(ViewOptions view, ListOptions list) {
list.operationColumn().addActionButton("明细","openItems");
}
/**
* 配置表单
*/
@Override
public void configForm(ViewOptions view, FormOptions form, FormWindowOptions formWindow) {
formWindow.width("800px");
form.labelWidth(85);
}
/**
* 配置源码覆盖
*/
@Override
public void configOverrides() {
//文件生成覆盖模式
context.overrides()
.setServiceIntfAnfImpl(WriteMode.COVER_EXISTS_FILE) //服务与接口
.setControllerAndAgent(WriteMode.COVER_EXISTS_FILE) //Rest
.setPageController(WriteMode.COVER_EXISTS_FILE) //页面控制器
.setFormPage(WriteMode.COVER_EXISTS_FILE) //表单HTML页
.setListPage(WriteMode.COVER_EXISTS_FILE) //列表HTML页
.setExtendJsFile(WriteMode.COVER_EXISTS_FILE);
}
/**
* 配置服务代码
*/
@Override
public void configService(ServiceOptions service) {
}
public ExampleOrderConfig() {
super("webfull-service-example", WEBFULL_EXAMPLE_ORDER.$TABLE, "webfull_example_");
}
}
这是生成订单管理代码的配置,我们可以看到这个配置类已经实现了 configModel、configFields、configSearch、configList、configForm、configOverrides、configService 这几个方法。下面我们逐个介绍一下这些方法作用。
方法 | 用途 |
---|---|
configModel | 配置模型,配置PO、VO或增加新的模型。 |
configFields | 配置字段,配置字段在表格、表单、搜索框内的表现形式。 |
configView | 配置视图 |
configSearch | 配置搜索栏 |
configList | 配置表格、列表 |
configForm | 配置表单 |
configController | 配置接口控制器 |
configService | 配置服务 |
configBPM | 可选,如果开启流程可以配置改方法,用于流程相关的配置。 |
configOverrides | 配置代码文件的覆盖模式。 |
模块的配置类,最终被注册到 WebFullCodeStarter ,启动 WebFullCodeStarter ,按控制台提示输入序号生成对应的模块代码。
小结
本节主要介绍了在 Foxnic-SQL 和 oxnic-Web 代码生成时配置类的原理与作用,本文明确了配置类中每个方法的作用,按需实现即可。
配置类的每个方法如何实现,我们并未在本节展开,后面的章节中我们将逐一介绍。
相关项目
https://gitee.com/LeeFJ/foxnic
https://gitee.com/LeeFJ/foxni...
https://gitee.com/lank/eam
https://gitee.com/LeeFJ/foxni...
官方文档
http://foxnicweb.com/docs/doc...
我们今天的关于php – 为什么此代码生成的随机代码存储为7位数而不是8位数和编写php程序产生一个随机数的分享已经告一段落,感谢您的关注,如果您想了解更多关于32位数据转8位数据和8位数据转32位数据、C# 按照相应逻辑生成指定位数的随机数、CC++ 生成各位数不相等的随机数、Foxnic-Web 代码生成 (2) —— 代码生成的配置类的相关信息,请在本站查询。
本文标签: