上周工作结束,来到斯凯网络也将近半个月来。 没有新人的感念,最多的是将自己当作一个战士。

     废话不多说,直接入正题,在没有仔细考虑问题之前我们总会 觉得:这尼玛的有毛线难度啊,不就是一个 int 转为char吗,直接把int 转化成string 然后打散不久可以了啊。  这个方案真的可以吗??

     我们若再仔细思考下,比如说将 1 转化为 “1”,12 转化为 “12”, 这样就可以了吗?

     但是我要问一个问题,这样用系统函数转化过程是很方便很简单,但是有谁知道转化过程中到底做了什么呢,假如要你自己写你会考虑到哪些呢?  对于一个C# 程序员来说,其实比较悲哀的一件事情是:我们一开始的固定思维是:int  转string 不就是一个 int a; a.toString() 的事情吗! 还有什么啊。。。压根没东西啊!  (本人以前也是开发C#的 哈哈!) 。  

              在这里我也深深的体会到C 的重要,以及为什么说C 的门槛高,而C#的门槛低。(本人自从学习objective-c之后也温习了不少C 知识唷 哈哈)

              答案很简单:做同样一件事情理解的深度是完全不一样的。    

              若是C 开发者则会反问C#:"啊?String类型在我们这里压根没有啊。再怎么说 string类型也无非是 char 的集合啊。所以将string 拆分开来也无非是 char。 因此对上面提出的12 转化为 ’12’  我就有个疑问:一个12 整数为什么要两个char? 若是三位数呢,则需要三个char?但是有一个很严重的问题是你有没有考虑过:在内存中 一个int 是需要4个字节,而一个char 只需要一个! 另外一个很重要的感念就是,在char 字符串家族中 他们是满足ASCII 码规范的。因此我们刚才提到的 ’1‘ 压根在内存结构中和 int 1 是完全不同的。"

            针对上面的种种疑问,所以我们把问题也稍微理清下把问题描述理解为:”在内存结构不变的情况下,怎样将int 数据存储在char中!“

      先列出 int 1内存数据:0x00000001;(注意:char‘1’ 内存数据是:00110001--0x31)

     所以我们可以将一个int 类型拆分4个char ;当然也就是:char[0] -0x00;char[1]-0x00;char[2]-0x00;char[3]-0x01; 

      哦,到这 为止,我们终于弄明白了!原来是这样啊,但是怎么样实现呢? 在程序的世界里要深刻理解一件事情就是:再我们逻辑上看起来很简单的事情,而在计算机世界都是不可想像的。。。。。

     呵呵,代码如下:

    @define BYTELENGTH 8;//8 bit 为一个字节

-(void) int2BytesWithValue:(int) value withByteLength: (int) byteLength withResult:(char*) result

{

    int shiftCount=0;

    for (int i=0; i<byteLength; ++i) {

        shiftCount=(byteLength-1-i)*BYTELENGTH;

        result[i]= (char)((value&(0x000000ff<<shiftCount))>>shiftCount);//注意 这里0x000000ff, 必须的不然结果可能会不一致

    }

}

 

//同样这里我也写出将 char* 反转化为int 类型吧。希望不要将C# 高级的思想所钝化。

-(int) bytes2IntWithValue:(char*) bytes withByteLength:(int) byteLength

{

    int result=0;

//   NSLog(@"int Length:%lu",  sizeof(int));

    for (int i=0; i<byteLength; ++i) {

         //这里若不 同或&0x000000ff 会出现意想不到的结果

        int temp=(int)((bytes[i]&0x000000ff)<<((byteLength-1-i)*BYTELENGTH));

         result|= temp;

    }

    return result;

}

  到此为止我才会说有所思考的说:“嗯, 这就对了!这是我想要的。。。。原来我以前一直不知道啊!还是谦虚点好啊!”;